mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
Merge pull request #17256 from maribu/sys/atomic_utils
sys/atomic_utils: add atomic_{load,store}_ptr()
This commit is contained in:
commit
3bb5588b28
@ -236,6 +236,33 @@ static inline uint32_t atomic_load_u32(const volatile uint32_t *var);
|
|||||||
* @return The value stored in @p var
|
* @return The value stored in @p var
|
||||||
*/
|
*/
|
||||||
static inline uint64_t atomic_load_u64(const volatile uint64_t *var);
|
static inline uint64_t atomic_load_u64(const volatile uint64_t *var);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Load an `uintptr_t` atomically
|
||||||
|
*
|
||||||
|
* @param[in] var Variable to load atomically
|
||||||
|
* @return The value stored in @p var
|
||||||
|
*/
|
||||||
|
static inline uintptr_t atomic_load_uintptr(const volatile uintptr_t *var) {
|
||||||
|
if (sizeof(uintptr_t) == 2) {
|
||||||
|
return atomic_load_u16((const volatile uint16_t *)var);
|
||||||
|
}
|
||||||
|
else if (sizeof(uintptr_t) == 4) {
|
||||||
|
return atomic_load_u32((const volatile uint32_t *)(uintptr_t)var);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
return atomic_load_u64((const volatile uint64_t *)(uintptr_t)var);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* @brief Load an `void *` atomically
|
||||||
|
*
|
||||||
|
* @param[in] ptr_addr Address to the pointer to load
|
||||||
|
* @return Value of the loaded pointer
|
||||||
|
*/
|
||||||
|
static inline void * atomic_load_ptr(void **ptr_addr) {
|
||||||
|
return (void *)atomic_load_uintptr((const volatile uintptr_t *)ptr_addr);
|
||||||
|
}
|
||||||
/** @} */
|
/** @} */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -266,6 +293,34 @@ static inline void atomic_store_u32(volatile uint32_t *dest, uint32_t val);
|
|||||||
* @param[in] val Value to write
|
* @param[in] val Value to write
|
||||||
*/
|
*/
|
||||||
static inline void atomic_store_u64(volatile uint64_t *dest, uint64_t val);
|
static inline void atomic_store_u64(volatile uint64_t *dest, uint64_t val);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Store an `uintptr_t` atomically
|
||||||
|
*
|
||||||
|
* @param[out] dest Location to atomically write the new value to
|
||||||
|
* @param[in] val Value to write
|
||||||
|
*/
|
||||||
|
static inline void atomic_store_uintptr(volatile uintptr_t *dest, uintptr_t val)
|
||||||
|
{
|
||||||
|
if (sizeof(uintptr_t) == 2) {
|
||||||
|
atomic_store_u16((volatile uint16_t *)dest, (uint16_t)val);
|
||||||
|
}
|
||||||
|
else if (sizeof(uintptr_t) == 4) {
|
||||||
|
atomic_store_u32((volatile uint32_t *)(uintptr_t)dest, (uint32_t)val);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
atomic_store_u64((volatile uint64_t *)(uintptr_t)dest, (uint64_t)val);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* @brief Store an `void *` atomically
|
||||||
|
*
|
||||||
|
* @param[out] dest Location to atomically write the new value to
|
||||||
|
* @param[in] val Value to write
|
||||||
|
*/
|
||||||
|
static inline void atomic_store_ptr(void **dest, const void *val) {
|
||||||
|
atomic_store_uintptr((volatile uintptr_t *)dest, (uintptr_t)val);
|
||||||
|
}
|
||||||
/** @} */
|
/** @} */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -51,6 +51,10 @@ static void test_load_store(void)
|
|||||||
uint64_t u64 = 42;
|
uint64_t u64 = 42;
|
||||||
atomic_store_u64(&u64, 0x1337133713371337);
|
atomic_store_u64(&u64, 0x1337133713371337);
|
||||||
TEST_ASSERT_EQUAL_INT(atomic_load_u64(&u64), 0x1337133713371337);
|
TEST_ASSERT_EQUAL_INT(atomic_load_u64(&u64), 0x1337133713371337);
|
||||||
|
|
||||||
|
void *ptr = NULL;
|
||||||
|
atomic_store_ptr(&ptr, &u64);
|
||||||
|
TEST_ASSERT(atomic_load_ptr(&ptr) == (void *)&u64);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void test_fetch_op_u8(fetch_op_u8_t atomic_op, fetch_op_u8_t op)
|
static void test_fetch_op_u8(fetch_op_u8_t atomic_op, fetch_op_u8_t op)
|
||||||
|
Loading…
Reference in New Issue
Block a user