diff options
author | Al Viro <viro@zeniv.linux.org.uk> | 2016-05-26 00:04:58 -0400 |
---|---|---|
committer | Al Viro <viro@zeniv.linux.org.uk> | 2016-05-26 00:04:58 -0400 |
commit | 887bddfa90c79957d61067cd54a10087be0c8b23 (patch) | |
tree | e4e4c24ee40d721196113df16d5d250bd1e8beac | |
parent | d42b386834ee1c22f6fac2f856bba8a6e4de38bb (diff) |
add down_write_killable_nested()
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
-rw-r--r-- | include/linux/rwsem.h | 2 | ||||
-rw-r--r-- | kernel/locking/rwsem.c | 16 |
2 files changed, 18 insertions, 0 deletions
diff --git a/include/linux/rwsem.h b/include/linux/rwsem.h index d1c12d160ace..d37fbb34d06f 100644 --- a/include/linux/rwsem.h +++ b/include/linux/rwsem.h | |||
@@ -156,6 +156,7 @@ extern void downgrade_write(struct rw_semaphore *sem); | |||
156 | */ | 156 | */ |
157 | extern void down_read_nested(struct rw_semaphore *sem, int subclass); | 157 | extern void down_read_nested(struct rw_semaphore *sem, int subclass); |
158 | extern void down_write_nested(struct rw_semaphore *sem, int subclass); | 158 | extern void down_write_nested(struct rw_semaphore *sem, int subclass); |
159 | extern int down_write_killable_nested(struct rw_semaphore *sem, int subclass); | ||
159 | extern void _down_write_nest_lock(struct rw_semaphore *sem, struct lockdep_map *nest_lock); | 160 | extern void _down_write_nest_lock(struct rw_semaphore *sem, struct lockdep_map *nest_lock); |
160 | 161 | ||
161 | # define down_write_nest_lock(sem, nest_lock) \ | 162 | # define down_write_nest_lock(sem, nest_lock) \ |
@@ -176,6 +177,7 @@ extern void up_read_non_owner(struct rw_semaphore *sem); | |||
176 | # define down_read_nested(sem, subclass) down_read(sem) | 177 | # define down_read_nested(sem, subclass) down_read(sem) |
177 | # define down_write_nest_lock(sem, nest_lock) down_write(sem) | 178 | # define down_write_nest_lock(sem, nest_lock) down_write(sem) |
178 | # define down_write_nested(sem, subclass) down_write(sem) | 179 | # define down_write_nested(sem, subclass) down_write(sem) |
180 | # define down_write_killable_nested(sem, subclass) down_write_killable(sem) | ||
179 | # define down_read_non_owner(sem) down_read(sem) | 181 | # define down_read_non_owner(sem) down_read(sem) |
180 | # define up_read_non_owner(sem) up_read(sem) | 182 | # define up_read_non_owner(sem) up_read(sem) |
181 | #endif | 183 | #endif |
diff --git a/kernel/locking/rwsem.c b/kernel/locking/rwsem.c index c817216c1615..2e853ad93a3a 100644 --- a/kernel/locking/rwsem.c +++ b/kernel/locking/rwsem.c | |||
@@ -173,6 +173,22 @@ void down_write_nested(struct rw_semaphore *sem, int subclass) | |||
173 | 173 | ||
174 | EXPORT_SYMBOL(down_write_nested); | 174 | EXPORT_SYMBOL(down_write_nested); |
175 | 175 | ||
176 | int __sched down_write_killable_nested(struct rw_semaphore *sem, int subclass) | ||
177 | { | ||
178 | might_sleep(); | ||
179 | rwsem_acquire(&sem->dep_map, subclass, 0, _RET_IP_); | ||
180 | |||
181 | if (LOCK_CONTENDED_RETURN(sem, __down_write_trylock, __down_write_killable)) { | ||
182 | rwsem_release(&sem->dep_map, 1, _RET_IP_); | ||
183 | return -EINTR; | ||
184 | } | ||
185 | |||
186 | rwsem_set_owner(sem); | ||
187 | return 0; | ||
188 | } | ||
189 | |||
190 | EXPORT_SYMBOL(down_write_killable_nested); | ||
191 | |||
176 | void up_read_non_owner(struct rw_semaphore *sem) | 192 | void up_read_non_owner(struct rw_semaphore *sem) |
177 | { | 193 | { |
178 | __up_read(sem); | 194 | __up_read(sem); |