2012-03-28 18:30:03 +01:00
|
|
|
/*
|
|
|
|
|
* This file is subject to the terms and conditions of the GNU General Public
|
|
|
|
|
* License. See the file "COPYING" in the main directory of this archive
|
|
|
|
|
* for more details.
|
|
|
|
|
*
|
2012-11-24 06:22:08 +04:00
|
|
|
* Copyright (C) 2001 - 2012 Tensilica Inc.
|
2012-03-28 18:30:03 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#ifndef _XTENSA_SYSTEM_H
|
|
|
|
|
#define _XTENSA_SYSTEM_H
|
|
|
|
|
|
2018-12-20 17:18:12 -08:00
|
|
|
#include <asm/core.h>
|
|
|
|
|
|
2019-10-04 23:33:31 -07:00
|
|
|
#define __mb() ({ __asm__ __volatile__("memw" : : : "memory"); })
|
|
|
|
|
#define __rmb() barrier()
|
|
|
|
|
#define __wmb() __mb()
|
|
|
|
|
|
|
|
|
|
#ifdef CONFIG_SMP
|
|
|
|
|
#define __smp_mb() __mb()
|
|
|
|
|
#define __smp_rmb() __rmb()
|
|
|
|
|
#define __smp_wmb() __wmb()
|
|
|
|
|
#endif
|
2012-03-28 18:30:03 +01:00
|
|
|
|
2018-12-20 17:18:12 -08:00
|
|
|
#if XCHAL_HAVE_S32C1I
|
2015-12-27 15:04:42 +02:00
|
|
|
#define __smp_mb__before_atomic() barrier()
|
|
|
|
|
#define __smp_mb__after_atomic() barrier()
|
2018-12-20 17:18:12 -08:00
|
|
|
#endif
|
2014-03-13 19:00:35 +01:00
|
|
|
|
2013-11-06 14:57:36 +01:00
|
|
|
#include <asm-generic/barrier.h>
|
2012-03-28 18:30:03 +01:00
|
|
|
|
|
|
|
|
#endif /* _XTENSA_SYSTEM_H */
|