#ifndef __ASM_SH_ATOMIC_IRQ_H #define __ASM_SH_ATOMIC_IRQ_H #include <linux/irqflags.h> /* * To get proper branch prediction for the main line, we must branch * forward to code at the end of this object's .text section, then * branch back to restart the operation. */ static inline void atomic_add(int i, atomic_t *v) { unsigned long flags; raw_local_irq_save(flags); v->counter += i; raw_local_irq_restore(flags); } static inline void atomic_sub(int i, atomic_t *v) { unsigned long flags; raw_local_irq_save(flags); v->counter -= i; raw_local_irq_restore(flags); } static inline int atomic_add_return(int i, atomic_t *v) { unsigned long temp, flags; raw_local_irq_save(flags); temp = v->counter; temp += i; v->counter = temp; raw_local_irq_restore(flags); return temp; } static inline int atomic_sub_return(int i, atomic_t *v) { unsigned long temp, flags; raw_local_irq_save(flags); temp = v->counter; temp -= i; v->counter = temp; raw_local_irq_restore(flags); return temp; } static inline void atomic_clear_mask(unsigned int mask, atomic_t *v) { unsigned long flags; raw_local_irq_save(flags); v->counter &= ~mask; raw_local_irq_restore(flags); } static inline void atomic_set_mask(unsigned int mask, atomic_t *v) { unsigned long flags; raw_local_irq_save(flags); v->counter |= mask; raw_local_irq_restore(flags); } #endif /* __ASM_SH_ATOMIC_IRQ_H */