Server IP : 80.87.202.40 / Your IP : 216.73.216.169 Web Server : Apache System : Linux rospirotorg.ru 5.14.0-539.el9.x86_64 #1 SMP PREEMPT_DYNAMIC Thu Dec 5 22:26:13 UTC 2024 x86_64 User : bitrix ( 600) PHP Version : 8.2.27 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : ON Directory : /usr/src/kernels/5.14.0-570.el9.x86_64/include/linux/ |
Upload File : |
// SPDX-License-Identifier: GPL-2.0-only #ifndef _LINUX_RWBASE_RT_H #define _LINUX_RWBASE_RT_H #include <linux/rtmutex.h> #include <linux/atomic.h> #define READER_BIAS (1U << 31) #define WRITER_BIAS (1U << 30) struct rwbase_rt { atomic_t readers; struct rt_mutex_base rtmutex; }; #define __RWBASE_INITIALIZER(name) \ { \ .readers = ATOMIC_INIT(READER_BIAS), \ .rtmutex = __RT_MUTEX_BASE_INITIALIZER(name.rtmutex), \ } #define init_rwbase_rt(rwbase) \ do { \ rt_mutex_base_init(&(rwbase)->rtmutex); \ atomic_set(&(rwbase)->readers, READER_BIAS); \ } while (0) static __always_inline bool rw_base_is_locked(const struct rwbase_rt *rwb) { return atomic_read(&rwb->readers) != READER_BIAS; } static __always_inline bool rw_base_is_write_locked(const struct rwbase_rt *rwb) { return atomic_read(&rwb->readers) == WRITER_BIAS; } static __always_inline bool rw_base_is_contended(const struct rwbase_rt *rwb) { return atomic_read(&rwb->readers) > 0; } #endif /* _LINUX_RWBASE_RT_H */