| // 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 */ |