X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?a=blobdiff_plain;f=palacios%2Fsrc%2Fpalacios%2Fvmm_halt.c;h=5015046ed5b2fa7ea6ab1e9f50f9489082f101b1;hb=13d9a33d365278c508b8709288f9c7c2949a50f9;hp=2be016ce7c21e8c9c8091364a90e5ba2c2bf5dfc;hpb=cfcceed5890430afedcc544bd7dbb69e29dfd65a;p=palacios.git diff --git a/palacios/src/palacios/vmm_halt.c b/palacios/src/palacios/vmm_halt.c index 2be016c..5015046 100644 --- a/palacios/src/palacios/vmm_halt.c +++ b/palacios/src/palacios/vmm_halt.c @@ -38,36 +38,27 @@ int v3_handle_halt(struct guest_info * info) { if (info->cpl != 0) { v3_raise_exception(info, GPF_EXCEPTION); } else { - uint64_t yield_start = 0; - uint64_t yield_stop = 0; - uint32_t gap = 0; PrintDebug("CPU Yield\n"); - - rdtscll(yield_start); - v3_yield(info); - rdtscll(yield_stop); - - - //v3_update_time(info, yield_stop - yield_start); - gap = yield_stop - yield_start; - /* WARNING!!! WARNING!!! - * - * DO NOT REMOVE THIS CONDITIONAL!!! - * - * It is common for an OS to issue an IO op, and then sit in a halt loop - * waiting for the device to complete and raise an irq. - * If you remove this then the timer interrupt will ALWAYS subvert the completion - * interrupt and stall the guest. - */ - if (!v3_intr_pending(info)) { - v3_raise_irq(info, 0); + while (!v3_intr_pending(info)) { + rdtscll(yield_start); + v3_yield(info); + + v3_update_time(info, yield_start - info->time_state.cached_host_tsc); + + rdtscll(info->time_state.cached_host_tsc); + + /* 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"); + } } - - - PrintDebug("CPU Yield Done (%d cycles)\n", gap); info->rip += 1; }