X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?a=blobdiff_plain;f=palacios%2Fsrc%2Fpalacios%2Fvmm_halt.c;h=7970a404f4e877c078411086b0d828ad883bf927;hb=07a12ade201ee7c2fe2358084ca079d2facac500;hp=5015046ed5b2fa7ea6ab1e9f50f9489082f101b1;hpb=c4e343e346404fcc7674dcfa32e588a282be0f86;p=palacios.git diff --git a/palacios/src/palacios/vmm_halt.c b/palacios/src/palacios/vmm_halt.c index 5015046..7970a40 100644 --- a/palacios/src/palacios/vmm_halt.c +++ b/palacios/src/palacios/vmm_halt.c @@ -38,17 +38,12 @@ int v3_handle_halt(struct guest_info * info) { if (info->cpl != 0) { v3_raise_exception(info, GPF_EXCEPTION); } else { - uint64_t yield_start = 0; - PrintDebug("CPU Yield\n"); while (!v3_intr_pending(info)) { - rdtscll(yield_start); + /* Since we're in an exit, time is already paused here, so no need to pause again. */ v3_yield(info); - - v3_update_time(info, yield_start - info->time_state.cached_host_tsc); - - rdtscll(info->time_state.cached_host_tsc); + v3_update_timers(info); /* At this point, we either have some combination of interrupts, including perhaps a timer interrupt, or