|  | /* | 
|  | * Copyright (c) 1997-2015, Wind River Systems, Inc. | 
|  | * | 
|  | * SPDX-License-Identifier: Apache-2.0 | 
|  | */ | 
|  |  | 
|  | #ifndef ZEPHYR_INCLUDE_SYS_ATOMIC_C_H_ | 
|  | #define ZEPHYR_INCLUDE_SYS_ATOMIC_C_H_ | 
|  |  | 
|  | /* Included from <atomic.h> */ | 
|  |  | 
|  | #ifdef __cplusplus | 
|  | extern "C" { | 
|  | #endif | 
|  |  | 
|  | /* Simple and correct (but very slow) implementation of atomic | 
|  | * primitives that require nothing more than kernel interrupt locking. | 
|  | */ | 
|  |  | 
|  | __syscall bool atomic_cas(atomic_t *target, atomic_val_t old_value, | 
|  | atomic_val_t new_value); | 
|  |  | 
|  | __syscall bool atomic_ptr_cas(atomic_ptr_t *target, atomic_ptr_val_t old_value, | 
|  | atomic_ptr_val_t new_value); | 
|  |  | 
|  | __syscall atomic_val_t atomic_add(atomic_t *target, atomic_val_t value); | 
|  |  | 
|  | __syscall atomic_val_t atomic_sub(atomic_t *target, atomic_val_t value); | 
|  |  | 
|  | static inline atomic_val_t atomic_inc(atomic_t *target) | 
|  | { | 
|  | return atomic_add(target, 1); | 
|  |  | 
|  | } | 
|  |  | 
|  | static inline atomic_val_t atomic_dec(atomic_t *target) | 
|  | { | 
|  | return atomic_sub(target, 1); | 
|  |  | 
|  | } | 
|  |  | 
|  | extern atomic_val_t atomic_get(const atomic_t *target); | 
|  |  | 
|  | extern atomic_ptr_val_t atomic_ptr_get(const atomic_ptr_t *target); | 
|  |  | 
|  | __syscall atomic_val_t atomic_set(atomic_t *target, atomic_val_t value); | 
|  |  | 
|  | __syscall atomic_ptr_val_t atomic_ptr_set(atomic_ptr_t *target, atomic_ptr_val_t value); | 
|  |  | 
|  | static inline atomic_val_t atomic_clear(atomic_t *target) | 
|  | { | 
|  | return atomic_set(target, 0); | 
|  |  | 
|  | } | 
|  |  | 
|  | static inline atomic_ptr_val_t atomic_ptr_clear(atomic_ptr_t *target) | 
|  | { | 
|  | return atomic_ptr_set(target, NULL); | 
|  |  | 
|  | } | 
|  |  | 
|  | __syscall atomic_val_t atomic_or(atomic_t *target, atomic_val_t value); | 
|  |  | 
|  | __syscall atomic_val_t atomic_xor(atomic_t *target, atomic_val_t value); | 
|  |  | 
|  | __syscall atomic_val_t atomic_and(atomic_t *target, atomic_val_t value); | 
|  |  | 
|  | __syscall atomic_val_t atomic_nand(atomic_t *target, atomic_val_t value); | 
|  |  | 
|  | #ifdef __cplusplus | 
|  | } | 
|  | #endif | 
|  |  | 
|  | #ifdef CONFIG_ATOMIC_OPERATIONS_C | 
|  | #include <syscalls/atomic_c.h> | 
|  | #endif | 
|  |  | 
|  | #endif /* ZEPHYR_INCLUDE_SYS_ATOMIC_C_H_ */ |