Commit d40c54d641148b29457c2cb2abf6038bcea889c1

Authored by aurel32
1 parent 5e9ae189

target-i386: SVM: acknowledge interrupt only after it is taken

SVM specifies that the V_IRQ mask is only to be removed, if the
interrupt that is to be delivered actually is delivered.

As of the SVM rewrite, this mask is always unmasked when the main cpu
loop is processed, leaving a corner case where calling the interrupt
handler causes a #PF. In that case (booting Linux / starting gfxboot)
the current implementation tells the VMM the interrupt is taken, even
though it is not.

This patch modifies the VIRQ unmasking to occur after do_interrupt,
making gfxboot work again.

Signed-off-by: Alexander Graf <agraf@suse.de>
Signed-off-by: Aurelien Jarno <aurelien@aurel32.net>

git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@6008 c046a42c-6fe2-441c-8c8c-71466251a162
Showing 1 changed file with 1 additions and 1 deletions
cpu-exec.c
... ... @@ -401,11 +401,11 @@ int cpu_exec(CPUState *env1)
401 401 int intno;
402 402 /* FIXME: this should respect TPR */
403 403 svm_check_intercept(SVM_EXIT_VINTR);
404   - env->interrupt_request &= ~CPU_INTERRUPT_VIRQ;
405 404 intno = ldl_phys(env->vm_vmcb + offsetof(struct vmcb, control.int_vector));
406 405 if (loglevel & CPU_LOG_TB_IN_ASM)
407 406 fprintf(logfile, "Servicing virtual hardware INT=0x%02x\n", intno);
408 407 do_interrupt(intno, 0, 0, 0, 1);
  408 + env->interrupt_request &= ~CPU_INTERRUPT_VIRQ;
409 409 next_tb = 0;
410 410 #endif
411 411 }
... ...