[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-changelog] [xen-unstable] [IA64] Emulate PAL_HALT_LIGHT
# HG changeset patch # User awilliam@xxxxxxxxxxx # Node ID aa8257def6dc1f260f2259cda78ec5437bba3533 # Parent dad1f890aca52bb0b90c920d9f16e4e870a8acde [IA64] Emulate PAL_HALT_LIGHT Use do_block to emulate Guest PAL_HALT_LIGHT, whenever there is an interrupt for this vcpu, this vcpu is woken up. Signed-off-by: Anthony Xu <anthony.xu@xxxxxxxxx> --- xen/arch/ia64/vmx/pal_emul.c | 10 +++++++--- xen/arch/ia64/vmx/vlsapic.c | 13 +++++++------ xen/arch/ia64/xen/vcpu.c | 1 - xen/include/asm-ia64/vcpu.h | 1 + 4 files changed, 15 insertions(+), 10 deletions(-) diff -r dad1f890aca5 -r aa8257def6dc xen/arch/ia64/vmx/pal_emul.c --- a/xen/arch/ia64/vmx/pal_emul.c Mon Jul 03 08:15:43 2006 -0600 +++ b/xen/arch/ia64/vmx/pal_emul.c Mon Jul 03 08:27:24 2006 -0600 @@ -24,6 +24,8 @@ #include <asm/dom_fw.h> #include <asm/tlb.h> #include <asm/vmx_mm_def.h> +#include <xen/hypercall.h> +#include <public/sched.h> static void get_pal_parameters (VCPU *vcpu, UINT64 *gr29, @@ -123,9 +125,11 @@ static struct ia64_pal_retval static struct ia64_pal_retval pal_halt_light (VCPU *vcpu) { struct ia64_pal_retval result; - - result.status= -1; //unimplemented - + + if(SPURIOUS_VECTOR==vmx_check_pending_irq(vcpu)) + do_sched_op_compat(SCHEDOP_block,0); + + result.status= 0; return result; } diff -r dad1f890aca5 -r aa8257def6dc xen/arch/ia64/vmx/vlsapic.c --- a/xen/arch/ia64/vmx/vlsapic.c Mon Jul 03 08:15:43 2006 -0600 +++ b/xen/arch/ia64/vmx/vlsapic.c Mon Jul 03 08:27:24 2006 -0600 @@ -103,6 +103,7 @@ static void vtm_timer_fn(void *data) vitv = VCPU(vcpu, itv); if ( !ITV_IRQ_MASK(vitv) ){ vmx_vcpu_pend_interrupt(vcpu, vitv & 0xff); + vcpu_unblock(vcpu); } vtm=&(vcpu->arch.arch_vmx.vtm); cur_itc = now_itc(vtm); @@ -551,8 +552,7 @@ void vmx_vcpu_pend_batch_interrupt(VCPU * it into the guest. Otherwise, we set the VHPI if vac.a_int=1 so that when * the interrupt becomes unmasked, it gets injected. * RETURN: - * TRUE: Interrupt is injected. - * FALSE: Not injected but may be in VHPI when vac.a_int=1 + * the highest unmasked interrupt. * * Optimization: We defer setting the VHPI until the EOI time, if a higher * priority interrupt is in-service. The idea is to reduce the @@ -562,13 +562,15 @@ int vmx_check_pending_irq(VCPU *vcpu) { uint64_t spsr, mask; int h_pending, h_inservice; - int injected=0; uint64_t isr; IA64_PSR vpsr; REGS *regs=vcpu_regs(vcpu); local_irq_save(spsr); h_pending = highest_pending_irq(vcpu); - if ( h_pending == NULL_VECTOR ) goto chk_irq_exit; + if ( h_pending == NULL_VECTOR ) { + h_pending = SPURIOUS_VECTOR; + goto chk_irq_exit; + } h_inservice = highest_inservice_irq(vcpu); vpsr.val = vmx_vcpu_get_psr(vcpu); @@ -578,7 +580,6 @@ int vmx_check_pending_irq(VCPU *vcpu) if ( !vpsr.ic ) panic_domain(regs,"Interrupt when IC=0\n"); vmx_reflect_interruption(0,isr,0, 12, regs ); // EXT IRQ - injected = 1; } else if ( mask == IRQ_MASKED_BY_INSVC ) { // cann't inject VHPI @@ -591,7 +592,7 @@ int vmx_check_pending_irq(VCPU *vcpu) chk_irq_exit: local_irq_restore(spsr); - return injected; + return h_pending; } /* diff -r dad1f890aca5 -r aa8257def6dc xen/arch/ia64/xen/vcpu.c --- a/xen/arch/ia64/xen/vcpu.c Mon Jul 03 08:15:43 2006 -0600 +++ b/xen/arch/ia64/xen/vcpu.c Mon Jul 03 08:27:24 2006 -0600 @@ -266,7 +266,6 @@ IA64FAULT vcpu_reset_psr_sm(VCPU *vcpu, return IA64_NO_FAULT; } -#define SPURIOUS_VECTOR 0xf IA64FAULT vcpu_set_psr_dt(VCPU *vcpu) { diff -r dad1f890aca5 -r aa8257def6dc xen/include/asm-ia64/vcpu.h --- a/xen/include/asm-ia64/vcpu.h Mon Jul 03 08:15:43 2006 -0600 +++ b/xen/include/asm-ia64/vcpu.h Mon Jul 03 08:27:24 2006 -0600 @@ -20,6 +20,7 @@ typedef cpu_user_regs_t REGS; #define PSCB(_v,_x) VCPU(_v,_x) #define PSCBX(_v,_x) (_v->arch._x) +#define SPURIOUS_VECTOR 0xf /* general registers */ extern UINT64 vcpu_get_gr(VCPU *vcpu, unsigned long reg); _______________________________________________ Xen-changelog mailing list Xen-changelog@xxxxxxxxxxxxxxxxxxx http://lists.xensource.com/xen-changelog
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |