On Thu, 18 Mar 2021 16:59:47 +0000,
Will Deacon <[email protected]> wrote:
>
> On Thu, Mar 18, 2021 at 02:33:11PM +0000, Andrew Scull wrote:
> > To aid with debugging, add details of the source of a panic from nVHE
> > hyp. This is done by having nVHE hyp exit to nvhe_hyp_panic_handler()
> > rather than directly to panic(). The handler will then add the extra
> > details for debugging before panicking the kernel.
> >
> > If the panic was due to a BUG(), look up the metadata to log the file
> > and line, if available, otherwise log an address that can be looked up
> > in vmlinux. The hyp offset is also logged to allow other hyp VAs to be
> > converted, similar to how the kernel offset is logged during a panic.
> >
> > __hyp_panic_string is now inlined since it no longer needs to be
> > referenced as a symbol and the message is free to diverge between VHE
> > and nVHE.
> >
> > The following is an example of the logs generated by a BUG in nVHE hyp.
> >
> > [ 46.754840] kvm [307]: nVHE hyp BUG at:
> > arch/arm64/kvm/hyp/nvhe/switch.c:242!
> > [ 46.755357] kvm [307]: Hyp Offset: 0xfffea6c58e1e0000
> > [ 46.755824] Kernel panic - not syncing: HYP panic:
> > [ 46.755824] PS:400003c9 PC:0000d93a82c705ac ESR:f2000800
> > [ 46.755824] FAR:0000000080080000 HPFAR:0000000000800800
> > PAR:0000000000000000
> > [ 46.755824] VCPU:0000d93a880d0000
> > [ 46.756960] CPU: 3 PID: 307 Comm: kvm-vcpu-0 Not tainted
> > 5.12.0-rc3-00005-gc572b99cf65b-dirty #133
> > [ 46.757459] Hardware name: QEMU QEMU Virtual Machine, BIOS 0.0.0
> > 02/06/2015
> > [ 46.758366] Call trace:
> > [ 46.758601] dump_backtrace+0x0/0x1b0
> > [ 46.758856] show_stack+0x18/0x70
> > [ 46.759057] dump_stack+0xd0/0x12c
> > [ 46.759236] panic+0x16c/0x334
> > [ 46.759426] arm64_kernel_unmapped_at_el0+0x0/0x30
> > [ 46.759661] kvm_arch_vcpu_ioctl_run+0x134/0x750
> > [ 46.759936] kvm_vcpu_ioctl+0x2f0/0x970
> > [ 46.760156] __arm64_sys_ioctl+0xa8/0xec
> > [ 46.760379] el0_svc_common.constprop.0+0x60/0x120
> > [ 46.760627] do_el0_svc+0x24/0x90
> > [ 46.760766] el0_svc+0x2c/0x54
> > [ 46.760915] el0_sync_handler+0x1a4/0x1b0
> > [ 46.761146] el0_sync+0x170/0x180
> > [ 46.761889] SMP: stopping secondary CPUs
> > [ 46.762786] Kernel Offset: 0x3e1cd2820000 from 0xffff800010000000
> > [ 46.763142] PHYS_OFFSET: 0xffffa9f680000000
> > [ 46.763359] CPU features: 0x00240022,61806008
> > [ 46.763651] Memory Limit: none
>
> Nice!
>
> > [ 46.813867] ---[ end Kernel panic - not syncing: HYP panic:
> > [ 46.813867] PS:400003c9 PC:0000d93a82c705ac ESR:f2000800
> > [ 46.813867] FAR:0000000080080000 HPFAR:0000000000800800
> > PAR:0000000000000000
> > [ 46.813867] VCPU:0000d93a880d0000 ]---
>
> Why did these last three lines get printed twice?
That's the panic string that gets repeated, a standard "feature" of
the panic code:
root@tiger-roach:~# echo -n 'c' > /proc/sysrq-trigger
[250622.941867] sysrq: Trigger a crash
[250622.941903] Kernel panic - not syncing: sysrq triggered crash
[250622.945515] CPU: 0 PID: 4890 Comm: bash Tainted: G E 5.11.0
#3124
[250622.952930] Hardware name: , BIOS 2021.01-rc2-00012-gde865f7ee1 11/16/2020
[250622.959917] Call trace:
[250622.962417] dump_backtrace+0x0/0x1e4
[250622.966126] show_stack+0x24/0x80
[250622.969490] dump_stack+0xc8/0x120
[250622.972940] panic+0x178/0x38c
[250622.976045] sysrq_handle_crash+0x28/0x30
[250622.980098] __handle_sysrq+0x98/0x1a4
[250622.983893] write_sysrq_trigger+0x94/0x12c
[250622.988120] proc_reg_write+0xb4/0xf0
[250622.991828] vfs_write+0xfc/0x29c
[250622.995192] ksys_write+0x74/0x100
[250622.998642] __arm64_sys_write+0x28/0x3c
[250623.002610] el0_svc_common.constprop.0+0x80/0x1c0
[250623.007440] do_el0_svc+0x30/0xa0
[250623.010803] el0_svc+0x28/0x70
[250623.013908] el0_sync_handler+0x1a8/0x1ac
[250623.017962] el0_sync+0x174/0x180
[250623.021331] SMP: stopping secondary CPUs
[250623.025301] Kernel Offset: 0x435917bf0000 from 0xffff800010000000
[250623.031417] PHYS_OFFSET: 0xffff9bc5c0000000
[250623.035643] CPU features: 0x08240022,2aa0a830
[250623.040042] Memory Limit: none
[250623.043153] ---[ end Kernel panic - not syncing: sysrq triggered crash ]---
KVM just happens to have a fairly large, multi line panic string.
M.
--
Without deviation from the norm, progress is not possible.
_______________________________________________
kvmarm mailing list
[email protected]
https://lists.cs.columbia.edu/mailman/listinfo/kvmarm