mirror of
git://git.yoctoproject.org/linux-yocto.git
synced 2025-07-08 06:45:42 +02:00

Updated check_forking() and bench_forking() to use __mt_dup() to duplicate maple tree. Link: https://lkml.kernel.org/r/20231027033845.90608-9-zhangpeng.00@bytedance.com Signed-off-by: Peng Zhang <zhangpeng.00@bytedance.com> Reviewed-by: Liam R. Howlett <Liam.Howlett@oracle.com> Cc: Christian Brauner <brauner@kernel.org> Cc: Jonathan Corbet <corbet@lwn.net> Cc: Mateusz Guzik <mjguzik@gmail.com> Cc: Mathieu Desnoyers <mathieu.desnoyers@efficios.com> Cc: Matthew Wilcox <willy@infradead.org> Cc: Michael S. Tsirkin <mst@redhat.com> Cc: Mike Christie <michael.christie@oracle.com> Cc: Nicholas Piggin <npiggin@gmail.com> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Suren Baghdasaryan <surenb@google.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
45 lines
920 B
C
45 lines
920 B
C
/* SPDX-License-Identifier: GPL-2.0+ */
|
|
#ifndef _TOOLS__RWSEM_H
|
|
#define _TOOLS__RWSEM_H
|
|
|
|
#include <pthread.h>
|
|
|
|
struct rw_semaphore {
|
|
pthread_rwlock_t lock;
|
|
};
|
|
|
|
static inline int init_rwsem(struct rw_semaphore *sem)
|
|
{
|
|
return pthread_rwlock_init(&sem->lock, NULL);
|
|
}
|
|
|
|
static inline int exit_rwsem(struct rw_semaphore *sem)
|
|
{
|
|
return pthread_rwlock_destroy(&sem->lock);
|
|
}
|
|
|
|
static inline int down_read(struct rw_semaphore *sem)
|
|
{
|
|
return pthread_rwlock_rdlock(&sem->lock);
|
|
}
|
|
|
|
static inline int up_read(struct rw_semaphore *sem)
|
|
{
|
|
return pthread_rwlock_unlock(&sem->lock);
|
|
}
|
|
|
|
static inline int down_write(struct rw_semaphore *sem)
|
|
{
|
|
return pthread_rwlock_wrlock(&sem->lock);
|
|
}
|
|
|
|
static inline int up_write(struct rw_semaphore *sem)
|
|
{
|
|
return pthread_rwlock_unlock(&sem->lock);
|
|
}
|
|
|
|
#define down_read_nested(sem, subclass) down_read(sem)
|
|
#define down_write_nested(sem, subclass) down_write(sem)
|
|
|
|
#endif /* _TOOLS_RWSEM_H */
|