locking/lockdep: Factor out the validate_held_lock() helper function
authorJ. R. Okajima <hooanon05g@gmail.com>
Thu, 2 Feb 2017 16:38:16 +0000 (01:38 +0900)
committerIngo Molnar <mingo@kernel.org>
Thu, 16 Mar 2017 08:57:07 +0000 (09:57 +0100)
Behaviour should not change.

Signed-off-by: J. R. Okajima <hooanon05g@gmail.com>
Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>
Cc: Andrew Morton <akpm@linux-foundation.org>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Cc: Paul E. McKenney <paulmck@linux.vnet.ibm.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Thomas Gleixner <tglx@linutronix.de>
Link: http://lkml.kernel.org/r/1486053497-9948-2-git-send-email-hooanon05g@gmail.com
Signed-off-by: Ingo Molnar <mingo@kernel.org>
kernel/locking/lockdep.c

index 0d28b8259b9a1e1d736213d884592b7a36aa5d6d..da795480e0aad3dc539ce6c1f6bcdcf0c98dfb62 100644 (file)
@@ -3473,6 +3473,24 @@ out:
        return ret;
 }
 
+static int reacquire_held_locks(struct task_struct *curr, unsigned int depth,
+                             int idx)
+{
+       struct held_lock *hlock;
+
+       for (hlock = curr->held_locks + idx; idx < depth; idx++, hlock++) {
+               if (!__lock_acquire(hlock->instance,
+                                   hlock_class(hlock)->subclass,
+                                   hlock->trylock,
+                                   hlock->read, hlock->check,
+                                   hlock->hardirqs_off,
+                                   hlock->nest_lock, hlock->acquire_ip,
+                                   hlock->references, hlock->pin_count))
+                       return 1;
+       }
+       return 0;
+}
+
 static int
 __lock_set_class(struct lockdep_map *lock, const char *name,
                 struct lock_class_key *key, unsigned int subclass,
@@ -3503,15 +3521,8 @@ __lock_set_class(struct lockdep_map *lock, const char *name,
        curr->lockdep_depth = i;
        curr->curr_chain_key = hlock->prev_chain_key;
 
-       for (; i < depth; i++) {
-               hlock = curr->held_locks + i;
-               if (!__lock_acquire(hlock->instance,
-                       hlock_class(hlock)->subclass, hlock->trylock,
-                               hlock->read, hlock->check, hlock->hardirqs_off,
-                               hlock->nest_lock, hlock->acquire_ip,
-                               hlock->references, hlock->pin_count))
-                       return 0;
-       }
+       if (reacquire_held_locks(curr, depth, i))
+               return 0;
 
        /*
         * I took it apart and put it back together again, except now I have
@@ -3582,15 +3593,8 @@ __lock_release(struct lockdep_map *lock, int nested, unsigned long ip)
        curr->lockdep_depth = i;
        curr->curr_chain_key = hlock->prev_chain_key;
 
-       for (i++; i < depth; i++) {
-               hlock = curr->held_locks + i;
-               if (!__lock_acquire(hlock->instance,
-                       hlock_class(hlock)->subclass, hlock->trylock,
-                               hlock->read, hlock->check, hlock->hardirqs_off,
-                               hlock->nest_lock, hlock->acquire_ip,
-                               hlock->references, hlock->pin_count))
-                       return 0;
-       }
+       if (reacquire_held_locks(curr, depth, i + 1))
+               return 0;
 
        /*
         * We had N bottles of beer on the wall, we drank one, but now