summaryrefslogtreecommitdiff
path: root/pfinet/asm/system.h
blob: a631c91e279040d9dea4eb935dfe0737062cb5b8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
#include <cthreads.h>

/* This lock is held when "interrupts" are disabled. */
extern struct mutex global_interrupt_lock;

/* Save the "processor state" in the longword FLAGS. */
/* We define 1 to mean that global_interrupt_lock is held. */

#define save_flags(x) _real_save_flags (&x)
extern inline void 
_real_save_flags (u_long *flagsword)
{
  int locked;
  
  locked = !mutex_try_lock (&global_interrupt_lock);
  if (!locked)
    mutex_unlock (&global_interrupt_lock);
  *flagsword = locked;
}

/* Restore state saved in FLAGS. */
extern inline void
restore_flags (u_long flags)
{
  if (flags)
    mutex_try_lock (&global_interrupt_lock);
  else
    mutex_unlock (&global_interrupt_lock);
}

/* Prevent "interrupts" from happening. */
extern inline void 
cli ()
{
  mutex_try_lock (&global_interrupt_lock);
}

/* Permit "interrupts". */ 
extern inline void
sti ()
{
  mutex_unlock (&global_interrupt_lock);
}