X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?a=blobdiff_plain;f=palacios%2Fsrc%2Fpalacios%2Fvmm_halt.c;h=bfe2e5ac43c201e83bd50a294d995cc28319c98f;hb=9a32111c4074aafd55cd9590a24bd5c751a6fe61;hp=fc6d3d5437f15fa2107d75832e41caf48692741f;hpb=94f67717b6461df514dc225ed84f03b44c44061b;p=palacios.git diff --git a/palacios/src/palacios/vmm_halt.c b/palacios/src/palacios/vmm_halt.c index fc6d3d5..bfe2e5a 100644 --- a/palacios/src/palacios/vmm_halt.c +++ b/palacios/src/palacios/vmm_halt.c @@ -20,7 +20,7 @@ #include #include - +#include #ifndef V3_CONFIG_DEBUG_HALT #undef PrintDebug @@ -42,18 +42,26 @@ int v3_handle_halt(struct guest_info * info) { while (!v3_intr_pending(info)) { /* Since we're in an exit, time is already paused here, so no need to pause again. */ + // V3_Print("palacios: halt->yield\n"); + v3_yield(info); - v3_update_timers(info); + v3_disable_ints(); + v3_update_timers(info); + v3_enable_ints(); + /* At this point, we either have some combination of interrupts, including perhaps a timer interrupt, or no interrupt. */ if (!v3_intr_pending(info)) { /* if no interrupt, then we do halt */ - asm("hlt"); + /* asm("hlt"); */ } + } + + /* V3_Print("palacios: done with halt\n"); */ info->rip += 1; }