diff options
author | Michal Hocko <mhocko@suse.com> | 2016-04-07 11:12:28 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@kernel.org> | 2016-04-13 04:42:21 -0400 |
commit | a02137eb5177e7afc8dfa52a2888c1f2f4840739 (patch) | |
tree | 3f7e840b21913026195bf66259209d9c99874c06 | |
parent | 7deb5eebc1e61b15c5c7f1ef19f216b20d7f7d00 (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.h | 22 |
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 | */ |
52 | static inline void | 52 | static 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 | |||
65 | static 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 | ||
72 | static 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 | */ |