aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMichal Hocko <mhocko@suse.com>2016-04-07 11:12:28 -0400
committerIngo Molnar <mingo@kernel.org>2016-04-13 04:42:21 -0400
commita02137eb5177e7afc8dfa52a2888c1f2f4840739 (patch)
tree3f7e840b21913026195bf66259209d9c99874c06
parent7deb5eebc1e61b15c5c7f1ef19f216b20d7f7d00 (diff)
locking/rwsem, ia64: Provide __down_write_killable()
Introduce ___down_write() for the fast path and reuse it for __down_write() resp. __down_write_killable() each using the respective generic slow path (rwsem_down_write_failed() resp. rwsem_down_write_failed_killable()). Signed-off-by: Michal Hocko <mhocko@suse.com> Cc: Andrew Morton <akpm@linux-foundation.org> Cc: Chris Zankel <chris@zankel.net> Cc: David S. Miller <davem@davemloft.net> Cc: Linus Torvalds <torvalds@linux-foundation.org> Cc: Max Filippov <jcmvbkbc@gmail.com> Cc: Paul E. McKenney <paulmck@linux.vnet.ibm.com> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Signed-off-by: Davidlohr Bueso <dbueso@suse.de> Cc: Signed-off-by: Jason Low <jason.low2@hp.com> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: Tony Luck <tony.luck@intel.com> Cc: linux-alpha@vger.kernel.org Cc: linux-arch@vger.kernel.org Cc: linux-ia64@vger.kernel.org Cc: linux-s390@vger.kernel.org Cc: linux-sh@vger.kernel.org Cc: linux-xtensa@linux-xtensa.org Cc: sparclinux@vger.kernel.org Link: http://lkml.kernel.org/r/1460041951-22347-9-git-send-email-mhocko@kernel.org Signed-off-by: Ingo Molnar <mingo@kernel.org>
-rw-r--r--arch/ia64/include/asm/rwsem.h22
1 files changed, 19 insertions, 3 deletions
diff --git a/arch/ia64/include/asm/rwsem.h b/arch/ia64/include/asm/rwsem.h
index ce112472bdd6..8b23e070b844 100644
--- a/arch/ia64/include/asm/rwsem.h
+++ b/arch/ia64/include/asm/rwsem.h
@@ -49,8 +49,8 @@ __down_read (struct rw_semaphore *sem)
49/* 49/*
50 * lock for writing 50 * lock for writing
51 */ 51 */
52static inline void 52static inline long
53__down_write (struct rw_semaphore *sem) 53___down_write (struct rw_semaphore *sem)
54{ 54{
55 long old, new; 55 long old, new;
56 56
@@ -59,10 +59,26 @@ __down_write (struct rw_semaphore *sem)
59 new = old + RWSEM_ACTIVE_WRITE_BIAS; 59 new = old + RWSEM_ACTIVE_WRITE_BIAS;
60 } while (cmpxchg_acq(&sem->count, old, new) != old); 60 } while (cmpxchg_acq(&sem->count, old, new) != old);
61 61
62 if (old != 0) 62 return old;
63}
64
65static inline void
66__down_write (struct rw_semaphore *sem)
67{
68 if (___down_write(sem))
63 rwsem_down_write_failed(sem); 69 rwsem_down_write_failed(sem);
64} 70}
65 71
72static inline int
73__down_write_killable (struct rw_semaphore *sem)
74{
75 if (___down_write(sem))
76 if (IS_ERR(rwsem_down_write_failed_killable(sem)))
77 return -EINTR;
78
79 return 0;
80}
81
66/* 82/*
67 * unlock after reading 83 * unlock after reading
68 */ 84 */