#ifndef _URCU_ARCH_ARM_H #define _URCU_ARCH_ARM_H /* * arch_arm.h: trivial definitions for the ARM architecture. * * Copyright (c) 2010 Paul E. McKenney, IBM Corporation. * Copyright (c) 2009 Mathieu Desnoyers * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA */ #include #include #include #ifdef __cplusplus extern "C" { #endif /* * Using DMB is faster than the builtin __sync_synchronize and this instruction is * part of the baseline ARMv7 ISA. */ #ifdef URCU_ARCH_ARMV7 /* For backwards compat. */ #define CONFIG_RCU_ARM_HAVE_DMB 1 /* * Issues full system DMB operation. */ #define cmm_mb() __asm__ __volatile__ ("dmb sy":::"memory") #define cmm_rmb() __asm__ __volatile__ ("dmb sy":::"memory") #define cmm_wmb() __asm__ __volatile__ ("dmb sy":::"memory") /* * Issues DMB operation only to the inner shareable domain. */ #define cmm_smp_mb() __asm__ __volatile__ ("dmb ish":::"memory") #define cmm_smp_rmb() __asm__ __volatile__ ("dmb ish":::"memory") #define cmm_smp_wmb() __asm__ __volatile__ ("dmb ish":::"memory") #endif /* URCU_ARCH_ARMV7 */ #include #include /* * On Linux, define the membarrier system call number if not yet available in * the system headers. */ #if (defined(__linux__) && !defined(__NR_membarrier)) #define __NR_membarrier 389 #endif /* * Error out for compilers with known bugs. */ /* * http://gcc.gnu.org/bugzilla/show_bug.cgi?id=58854 */ #ifdef URCU_GCC_VERSION # if URCU_GCC_VERSION >= 40800 && URCU_GCC_VERSION <= 40802 # error Your gcc version produces clobbered frame accesses # endif #endif /* * https://gcc.gnu.org/bugzilla/show_bug.cgi?id=42263 */ #ifdef URCU_GCC_VERSION # if URCU_GCC_VERSION >= 40400 && URCU_GCC_VERSION <= 40402 # error Your gcc version has a non-functional __sync_synchronize() # endif #endif #ifdef __cplusplus } #endif #include #endif /* _URCU_ARCH_ARM_H */