diff options
author | Russell King <rmk+kernel@arm.linux.org.uk> | 2011-01-15 10:27:04 +0100 |
---|---|---|
committer | Russell King <rmk+kernel@arm.linux.org.uk> | 2011-01-15 10:27:04 +0100 |
commit | d5996b2ff0e26cf7ed4c103084a2d6fc569e7216 (patch) | |
tree | c4d50df299e9c0e07e8ae66406489c01f4c9d6a9 /virt | |
parent | ARM: Fix build regression on SA11x0, PXA, and H720x targets (diff) | |
download | linux-d5996b2ff0e26cf7ed4c103084a2d6fc569e7216.tar.xz linux-d5996b2ff0e26cf7ed4c103084a2d6fc569e7216.zip |
ARM: fix /proc/$PID/stack on SMP
Rabin Vincent reports:
| On SMP, this BUG() in save_stack_trace_tsk() can be easily triggered
| from user space by reading /proc/$PID/stack, where $PID is any pid but
| the current process:
|
| if (tsk != current) {
| #ifdef CONFIG_SMP
| /*
| * What guarantees do we have here that 'tsk'
| * is not running on another CPU?
| */
| BUG();
| #else
Fix this by replacing the BUG() with an entry to terminate the stack
trace, returning an empty trace - I'd rather not expose the dwarf
unwinder to a volatile stack of a running thread.
Reported-by: Rabin Vincent <rabin@rab.in>
Tested-by: Rabin Vincent <rabin@rab.in>
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
Diffstat (limited to 'virt')
0 files changed, 0 insertions, 0 deletions