diff options
| author | Ingo Molnar <mingo@kernel.org> | 2015-09-13 04:01:24 -0400 |
|---|---|---|
| committer | Ingo Molnar <mingo@kernel.org> | 2015-09-13 04:01:24 -0400 |
| commit | c7ef92cea98bc468bbc8e67b6e49d7365dc69482 (patch) | |
| tree | 1ed0118f697d72103eaf8fa53bd373be7a1c91ff /kernel/locking | |
| parent | a6b277857fd2c990bc208ca1958d3f34d26052f7 (diff) | |
| parent | 6ff33f3902c3b1c5d0db6b1e2c70b6d76fba357f (diff) | |
Merge tag 'v4.3-rc1' into locking/core, to refresh the tree
Signed-off-by: Ingo Molnar <mingo@kernel.org>
Diffstat (limited to 'kernel/locking')
| -rw-r--r-- | kernel/locking/Makefile | 3 | ||||
| -rw-r--r-- | kernel/locking/percpu-rwsem.c | 13 |
2 files changed, 14 insertions, 2 deletions
diff --git a/kernel/locking/Makefile b/kernel/locking/Makefile index 36942047ffc0..8e96f6cc2a4a 100644 --- a/kernel/locking/Makefile +++ b/kernel/locking/Makefile | |||
| @@ -1,5 +1,5 @@ | |||
| 1 | 1 | ||
| 2 | obj-y += mutex.o semaphore.o rwsem.o | 2 | obj-y += mutex.o semaphore.o rwsem.o percpu-rwsem.o |
| 3 | 3 | ||
| 4 | ifdef CONFIG_FUNCTION_TRACER | 4 | ifdef CONFIG_FUNCTION_TRACER |
| 5 | CFLAGS_REMOVE_lockdep.o = $(CC_FLAGS_FTRACE) | 5 | CFLAGS_REMOVE_lockdep.o = $(CC_FLAGS_FTRACE) |
| @@ -24,6 +24,5 @@ obj-$(CONFIG_DEBUG_SPINLOCK) += spinlock.o | |||
| 24 | obj-$(CONFIG_DEBUG_SPINLOCK) += spinlock_debug.o | 24 | obj-$(CONFIG_DEBUG_SPINLOCK) += spinlock_debug.o |
| 25 | obj-$(CONFIG_RWSEM_GENERIC_SPINLOCK) += rwsem-spinlock.o | 25 | obj-$(CONFIG_RWSEM_GENERIC_SPINLOCK) += rwsem-spinlock.o |
| 26 | obj-$(CONFIG_RWSEM_XCHGADD_ALGORITHM) += rwsem-xadd.o | 26 | obj-$(CONFIG_RWSEM_XCHGADD_ALGORITHM) += rwsem-xadd.o |
| 27 | obj-$(CONFIG_PERCPU_RWSEM) += percpu-rwsem.o | ||
| 28 | obj-$(CONFIG_QUEUED_RWLOCKS) += qrwlock.o | 27 | obj-$(CONFIG_QUEUED_RWLOCKS) += qrwlock.o |
| 29 | obj-$(CONFIG_LOCK_TORTURE_TEST) += locktorture.o | 28 | obj-$(CONFIG_LOCK_TORTURE_TEST) += locktorture.o |
diff --git a/kernel/locking/percpu-rwsem.c b/kernel/locking/percpu-rwsem.c index 652a8ee8efe9..f32567254867 100644 --- a/kernel/locking/percpu-rwsem.c +++ b/kernel/locking/percpu-rwsem.c | |||
| @@ -88,6 +88,19 @@ void percpu_down_read(struct percpu_rw_semaphore *brw) | |||
| 88 | __up_read(&brw->rw_sem); | 88 | __up_read(&brw->rw_sem); |
| 89 | } | 89 | } |
| 90 | 90 | ||
| 91 | int percpu_down_read_trylock(struct percpu_rw_semaphore *brw) | ||
| 92 | { | ||
| 93 | if (unlikely(!update_fast_ctr(brw, +1))) { | ||
| 94 | if (!__down_read_trylock(&brw->rw_sem)) | ||
| 95 | return 0; | ||
| 96 | atomic_inc(&brw->slow_read_ctr); | ||
| 97 | __up_read(&brw->rw_sem); | ||
| 98 | } | ||
| 99 | |||
| 100 | rwsem_acquire_read(&brw->rw_sem.dep_map, 0, 1, _RET_IP_); | ||
| 101 | return 1; | ||
| 102 | } | ||
| 103 | |||
| 91 | void percpu_up_read(struct percpu_rw_semaphore *brw) | 104 | void percpu_up_read(struct percpu_rw_semaphore *brw) |
| 92 | { | 105 | { |
| 93 | rwsem_release(&brw->rw_sem.dep_map, 1, _RET_IP_); | 106 | rwsem_release(&brw->rw_sem.dep_map, 1, _RET_IP_); |
