blob: 467d9415a32e5d9ae4c331e6569fc4b26b55bfdb [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
Matt Fleming0c50f6f2009-06-13 22:23:27 +010013 raw_local_irq_save(flags);
Matt Fleming84fdf6c2009-01-20 21:14:38 +000014 v->counter += i;
Matt Fleming0c50f6f2009-06-13 22:23:27 +010015 raw_local_irq_restore(flags);
Paul Mundtec723fbe2006-12-07 20:33:38 +090016}
17
18static inline void atomic_sub(int i, atomic_t *v)
19{
20 unsigned long flags;
21
Matt Fleming0c50f6f2009-06-13 22:23:27 +010022 raw_local_irq_save(flags);
Matt Fleming84fdf6c2009-01-20 21:14:38 +000023 v->counter -= i;
Matt Fleming0c50f6f2009-06-13 22:23:27 +010024 raw_local_irq_restore(flags);
Paul Mundtec723fbe2006-12-07 20:33:38 +090025}
26
27static inline int atomic_add_return(int i, atomic_t *v)
28{
29 unsigned long temp, flags;
30
Matt Fleming0c50f6f2009-06-13 22:23:27 +010031 raw_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;
Matt Fleming0c50f6f2009-06-13 22:23:27 +010035 raw_local_irq_restore(flags);
Paul Mundtec723fbe2006-12-07 20:33:38 +090036
37 return temp;
38}
39
40static inline int atomic_sub_return(int i, atomic_t *v)
41{
42 unsigned long temp, flags;
43
Matt Fleming0c50f6f2009-06-13 22:23:27 +010044 raw_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;
Matt Fleming0c50f6f2009-06-13 22:23:27 +010048 raw_local_irq_restore(flags);
Paul Mundtec723fbe2006-12-07 20:33:38 +090049
50 return temp;
51}
52
53static inline void atomic_clear_mask(unsigned int mask, atomic_t *v)
54{
55 unsigned long flags;
56
Matt Fleming0c50f6f2009-06-13 22:23:27 +010057 raw_local_irq_save(flags);
Matt Fleming84fdf6c2009-01-20 21:14:38 +000058 v->counter &= ~mask;
Matt Fleming0c50f6f2009-06-13 22:23:27 +010059 raw_local_irq_restore(flags);
Paul Mundtec723fbe2006-12-07 20:33:38 +090060}
61
62static inline void atomic_set_mask(unsigned int mask, atomic_t *v)
63{
64 unsigned long flags;
65
Matt Fleming0c50f6f2009-06-13 22:23:27 +010066 raw_local_irq_save(flags);
Matt Fleming84fdf6c2009-01-20 21:14:38 +000067 v->counter |= mask;
Matt Fleming0c50f6f2009-06-13 22:23:27 +010068 raw_local_irq_restore(flags);
Paul Mundtec723fbe2006-12-07 20:33:38 +090069}
70
71#endif /* __ASM_SH_ATOMIC_IRQ_H */