From: Alexey Kodanev Date: Sat, 7 Mar 2015 00:06:53 +0000 (+0300) Subject: locktorture: fix deadlock in 'rw_lock_irq' type X-Git-Tag: v4.1.12-92~162^2 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=7958dc35681b6ce10e6cceae9d9e6bbd1c86fb3e;p=users%2Fjedix%2Flinux-maple.git locktorture: fix deadlock in 'rw_lock_irq' type Orabug: 20811436 torture_rwlock_read_unlock_irq() must use read_unlock_irqrestore() instead of write_unlock_irqrestore(). Use read_unlock_irqrestore() instead of write_unlock_irqrestore(). Signed-off-by: Alexey Kodanev Signed-off-by: Paul E. McKenney Reviewed-by: Josh Triplett (cherry picked from commit f548d99ef4f5ec8f7080e88ad07c44d16d058ddc) Signed-off-by: Dan Duval --- diff --git a/kernel/locking/locktorture.c b/kernel/locking/locktorture.c index ec8cce2597790..6a2723c88c33a 100644 --- a/kernel/locking/locktorture.c +++ b/kernel/locking/locktorture.c @@ -309,7 +309,7 @@ static int torture_rwlock_read_lock_irq(void) __acquires(torture_rwlock) static void torture_rwlock_read_unlock_irq(void) __releases(torture_rwlock) { - write_unlock_irqrestore(&torture_rwlock, cxt.cur_ops->flags); + read_unlock_irqrestore(&torture_rwlock, cxt.cur_ops->flags); } static struct lock_torture_ops rw_lock_irq_ops = {