From: Jack Lange Date: Fri, 20 Mar 2009 22:17:13 +0000 (-0500) Subject: added EXITINTINFO checks before interrupt injection X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?p=palacios.git;a=commitdiff_plain;h=04e582f922cfa2e9fb7304e1987a3d2298c43868 added EXITINTINFO checks before interrupt injection --- diff --git a/palacios/src/palacios/svm_handler.c b/palacios/src/palacios/svm_handler.c index 7c278d3..aaed6c6 100644 --- a/palacios/src/palacios/svm_handler.c +++ b/palacios/src/palacios/svm_handler.c @@ -74,9 +74,15 @@ int v3_handle_svm_exit(struct guest_info * info) { if ((info->intr_state.irq_pending == 1) && (guest_ctrl->guest_ctrl.V_IRQ == 0)) { // Interrupt was taken in the guest #ifdef DEBUG_INTERRUPTS - PrintDebug("Interrupt %d taken by guest\n", info->intr_state.irq_vector); + PrintDebug("Interrupt %d taken by guest\n", info->intr_state.irq_vector); #endif - v3_injecting_intr(info, info->intr_state.irq_vector, EXTERNAL_IRQ); + if (!guest_ctrl->exit_int_info.valid) { + v3_injecting_intr(info, info->intr_state.irq_vector, EXTERNAL_IRQ); + } else { +#ifdef DEBUG_INTERRUPTS + PrintDebug("EXIT INT INFO is set (vec=%d)\n", guest_ctrl->exit_int_info.vector); +#endif + } } info->intr_state.irq_pending = 0;