|  | // 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(struct rwbase_rt *rwb) | 
|  | { | 
|  | return atomic_read(&rwb->readers) != READER_BIAS; | 
|  | } | 
|  |  | 
|  | static __always_inline bool rw_base_is_contended(struct rwbase_rt *rwb) | 
|  | { | 
|  | return atomic_read(&rwb->readers) > 0; | 
|  | } | 
|  |  | 
|  | #endif /* _LINUX_RWBASE_RT_H */ |