diff options
| author | Will Deacon <will.deacon@arm.com> | 2016-02-10 19:05:28 +0300 | 
|---|---|---|
| committer | Will Deacon <will.deacon@arm.com> | 2016-02-10 19:05:28 +0300 | 
| commit | e04a28d45ff343b47a4ffc4dee3a3e279e76ddfa (patch) | |
| tree | 0122e91fd0d3d506298658f7b7dbeced83b69bc3 /tools/perf/scripts/python/sched-migration.py | |
| parent | bcaf669b4bdbad09888df086d266a34e293ace85 (diff) | |
| download | linux-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 'tools/perf/scripts/python/sched-migration.py')
0 files changed, 0 insertions, 0 deletions
