blob: a0b348068cae66f4407760abde7013d0e7034f7a [file] [log] [blame]
Paul Mundtec723fbe2006-12-07 20:33:38 +09001#ifndef __ASM_SH_ATOMIC_IRQ_H
2#define __ASM_SH_ATOMIC_IRQ_H
3
4/*
5 * To get proper branch prediction for the main line, we must branch
6 * forward to code at the end of this object's .text section, then
7 * branch back to restart the operation.
8 */
9static inline void atomic_add(int i, atomic_t *v)
10{
11 unsigned long flags;
12
13 local_irq_save(flags);
Matt Fleming84fdf6c2009-01-20 21:14:38 +000014 v->counter += i;
Paul Mundtec723fbe2006-12-07 20:33:38 +090015 local_irq_restore(flags);
16}
17
18static inline void atomic_sub(int i, atomic_t *v)
19{
20 unsigned long flags;
21
22 local_irq_save(flags);
Matt Fleming84fdf6c2009-01-20 21:14:38 +000023 v->counter -= i;
Paul Mundtec723fbe2006-12-07 20:33:38 +090024 local_irq_restore(flags);
25}
26
27static inline int atomic_add_return(int i, atomic_t *v)
28{
29 unsigned long temp, flags;
30
31 local_irq_save(flags);
Matt Fleming84fdf6c2009-01-20 21:14:38 +000032 temp = v->counter;
Paul Mundtec723fbe2006-12-07 20:33:38 +090033 temp += i;
Matt Fleming84fdf6c2009-01-20 21:14:38 +000034 v->counter = temp;
Paul Mundtec723fbe2006-12-07 20:33:38 +090035 local_irq_restore(flags);
36
37 return temp;
38}
39
40static inline int atomic_sub_return(int i, atomic_t *v)
41{
42 unsigned long temp, flags;
43
44 local_irq_save(flags);
Matt Fleming84fdf6c2009-01-20 21:14:38 +000045 temp = v->counter;
Paul Mundtec723fbe2006-12-07 20:33:38 +090046 temp -= i;
Matt Fleming84fdf6c2009-01-20 21:14:38 +000047 v->counter = temp;
Paul Mundtec723fbe2006-12-07 20:33:38 +090048 local_irq_restore(flags);
49
50 return temp;
51}
52
53static inline void atomic_clear_mask(unsigned int mask, atomic_t *v)
54{
55 unsigned long flags;
56
57 local_irq_save(flags);
Matt Fleming84fdf6c2009-01-20 21:14:38 +000058 v->counter &= ~mask;
Paul Mundtec723fbe2006-12-07 20:33:38 +090059 local_irq_restore(flags);
60}
61
62static inline void atomic_set_mask(unsigned int mask, atomic_t *v)
63{
64 unsigned long flags;
65
66 local_irq_save(flags);
Matt Fleming84fdf6c2009-01-20 21:14:38 +000067 v->counter |= mask;
Paul Mundtec723fbe2006-12-07 20:33:38 +090068 local_irq_restore(flags);
69}
70
71#endif /* __ASM_SH_ATOMIC_IRQ_H */