Zephyr API Documentation 4.4.99
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
atomic_builtin.h
Go to the documentation of this file.
1/* atomic operations */
2
3/*
4 * Copyright (c) 1997-2015, Wind River Systems, Inc.
5 * Copyright (c) 2023 Nordic Semiconductor ASA
6 *
7 * SPDX-License-Identifier: Apache-2.0
8 */
9
16
17#ifndef ZEPHYR_INCLUDE_SYS_ATOMIC_BUILTIN_H_
18#define ZEPHYR_INCLUDE_SYS_ATOMIC_BUILTIN_H_
19
20#include <stdbool.h>
21#include <stddef.h>
23
24#ifdef __cplusplus
25extern "C" {
26#endif
27
28/* Included from <atomic.h> */
29
31
32static inline bool atomic_cas(atomic_t *target, atomic_val_t old_value,
33 atomic_val_t new_value)
34{
35 return __atomic_compare_exchange_n(target, &old_value, new_value,
36 0, __ATOMIC_SEQ_CST,
37 __ATOMIC_SEQ_CST);
38}
39
40static inline bool atomic_ptr_cas(atomic_ptr_t *target, atomic_ptr_val_t old_value,
41 atomic_ptr_val_t new_value)
42{
43 return __atomic_compare_exchange_n(target, &old_value, new_value,
44 0, __ATOMIC_SEQ_CST,
45 __ATOMIC_SEQ_CST);
46}
47
48static inline atomic_val_t atomic_add(atomic_t *target, atomic_val_t value)
49{
50 return __atomic_fetch_add(target, value, __ATOMIC_SEQ_CST);
51}
52
53static inline atomic_val_t atomic_sub(atomic_t *target, atomic_val_t value)
54{
55 return __atomic_fetch_sub(target, value, __ATOMIC_SEQ_CST);
56}
57
58static inline atomic_val_t atomic_inc(atomic_t *target)
59{
60 return atomic_add(target, 1);
61}
62
63static inline atomic_val_t atomic_dec(atomic_t *target)
64{
65 return atomic_sub(target, 1);
66}
67
68static inline atomic_val_t atomic_get(const atomic_t *target)
69{
70 return __atomic_load_n(target, __ATOMIC_SEQ_CST);
71}
72
73static inline atomic_ptr_val_t atomic_ptr_get(const atomic_ptr_t *target)
74{
75 return __atomic_load_n(target, __ATOMIC_SEQ_CST);
76}
77
78static inline atomic_val_t atomic_set(atomic_t *target, atomic_val_t value)
79{
80 /* This builtin, as described by Intel, is not a traditional
81 * test-and-set operation, but rather an atomic exchange operation. It
82 * writes value into *ptr, and returns the previous contents of *ptr.
83 */
84 return __atomic_exchange_n(target, value, __ATOMIC_SEQ_CST);
85}
86
88{
89 return __atomic_exchange_n(target, value, __ATOMIC_SEQ_CST);
90}
91
92static inline atomic_val_t atomic_clear(atomic_t *target)
93{
94 return atomic_set(target, 0);
95}
96
98{
99 return atomic_ptr_set(target, NULL);
100}
101
102static inline atomic_val_t atomic_or(atomic_t *target, atomic_val_t value)
103{
104 return __atomic_fetch_or(target, value, __ATOMIC_SEQ_CST);
105}
106
107static inline atomic_val_t atomic_xor(atomic_t *target, atomic_val_t value)
108{
109 return __atomic_fetch_xor(target, value, __ATOMIC_SEQ_CST);
110}
111
112static inline atomic_val_t atomic_and(atomic_t *target, atomic_val_t value)
113{
114 return __atomic_fetch_and(target, value, __ATOMIC_SEQ_CST);
115}
116
117static inline atomic_val_t atomic_nand(atomic_t *target, atomic_val_t value)
118{
119 return __atomic_fetch_nand(target, value, __ATOMIC_SEQ_CST);
120}
121
123
124#ifdef __cplusplus
125}
126#endif
127
128#endif /* ZEPHYR_INCLUDE_SYS_ATOMIC_BUILTIN_H_ */
Atomic type definitions for the atomic operations API.
long atomic_t
Atomic integer variable.
Definition atomic_types.h:31
atomic_val_t atomic_or(atomic_t *target, atomic_val_t value)
Atomic bitwise inclusive OR.
atomic_val_t atomic_xor(atomic_t *target, atomic_val_t value)
Atomic bitwise exclusive OR (XOR).
atomic_ptr_val_t atomic_ptr_get(const atomic_ptr_t *target)
Atomic get a pointer value.
atomic_t atomic_val_t
Value type for atomic integer variables.
Definition atomic_types.h:38
atomic_val_t atomic_get(const atomic_t *target)
Atomic get.
atomic_ptr_t atomic_ptr_val_t
Value type for atomic pointer variables.
Definition atomic_types.h:53
atomic_ptr_val_t atomic_ptr_set(atomic_ptr_t *target, atomic_ptr_val_t value)
Atomic get-and-set for pointer values.
atomic_val_t atomic_nand(atomic_t *target, atomic_val_t value)
Atomic bitwise NAND.
atomic_val_t atomic_and(atomic_t *target, atomic_val_t value)
Atomic bitwise AND.
atomic_val_t atomic_add(atomic_t *target, atomic_val_t value)
Atomic addition.
atomic_ptr_val_t atomic_ptr_clear(atomic_ptr_t *target)
Atomic clear of a pointer value.
atomic_val_t atomic_set(atomic_t *target, atomic_val_t value)
Atomic get-and-set.
atomic_val_t atomic_sub(atomic_t *target, atomic_val_t value)
Atomic subtraction.
atomic_val_t atomic_clear(atomic_t *target)
Atomic clear.
bool atomic_ptr_cas(atomic_ptr_t *target, atomic_ptr_val_t old_value, atomic_ptr_val_t new_value)
Atomic compare-and-set with pointer values.
atomic_val_t atomic_inc(atomic_t *target)
Atomic increment.
bool atomic_cas(atomic_t *target, atomic_val_t old_value, atomic_val_t new_value)
Atomic compare-and-set.
atomic_val_t atomic_dec(atomic_t *target)
Atomic decrement.
void * atomic_ptr_t
Atomic pointer variable.
Definition atomic_types.h:46