barrier.h 694 B

12345678910111213141516171819202122232425262728
  1. #ifndef _H8300_BARRIER_H
  2. #define _H8300_BARRIER_H
  3. #define nop() asm volatile ("nop"::)
  4. /*
  5. * Force strict CPU ordering.
  6. * Not really required on H8...
  7. */
  8. #define mb() asm volatile ("" : : :"memory")
  9. #define rmb() asm volatile ("" : : :"memory")
  10. #define wmb() asm volatile ("" : : :"memory")
  11. #define set_mb(var, value) do { xchg(&var, value); } while (0)
  12. #ifdef CONFIG_SMP
  13. #define smp_mb() mb()
  14. #define smp_rmb() rmb()
  15. #define smp_wmb() wmb()
  16. #define smp_read_barrier_depends() read_barrier_depends()
  17. #else
  18. #define smp_mb() barrier()
  19. #define smp_rmb() barrier()
  20. #define smp_wmb() barrier()
  21. #define smp_read_barrier_depends() do { } while(0)
  22. #endif
  23. #endif /* _H8300_BARRIER_H */