locking/lockdep: Avoid RCU-induced noinstr fail
authorPeter Zijlstra <peterz@infradead.org>
Thu, 24 Jun 2021 09:41:10 +0000 (11:41 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 18 Nov 2021 13:03:53 +0000 (14:03 +0100)
[ Upstream commit ce0b9c805dd66d5e49fd53ec5415ae398f4c56e6 ]

vmlinux.o: warning: objtool: look_up_lock_class()+0xc7: call to rcu_read_lock_any_held() leaves .noinstr.text section

Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>
Link: https://lore.kernel.org/r/20210624095148.311980536@infradead.org
Signed-off-by: Sasha Levin <sashal@kernel.org>
kernel/locking/lockdep.c

index 5184f689681588978af83ade472c6423a807af52..2823329143503658d7da09ab112fe4d0d76f601f 100644 (file)
@@ -887,7 +887,7 @@ look_up_lock_class(const struct lockdep_map *lock, unsigned int subclass)
        if (DEBUG_LOCKS_WARN_ON(!irqs_disabled()))
                return NULL;
 
-       hlist_for_each_entry_rcu(class, hash_head, hash_entry) {
+       hlist_for_each_entry_rcu_notrace(class, hash_head, hash_entry) {
                if (class->key == key) {
                        /*
                         * Huh! same key, different name? Did someone trample