barrier.h 710 B

12345678910111213141516171819202122232425262728293031
  1. /*
  2. * This file is subject to the terms and conditions of the GNU General Public
  3. * License. See the file "COPYING" in the main directory of this archive
  4. * for more details.
  5. *
  6. * Copyright (C) 2001 - 2012 Tensilica Inc.
  7. */
  8. #ifndef _XTENSA_SYSTEM_H
  9. #define _XTENSA_SYSTEM_H
  10. #include <asm/core.h>
  11. #define __mb() ({ __asm__ __volatile__("memw" : : : "memory"); })
  12. #define __rmb() barrier()
  13. #define __wmb() __mb()
  14. #ifdef CONFIG_SMP
  15. #define __smp_mb() __mb()
  16. #define __smp_rmb() __rmb()
  17. #define __smp_wmb() __wmb()
  18. #endif
  19. #if XCHAL_HAVE_S32C1I
  20. #define __smp_mb__before_atomic() barrier()
  21. #define __smp_mb__after_atomic() barrier()
  22. #endif
  23. #include <asm-generic/barrier.h>
  24. #endif /* _XTENSA_SYSTEM_H */