1 /*
2  * Copyright (c) 1997-2015, Wind River Systems, Inc.
3  *
4  * SPDX-License-Identifier: Apache-2.0
5  */
6 
7 #ifndef ZEPHYR_INCLUDE_SYS_ATOMIC_C_H_
8 #define ZEPHYR_INCLUDE_SYS_ATOMIC_C_H_
9 
10 /* Included from <atomic.h> */
11 
12 #ifdef __cplusplus
13 extern "C" {
14 #endif
15 
16 /* Simple and correct (but very slow) implementation of atomic
17  * primitives that require nothing more than kernel interrupt locking.
18  */
19 
20 __syscall bool atomic_cas(atomic_t *target, atomic_val_t old_value,
21 			 atomic_val_t new_value);
22 
23 __syscall bool atomic_ptr_cas(atomic_ptr_t *target, atomic_ptr_val_t old_value,
24 			      atomic_ptr_val_t new_value);
25 
26 __syscall atomic_val_t atomic_add(atomic_t *target, atomic_val_t value);
27 
28 __syscall atomic_val_t atomic_sub(atomic_t *target, atomic_val_t value);
29 
atomic_inc(atomic_t * target)30 static inline atomic_val_t atomic_inc(atomic_t *target)
31 {
32 	return atomic_add(target, 1);
33 
34 }
35 
atomic_dec(atomic_t * target)36 static inline atomic_val_t atomic_dec(atomic_t *target)
37 {
38 	return atomic_sub(target, 1);
39 
40 }
41 
42 atomic_val_t atomic_get(const atomic_t *target);
43 
44 atomic_ptr_val_t atomic_ptr_get(const atomic_ptr_t *target);
45 
46 __syscall atomic_val_t atomic_set(atomic_t *target, atomic_val_t value);
47 
48 __syscall atomic_ptr_val_t atomic_ptr_set(atomic_ptr_t *target, atomic_ptr_val_t value);
49 
atomic_clear(atomic_t * target)50 static inline atomic_val_t atomic_clear(atomic_t *target)
51 {
52 	return atomic_set(target, 0);
53 
54 }
55 
atomic_ptr_clear(atomic_ptr_t * target)56 static inline atomic_ptr_val_t atomic_ptr_clear(atomic_ptr_t *target)
57 {
58 	return atomic_ptr_set(target, NULL);
59 
60 }
61 
62 __syscall atomic_val_t atomic_or(atomic_t *target, atomic_val_t value);
63 
64 __syscall atomic_val_t atomic_xor(atomic_t *target, atomic_val_t value);
65 
66 __syscall atomic_val_t atomic_and(atomic_t *target, atomic_val_t value);
67 
68 __syscall atomic_val_t atomic_nand(atomic_t *target, atomic_val_t value);
69 
70 #ifdef __cplusplus
71 }
72 #endif
73 
74 #ifdef CONFIG_ATOMIC_OPERATIONS_C
75 
76 #ifndef DISABLE_SYSCALL_TRACING
77 /* Skip defining macros of atomic_*() for syscall tracing.
78  * Compiler does not like "({ ... tracing code ... })" and complains
79  *
80  *   error: expected identifier or '(' before '{' token
81  *
82  * ... even though there is a '(' before '{'.
83  */
84 #define DISABLE_SYSCALL_TRACING
85 #define _REMOVE_DISABLE_SYSCALL_TRACING
86 #endif
87 
88 #include <syscalls/atomic_c.h>
89 
90 #ifdef _REMOVE_DISABLE_SYSCALL_TRACING
91 #undef DISABLE_SYSCALL_TRACING
92 #undef _REMOVE_DISABLE_SYSCALL_TRACING
93 #endif
94 
95 #endif
96 
97 #endif /* ZEPHYR_INCLUDE_SYS_ATOMIC_C_H_ */
98