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_); |