barrier.h 743 B

1234567891011121314151617181920212223242526272829
  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. #define read_barrier_depends() do { } while (0)
  13. #ifdef CONFIG_SMP
  14. #define smp_mb() mb()
  15. #define smp_rmb() rmb()
  16. #define smp_wmb() wmb()
  17. #define smp_read_barrier_depends() read_barrier_depends()
  18. #else
  19. #define smp_mb() barrier()
  20. #define smp_rmb() barrier()
  21. #define smp_wmb() barrier()
  22. #define smp_read_barrier_depends() do { } while(0)
  23. #endif
  24. #endif /* _H8300_BARRIER_H */