.. | .. |
---|
30 | 30 | #define __LOCK(lock) \ |
---|
31 | 31 | do { preempt_disable(); ___LOCK(lock); } while (0) |
---|
32 | 32 | |
---|
| 33 | +#define __HARD_LOCK(lock) \ |
---|
| 34 | + do { ___LOCK(lock); } while (0) |
---|
| 35 | + |
---|
33 | 36 | #define __LOCK_BH(lock) \ |
---|
34 | 37 | do { __local_bh_disable_ip(_THIS_IP_, SOFTIRQ_LOCK_OFFSET); ___LOCK(lock); } while (0) |
---|
35 | 38 | |
---|
36 | 39 | #define __LOCK_IRQ(lock) \ |
---|
37 | 40 | do { local_irq_disable(); __LOCK(lock); } while (0) |
---|
38 | 41 | |
---|
| 42 | +#define __HARD_LOCK_IRQ(lock) \ |
---|
| 43 | + do { hard_local_irq_disable(); __HARD_LOCK(lock); } while (0) |
---|
| 44 | + |
---|
39 | 45 | #define __LOCK_IRQSAVE(lock, flags) \ |
---|
40 | 46 | do { local_irq_save(flags); __LOCK(lock); } while (0) |
---|
| 47 | + |
---|
| 48 | +#define __HARD_LOCK_IRQSAVE(lock, flags) \ |
---|
| 49 | + do { flags = hard_local_irq_save(); __HARD_LOCK(lock); } while (0) |
---|
41 | 50 | |
---|
42 | 51 | #define ___UNLOCK(lock) \ |
---|
43 | 52 | do { __release(lock); (void)(lock); } while (0) |
---|
44 | 53 | |
---|
45 | 54 | #define __UNLOCK(lock) \ |
---|
46 | 55 | do { preempt_enable(); ___UNLOCK(lock); } while (0) |
---|
| 56 | + |
---|
| 57 | +#define __HARD_UNLOCK(lock) \ |
---|
| 58 | + do { ___UNLOCK(lock); } while (0) |
---|
47 | 59 | |
---|
48 | 60 | #define __UNLOCK_BH(lock) \ |
---|
49 | 61 | do { __local_bh_enable_ip(_THIS_IP_, SOFTIRQ_LOCK_OFFSET); \ |
---|
.. | .. |
---|
52 | 64 | #define __UNLOCK_IRQ(lock) \ |
---|
53 | 65 | do { local_irq_enable(); __UNLOCK(lock); } while (0) |
---|
54 | 66 | |
---|
| 67 | +#define __HARD_UNLOCK_IRQ(lock) \ |
---|
| 68 | + do { hard_local_irq_enable(); __HARD_UNLOCK(lock); } while (0) |
---|
| 69 | + |
---|
55 | 70 | #define __UNLOCK_IRQRESTORE(lock, flags) \ |
---|
56 | 71 | do { local_irq_restore(flags); __UNLOCK(lock); } while (0) |
---|
57 | 72 | |
---|
| 73 | +#define __HARD_UNLOCK_IRQRESTORE(lock, flags) \ |
---|
| 74 | + do { hard_local_irq_restore(flags); __HARD_UNLOCK(lock); } while (0) |
---|
| 75 | + |
---|
58 | 76 | #define _raw_spin_lock(lock) __LOCK(lock) |
---|
59 | 77 | #define _raw_spin_lock_nested(lock, subclass) __LOCK(lock) |
---|
60 | 78 | #define _raw_read_lock(lock) __LOCK(lock) |
---|