Re: PING: [PATCH] KVM: arm64: Decode basic HYP fault information

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Pavel,

It's only been a week and we're approaching the merge window.

Both Marc and I are well aware that you sent this patch.

Please be more patient.  For example, if a month or more passes without
you hearing anything, then it's ok to ask what the plans are.

-Christoffer

On Wed, Aug 19, 2015 at 10:26:34AM +0300, Pavel Fedin wrote:
> PING
> 
> Kind regards,
> Pavel Fedin
> Expert Engineer
> Samsung Electronics Research center Russia
> 
> 
> > -----Original Message-----
> > From: kvm-owner@xxxxxxxxxxxxxxx [mailto:kvm-owner@xxxxxxxxxxxxxxx] On Behalf Of Pavel Fedin
> > Sent: Tuesday, August 11, 2015 10:34 AM
> > To: kvmarm@xxxxxxxxxxxxxxxxxxxxx; kvm@xxxxxxxxxxxxxxx
> > Cc: 'Christoffer Dall'; 'Marc Zyngier'
> > Subject: [PATCH] KVM: arm64: Decode basic HYP fault information
> > 
> > Print exception vector name, exception class and PC translated to EL1 virtual
> > address. Significantly aids debugging HYP crashes without special means like
> > JTAG.
> > 
> > Signed-off-by: Pavel Fedin <p.fedin@xxxxxxxxxxx>
> > ---
> >  arch/arm64/kvm/handle_exit.c | 30 +++++++++++++++++++++++++++++
> >  arch/arm64/kvm/hyp.S         | 46 +++++++++++++++++---------------------------
> >  2 files changed, 48 insertions(+), 28 deletions(-)
> > 
> > diff --git a/arch/arm64/kvm/handle_exit.c b/arch/arm64/kvm/handle_exit.c
> > index 29b184a..4d70d64 100644
> > --- a/arch/arm64/kvm/handle_exit.c
> > +++ b/arch/arm64/kvm/handle_exit.c
> > @@ -136,3 +136,33 @@ int handle_exit(struct kvm_vcpu *vcpu, struct kvm_run *run,
> >  		return 0;
> >  	}
> >  }
> > +
> > +static const char *const hyp_faults[] = {
> > +	"EL2t Synchronous",
> > +	"EL2t IRQ",
> > +	"EL2t FIQ",
> > +	"EL2t Error",
> > +	"EL2h Synchronous",
> > +	"EL2h IRQ",
> > +	"EL2h FIQ",
> > +	"EL2h Error",
> > +	"EL1 Synchronous",
> > +	"EL1 IRQ",
> > +	"EL1 FIQ",
> > +	"EL1 Error"
> > +};
> > +
> > +void kvm_hyp_panic(unsigned long vector, unsigned int spsr, unsigned long pc,
> > +		   unsigned int esr, unsigned long far, unsigned long hpfar,
> > +		   unsigned long par, struct kvm_vcpu *vcpu)
> > +{
> > +	pr_emerg("Unhandled HYP exception %s on VCPU %p\n",
> > +		hyp_faults[vector], vcpu);
> > +	pr_emerg("PC : %016lx SPSR : %08x         ESR: %08x\n", pc, spsr, esr);
> > +	pr_emerg("FAR: %016lx HPFAR: %016lx PAR: %016lx\n", far, hpfar, par);
> > +
> > +	pr_emerg("Exception class: %02x Translated PC: %016lx\n",
> > +		esr >> ESR_ELx_EC_SHIFT, pc - HYP_PAGE_OFFSET + PAGE_OFFSET);
> > +
> > +	panic("HYP panic");
> > +}
> > diff --git a/arch/arm64/kvm/hyp.S b/arch/arm64/kvm/hyp.S
> > index c81eaaf..62785cd 100644
> > --- a/arch/arm64/kvm/hyp.S
> > +++ b/arch/arm64/kvm/hyp.S
> > @@ -1060,13 +1060,11 @@ __kvm_hyp_panic:
> >  	ldr	x2, [x0, #VCPU_HOST_CONTEXT]
> >  	kern_hyp_va x2
> > 
> > +	mov	x0, lr
> >  	bl __restore_sysregs
> > +	mov	lr, x0
> > 
> > -1:	adr	x0, __hyp_panic_str
> > -	adr	x1, 2f
> > -	ldp	x2, x3, [x1]
> > -	sub	x0, x0, x2
> > -	add	x0, x0, x3
> > +1:	mov	x0, lr
> >  	mrs	x1, spsr_el2
> >  	mrs	x2, elr_el2
> >  	mrs	x3, esr_el2
> > @@ -1078,20 +1076,11 @@ __kvm_hyp_panic:
> >  	mov	lr, #(PSR_F_BIT | PSR_I_BIT | PSR_A_BIT | PSR_D_BIT |\
> >  		      PSR_MODE_EL1h)
> >  	msr	spsr_el2, lr
> > -	ldr	lr, =panic
> > +	ldr	lr, =kvm_hyp_panic
> >  	msr	elr_el2, lr
> >  	eret
> > -
> > -	.align	3
> > -2:	.quad	HYP_PAGE_OFFSET
> > -	.quad	PAGE_OFFSET
> >  ENDPROC(__kvm_hyp_panic)
> > 
> > -__hyp_panic_str:
> > -	.ascii	"HYP panic:\nPS:%08x PC:%p ESR:%p\nFAR:%p HPFAR:%p PAR:%p\nVCPU:%p\n\0"
> > -
> > -	.align	2
> > -
> >  /*
> >   * u64 kvm_call_hyp(void *hypfn, ...);
> >   *
> > @@ -1115,26 +1104,27 @@ ENTRY(kvm_call_hyp)
> >  	ret
> >  ENDPROC(kvm_call_hyp)
> > 
> > -.macro invalid_vector	label, target
> > +.macro invalid_vector	label, N, target
> >  	.align	2
> >  \label:
> > +	mov lr, #\N
> >  	b \target
> >  ENDPROC(\label)
> >  .endm
> > 
> >  	/* None of these should ever happen */
> > -	invalid_vector	el2t_sync_invalid, __kvm_hyp_panic
> > -	invalid_vector	el2t_irq_invalid, __kvm_hyp_panic
> > -	invalid_vector	el2t_fiq_invalid, __kvm_hyp_panic
> > -	invalid_vector	el2t_error_invalid, __kvm_hyp_panic
> > -	invalid_vector	el2h_sync_invalid, __kvm_hyp_panic
> > -	invalid_vector	el2h_irq_invalid, __kvm_hyp_panic
> > -	invalid_vector	el2h_fiq_invalid, __kvm_hyp_panic
> > -	invalid_vector	el2h_error_invalid, __kvm_hyp_panic
> > -	invalid_vector	el1_sync_invalid, __kvm_hyp_panic
> > -	invalid_vector	el1_irq_invalid, __kvm_hyp_panic
> > -	invalid_vector	el1_fiq_invalid, __kvm_hyp_panic
> > -	invalid_vector	el1_error_invalid, __kvm_hyp_panic
> > +	invalid_vector	el2t_sync_invalid, 0, __kvm_hyp_panic
> > +	invalid_vector	el2t_irq_invalid, 1, __kvm_hyp_panic
> > +	invalid_vector	el2t_fiq_invalid, 2, __kvm_hyp_panic
> > +	invalid_vector	el2t_error_invalid, 3, __kvm_hyp_panic
> > +	invalid_vector	el2h_sync_invalid, 4, __kvm_hyp_panic
> > +	invalid_vector	el2h_irq_invalid, 5, __kvm_hyp_panic
> > +	invalid_vector	el2h_fiq_invalid, 6, __kvm_hyp_panic
> > +	invalid_vector	el2h_error_invalid, 7, __kvm_hyp_panic
> > +	invalid_vector	el1_sync_invalid, 8, __kvm_hyp_panic
> > +	invalid_vector	el1_irq_invalid, 9, __kvm_hyp_panic
> > +	invalid_vector	el1_fiq_invalid, 10, __kvm_hyp_panic
> > +	invalid_vector	el1_error_invalid, 11, __kvm_hyp_panic
> > 
> >  el1_sync:					// Guest trapped into EL2
> >  	push	x0, x1
> > --
> > 2.4.4
> > 
> > 
> > Kind regards,
> > Pavel Fedin
> > Expert Engineer
> > Samsung Electronics Research center Russia
> > 
> > 
> > 
> > --
> > To unsubscribe from this list: send the line "unsubscribe kvm" in
> > the body of a message to majordomo@xxxxxxxxxxxxxxx
> > More majordomo info at  http://vger.kernel.org/majordomo-info.html
> 
--
To unsubscribe from this list: send the line "unsubscribe kvm" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html



[Index of Archives]     [KVM ARM]     [KVM ia64]     [KVM ppc]     [Virtualization Tools]     [Spice Development]     [Libvirt]     [Libvirt Users]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite Questions]     [Linux Kernel]     [Linux SCSI]     [XFree86]
  Powered by Linux