diff options
author | Jakub Kicinski <[email protected]> | 2019-03-29 17:08:54 -0700 |
---|---|---|
committer | Ingo Molnar <[email protected]> | 2019-04-29 08:29:21 +0200 |
commit | 94b5f312cfb4a66055d9b688dc9ab6b297eb9dcc (patch) | |
tree | 7a4dc14eb16fa750262bb6cc3252d0e106fea8d4 /tools/perf/scripts/python/export-to-sqlite.py | |
parent | b92e793bbe4a1c49dbf78d8d526561e7a7dd568a (diff) |
locking/static_key: Don't take sleeping locks in __static_key_slow_dec_deferred()
Changing jump_label state is protected by jump_label_lock().
Rate limited static_key_slow_dec(), however, will never
directly call jump_label_update(), it will schedule a delayed
work instead. Therefore it's unnecessary to take both the
cpus_read_lock() and jump_label_lock().
This allows static_key_slow_dec_deferred() to be called
from atomic contexts, like socket destructing in net/tls,
without the need for another indirection.
Signed-off-by: Jakub Kicinski <[email protected]>
Signed-off-by: Peter Zijlstra (Intel) <[email protected]>
Reviewed-by: Simon Horman <[email protected]>
Cc: Andrew Morton <[email protected]>
Cc: Linus Torvalds <[email protected]>
Cc: Paul E. McKenney <[email protected]>
Cc: Peter Zijlstra <[email protected]>
Cc: Thomas Gleixner <[email protected]>
Cc: Will Deacon <[email protected]>
Cc: [email protected]
Cc: [email protected]
Cc: [email protected]
Cc: [email protected]
Link: https://lkml.kernel.org/r/[email protected]
Signed-off-by: Ingo Molnar <[email protected]>
Diffstat (limited to 'tools/perf/scripts/python/export-to-sqlite.py')
0 files changed, 0 insertions, 0 deletions