linux-uconsole/arch/powerpc
Anton Blanchard aa517b185c powerpc/perf: Fix book3s kernel to userspace backtraces
commit 72e349f112 upstream.

When we take a PMU exception or a software event we call
perf_read_regs(). This overloads regs->result with a boolean that
describes if we should use the sampled instruction address register
(SIAR) or the regs.

If the exception is in kernel, we start with the kernel regs and
backtrace through the kernel stack. At this point we switch to the
userspace regs and backtrace the user stack with perf_callchain_user().

Unfortunately these regs have not got the perf_read_regs() treatment,
so regs->result could be anything. If it is non zero,
perf_instruction_pointer() decides to use the SIAR, and we get issues
like this:

0.11%  qemu-system-ppc  [kernel.kallsyms]        [k] _raw_spin_lock_irqsave
       |
       ---_raw_spin_lock_irqsave
          |
          |--52.35%-- 0
          |          |
          |          |--46.39%-- __hrtimer_start_range_ns
          |          |          kvmppc_run_core
          |          |          kvmppc_vcpu_run_hv
          |          |          kvmppc_vcpu_run
          |          |          kvm_arch_vcpu_ioctl_run
          |          |          kvm_vcpu_ioctl
          |          |          do_vfs_ioctl
          |          |          sys_ioctl
          |          |          system_call
          |          |          |
          |          |          |--67.08%-- _raw_spin_lock_irqsave <--- hi mum
          |          |          |          |
          |          |          |           --100.00%-- 0x7e714
          |          |          |                     0x7e714

Notice the bogus _raw_spin_irqsave when we transition from kernel
(system_call) to userspace (0x7e714). We inserted what was in the SIAR.

Add a check in regs_use_siar() to check that the regs in question
are from a PMU exception. With this fix the backtrace makes sense:

     0.47%  qemu-system-ppc  [kernel.vmlinux]         [k] _raw_spin_lock_irqsave
            |
            ---_raw_spin_lock_irqsave
               |
               |--53.83%-- 0
               |          |
               |          |--44.73%-- hrtimer_try_to_cancel
               |          |          kvmppc_start_thread
               |          |          kvmppc_run_core
               |          |          kvmppc_vcpu_run_hv
               |          |          kvmppc_vcpu_run
               |          |          kvm_arch_vcpu_ioctl_run
               |          |          kvm_vcpu_ioctl
               |          |          do_vfs_ioctl
               |          |          sys_ioctl
               |          |          system_call
               |          |          __ioctl
               |          |          0x7e714
               |          |          0x7e714

Signed-off-by: Anton Blanchard <anton@samba.org>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
2015-07-10 10:40:22 -07:00
..
boot powerpc/mpc85xx: Add ranges to etsec2 nodes 2015-04-13 14:02:12 +02:00
configs USB: remove remaining instances of USB_SUSPEND 2013-05-15 13:44:44 -04:00
crypto crypto: add missing crypto module aliases 2015-01-29 17:40:57 -08:00
include powerpc/perf: Fix ABIv2 kernel backtraces 2014-10-05 14:54:14 -07:00
kernel powerpc: Align TOC to 256 bytes 2015-06-05 23:19:57 -07:00
kvm KVM: PPC: e500: Fix bad address type in deliver_tlb_misss() 2014-02-06 11:08:17 -08:00
lib powerpc: fix typo 'CONFIG_PPC_CPU' 2014-07-06 18:54:15 -07:00
math-emu
mm vm: add VM_FAULT_SIGSEGV handling support 2015-04-29 10:34:00 +02:00
net bpf: do not use reciprocal divide 2014-02-06 11:08:16 -08:00
oprofile Merge branch 'merge' into next 2013-01-29 11:33:37 +11:00
perf powerpc/perf: Fix book3s kernel to userspace backtraces 2015-07-10 10:40:22 -07:00
platforms vm: add VM_FAULT_SIGSEGV handling support 2015-04-29 10:34:00 +02:00
sysdev axonram: Fix bug in direct_access 2015-03-06 14:40:50 -08:00
xmon powerpc/xmon: Fix another endiannes issue in RTAS call from xmon 2015-02-05 22:35:36 -08:00
Kconfig locking/mutex: Disable optimistic spinning on some architectures 2014-07-28 08:00:07 -07:00
Kconfig.debug powerpc: Add an in memory udbg console 2013-05-08 06:36:49 +10:00
Makefile powerpc: Fix 64 bit builds with binutils 2.24 2014-06-07 13:25:40 -07:00
relocs_check.pl