summaryrefslogtreecommitdiff
path: root/security
diff options
context:
space:
mode:
authorWill Deacon <will.deacon@arm.com>2016-02-10 19:05:28 +0300
committerWill Deacon <will.deacon@arm.com>2016-02-10 19:05:28 +0300
commite04a28d45ff343b47a4ffc4dee3a3e279e76ddfa (patch)
tree0122e91fd0d3d506298658f7b7dbeced83b69bc3 /security
parentbcaf669b4bdbad09888df086d266a34e293ace85 (diff)
downloadlinux-e04a28d45ff343b47a4ffc4dee3a3e279e76ddfa.tar.xz
arm64: debug: re-enable irqs before sending breakpoint SIGTRAP
force_sig_info can sleep under an -rt kernel, so attempting to send a breakpoint SIGTRAP with interrupts disabled yields the following BUG: BUG: sleeping function called from invalid context at /kernel-source/kernel/locking/rtmutex.c:917 in_atomic(): 0, irqs_disabled(): 128, pid: 551, name: test.sh CPU: 5 PID: 551 Comm: test.sh Not tainted 4.1.13-rt13 #7 Hardware name: Freescale Layerscape 2085a RDB Board (DT) Call trace: dump_backtrace+0x0/0x128 show_stack+0x24/0x30 dump_stack+0x80/0xa0 ___might_sleep+0x128/0x1a0 rt_spin_lock+0x2c/0x40 force_sig_info+0xcc/0x210 brk_handler.part.2+0x6c/0x80 brk_handler+0xd8/0xe8 do_debug_exception+0x58/0xb8 This patch fixes the problem by ensuring that interrupts are enabled prior to sending the SIGTRAP if they were already enabled in the user context. Reported-by: Yang Shi <yang.shi@linaro.org> Signed-off-by: Will Deacon <will.deacon@arm.com>
Diffstat (limited to 'security')
0 files changed, 0 insertions, 0 deletions