diff --git a/cpu/arm7_common/include/atomic_utils_arch.h b/cpu/arm7_common/include/atomic_utils_arch.h new file mode 100644 index 0000000000..e31fab8012 --- /dev/null +++ b/cpu/arm7_common/include/atomic_utils_arch.h @@ -0,0 +1,76 @@ +/* + * Copyright (C) 2020 Otto-von-Guericke-Universität Magdeburg + * + * This file is subject to the terms and conditions of the GNU Lesser General + * Public License v2.1. See the file LICENSE in the top level directory for more + * details. + */ + +/** + * @ingroup cpu_arm7_common + * + * @{ + * + * @file + * @brief Implementation of fast atomic utility functions + * @author Marian Buschsieweke + */ + +#ifndef ATOMIC_UTILS_ARCH_H +#define ATOMIC_UTILS_ARCH_H +#ifndef DOXYGEN + +#include "periph_cpu.h" + +#ifdef __cplusplus +extern "C" { +#endif + +/* clang provides no built-in atomic access to regular variables */ +#ifndef __clang__ + +#define HAS_ATOMIC_LOAD_U8 +static inline uint8_t atomic_load_u8(const uint8_t *var) +{ + return __atomic_load_1(var, __ATOMIC_SEQ_CST); +} + +#define HAS_ATOMIC_LOAD_U16 +static inline uint16_t atomic_load_u16(const uint16_t *var) +{ + return __atomic_load_2(var, __ATOMIC_SEQ_CST); +} + +#define HAS_ATOMIC_LOAD_U32 +static inline uint32_t atomic_load_u32(const uint32_t *var) +{ + return __atomic_load_4(var, __ATOMIC_SEQ_CST); +} + +#define HAS_ATOMIC_STORE_U8 +static inline void atomic_store_u8(uint8_t *dest, uint8_t val) +{ + __atomic_store_1(dest, val, __ATOMIC_SEQ_CST); +} + +#define HAS_ATOMIC_STORE_U16 +static inline void atomic_store_u16(uint16_t *dest, uint16_t val) +{ + __atomic_store_2(dest, val, __ATOMIC_SEQ_CST); +} + +#define HAS_ATOMIC_STORE_U32 +static inline void atomic_store_u32(uint32_t *dest, uint32_t val) +{ + __atomic_store_4(dest, val, __ATOMIC_SEQ_CST); +} + +#endif /* __clang__ */ + +#ifdef __cplusplus +} +#endif + +#endif /* DOXYGEN */ +#endif /* ATOMIC_UTILS_ARCH_H */ +/** @} */