diff options
| author | Mathieu Desnoyers <[email protected]> | 2014-05-08 07:47:49 -0400 | 
|---|---|---|
| committer | Steven Rostedt <[email protected]> | 2014-05-08 09:10:56 -0400 | 
| commit | 8058bd0faad860e75547cc5cb5d4ade016247a79 (patch) | |
| tree | 71172e9ae00c358e23e93c451f0b7dc45d98f436 /scripts/gdb/linux/tasks.py | |
| parent | 098507ae3ec2331476fb52e85d4040c1cc6d0ef4 (diff) | |
tracepoint: Fix use of tracepoint funcs after rcu free
Commit de7b2973903c "tracepoint: Use struct pointer instead of name hash
for reg/unreg tracepoints" introduces a use after free by calling
release_probes on the old struct tracepoint array before the newly
allocated array is published with rcu_assign_pointer. There is a race
window where tracepoints (RCU readers) can perform a
"use-after-grace-period-after-free", which shows up as a GPF in
stress-tests.
Link: http://lkml.kernel.org/r/[email protected]
Link: http://lkml.kernel.org/p/[email protected]
Reported-by: Sasha Levin <[email protected]>
CC: Oleg Nesterov <[email protected]>
CC: Dave Jones <[email protected]>
Fixes: de7b2973903c "tracepoint: Use struct pointer instead of name hash for reg/unreg tracepoints"
Signed-off-by: Mathieu Desnoyers <[email protected]>
Signed-off-by: Steven Rostedt <[email protected]>
Diffstat (limited to 'scripts/gdb/linux/tasks.py')
0 files changed, 0 insertions, 0 deletions