barrier.h (9938b04472d5c59f8bd8152a548533a8599596a2) | barrier.h (f7c34874f04a80d6c39a32f08da2529e59602d3c) |
---|---|
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 9#ifndef _XTENSA_SYSTEM_H 10#define _XTENSA_SYSTEM_H 11 | 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 9#ifndef _XTENSA_SYSTEM_H 10#define _XTENSA_SYSTEM_H 11 |
12#include <asm/core.h> 13 |
|
12#define mb() ({ __asm__ __volatile__("memw" : : : "memory"); }) 13#define rmb() barrier() 14#define wmb() mb() 15 | 14#define mb() ({ __asm__ __volatile__("memw" : : : "memory"); }) 15#define rmb() barrier() 16#define wmb() mb() 17 |
18#if XCHAL_HAVE_S32C1I |
|
16#define __smp_mb__before_atomic() barrier() 17#define __smp_mb__after_atomic() barrier() | 19#define __smp_mb__before_atomic() barrier() 20#define __smp_mb__after_atomic() barrier() |
21#endif |
|
18 19#include <asm-generic/barrier.h> 20 21#endif /* _XTENSA_SYSTEM_H */ | 22 23#include <asm-generic/barrier.h> 24 25#endif /* _XTENSA_SYSTEM_H */ |