kernel: atomic: possibility of arch specific implementation

For non-specified archs, including those out-of-tree, the possibility to
use a specific implementation has been reintroduced.

CONFIG_ATOMIC_OPERATIONS_ARCH must be selected to utilize this.

Signed-off-by: Tommie Skriver <tosk@demant.com>
This commit is contained in:
Tommie Skriver 2021-04-11 10:19:46 +02:00 committed by Carles Cufí
commit 7fac6a1bfd
3 changed files with 57 additions and 1 deletions

View file

@ -33,7 +33,10 @@ typedef atomic_ptr_t atomic_ptr_val_t;
# ifdef CONFIG_XTENSA
/* Not all Xtensa toolchains support GCC-style atomic intrinsics */
# include <arch/xtensa/atomic_xtensa.h>
# endif
# else
/* Other arch specific implementation */
# include <sys/atomic_arch.h>
# endif /* CONFIG_XTENSA */
#else
/* Default. See this file for the Doxygen reference: */
#include <sys/atomic_builtin.h>

49
include/sys/atomic_arch.h Normal file
View file

@ -0,0 +1,49 @@
/*
* Copyright (c) 2021 Demant A/S
*
* SPDX-License-Identifier: Apache-2.0
*/
#ifndef ZEPHYR_INCLUDE_SYS_ATOMIC_ARCH_H_
#define ZEPHYR_INCLUDE_SYS_ATOMIC_ARCH_H_
/* Included from <atomic.h> */
/* Arch specific atomic primitives */
extern bool atomic_cas(atomic_t *target, atomic_val_t old_value,
atomic_val_t new_value);
extern bool atomic_ptr_cas(atomic_ptr_t *target, void *old_value,
void *new_value);
extern atomic_val_t atomic_add(atomic_t *target, atomic_val_t value);
extern atomic_val_t atomic_sub(atomic_t *target, atomic_val_t value);
extern atomic_val_t atomic_inc(atomic_t *target);
extern atomic_val_t atomic_dec(atomic_t *target);
extern atomic_val_t atomic_get(const atomic_t *target);
extern void *atomic_ptr_get(const atomic_ptr_t *target);
extern atomic_val_t atomic_set(atomic_t *target, atomic_val_t value);
extern void *atomic_ptr_set(atomic_ptr_t *target, void *value);
extern atomic_val_t atomic_clear(atomic_t *target);
extern void *atomic_ptr_clear(atomic_ptr_t *target);
extern atomic_val_t atomic_or(atomic_t *target, atomic_val_t value);
extern atomic_val_t atomic_xor(atomic_t *target, atomic_val_t value);
extern atomic_val_t atomic_and(atomic_t *target, atomic_val_t value);
extern atomic_val_t atomic_nand(atomic_t *target, atomic_val_t value);
#endif /* ZEPHYR_INCLUDE_SYS_ATOMIC_ARCH_H_ */