cregit-Linux how code gets into the kernel

Release 4.12 include/asm-generic/rwsem.h

#ifndef _ASM_GENERIC_RWSEM_H

#define _ASM_GENERIC_RWSEM_H

#ifndef _LINUX_RWSEM_H
#error "Please don't include <asm/rwsem.h> directly, use <linux/rwsem.h> instead."
#endif

#ifdef __KERNEL__

/*
 * R/W semaphores originally for PPC using the stuff in lib/rwsem.c.
 * Adapted largely from include/asm-i386/rwsem.h
 * by Paul Mackerras <paulus@samba.org>.
 */

/*
 * the semaphore definition
 */
#ifdef CONFIG_64BIT

# define RWSEM_ACTIVE_MASK		0xffffffffL
#else

# define RWSEM_ACTIVE_MASK		0x0000ffffL
#endif


#define RWSEM_UNLOCKED_VALUE		0x00000000L

#define RWSEM_ACTIVE_BIAS		0x00000001L

#define RWSEM_WAITING_BIAS		(-RWSEM_ACTIVE_MASK-1)

#define RWSEM_ACTIVE_READ_BIAS		RWSEM_ACTIVE_BIAS

#define RWSEM_ACTIVE_WRITE_BIAS		(RWSEM_WAITING_BIAS + RWSEM_ACTIVE_BIAS)

/*
 * lock for reading
 */

static inline void __down_read(struct rw_semaphore *sem) { if (unlikely(atomic_long_inc_return_acquire(&sem->count) <= 0)) rwsem_down_read_failed(sem); }

Contributors

PersonTokensPropCommitsCommitProp
Richard Kuo3196.88%150.00%
Davidlohr Bueso A13.12%150.00%
Total32100.00%2100.00%


static inline int __down_read_trylock(struct rw_semaphore *sem) { long tmp; while ((tmp = atomic_long_read(&sem->count)) >= 0) { if (tmp == atomic_long_cmpxchg_acquire(&sem->count, tmp, tmp + RWSEM_ACTIVE_READ_BIAS)) { return 1; } } return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Richard Kuo5491.53%150.00%
Jason Low58.47%150.00%
Total59100.00%2100.00%

/* * lock for writing */
static inline void __down_write(struct rw_semaphore *sem) { long tmp; tmp = atomic_long_add_return_acquire(RWSEM_ACTIVE_WRITE_BIAS, &sem->count); if (unlikely(tmp != RWSEM_ACTIVE_WRITE_BIAS)) rwsem_down_write_failed(sem); }

Contributors

PersonTokensPropCommitsCommitProp
Richard Kuo3995.12%133.33%
Davidlohr Bueso A12.44%133.33%
Michal Hocko12.44%133.33%
Total41100.00%3100.00%


static inline int __down_write_killable(struct rw_semaphore *sem) { long tmp; tmp = atomic_long_add_return_acquire(RWSEM_ACTIVE_WRITE_BIAS, &sem->count); if (unlikely(tmp != RWSEM_ACTIVE_WRITE_BIAS)) if (IS_ERR(rwsem_down_write_failed_killable(sem))) return -EINTR; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Michal Hocko53100.00%1100.00%
Total53100.00%1100.00%


static inline int __down_write_trylock(struct rw_semaphore *sem) { long tmp; tmp = atomic_long_cmpxchg_acquire(&sem->count, RWSEM_UNLOCKED_VALUE, RWSEM_ACTIVE_WRITE_BIAS); return tmp == RWSEM_UNLOCKED_VALUE; }

Contributors

PersonTokensPropCommitsCommitProp
Richard Kuo3397.06%150.00%
Jason Low12.94%150.00%
Total34100.00%2100.00%

/* * unlock after reading */
static inline void __up_read(struct rw_semaphore *sem) { long tmp; tmp = atomic_long_dec_return_release(&sem->count); if (unlikely(tmp < -1 && (tmp & RWSEM_ACTIVE_MASK) == 0)) rwsem_wake(sem); }

Contributors

PersonTokensPropCommitsCommitProp
Richard Kuo4797.92%150.00%
Davidlohr Bueso A12.08%150.00%
Total48100.00%2100.00%

/* * unlock after writing */
static inline void __up_write(struct rw_semaphore *sem) { if (unlikely(atomic_long_sub_return_release(RWSEM_ACTIVE_WRITE_BIAS, &sem->count) < 0)) rwsem_wake(sem); }

Contributors

PersonTokensPropCommitsCommitProp
Richard Kuo3397.06%150.00%
Davidlohr Bueso A12.94%150.00%
Total34100.00%2100.00%

/* * downgrade write lock to read lock */
static inline void __downgrade_write(struct rw_semaphore *sem) { long tmp; /* * When downgrading from exclusive to shared ownership, * anything inside the write-locked region cannot leak * into the read side. In contrast, anything in the * read-locked region is ok to be re-ordered into the * write side. As such, rely on RELEASE semantics. */ tmp = atomic_long_add_return_release(-RWSEM_WAITING_BIAS, &sem->count); if (tmp < 0) rwsem_downgrade_wake(sem); }

Contributors

PersonTokensPropCommitsCommitProp
Richard Kuo3895.00%150.00%
Davidlohr Bueso A25.00%150.00%
Total40100.00%2100.00%

#endif /* __KERNEL__ */ #endif /* _ASM_GENERIC_RWSEM_H */

Overall Contributors

PersonTokensPropCommitsCommitProp
Richard Kuo33582.51%116.67%
Michal Hocko5413.30%233.33%
Davidlohr Bueso A61.48%116.67%
Jason Low61.48%116.67%
Will Deacon51.23%116.67%
Total406100.00%6100.00%
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.