X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?a=blobdiff_plain;f=palacios%2Fsrc%2Fpalacios%2Fvmm_halt.c;h=57aee0fffe39ccdbccb950f9037a12369de09fde;hb=d57b407f9d05a21303bc2c94cbd5142de130be48;hp=e7862c814803a0f54a18f6480a993d4ef74a8ff0;hpb=25aec1d035e5a740d8c1cb936d7633b6bb5751f1;p=palacios.git diff --git a/palacios/src/palacios/vmm_halt.c b/palacios/src/palacios/vmm_halt.c index e7862c8..57aee0f 100644 --- a/palacios/src/palacios/vmm_halt.c +++ b/palacios/src/palacios/vmm_halt.c @@ -21,6 +21,7 @@ #include #include #include +#include #ifndef V3_CONFIG_DEBUG_HALT #undef PrintDebug @@ -28,29 +29,37 @@ #endif -#define YIELD_TIME_USEC 1000 - - // // This should trigger a #GP if cpl != 0, otherwise, yield to host // -int v3_handle_halt(struct guest_info * info) { - +int v3_handle_halt(struct guest_info * info) +{ + if (info->cpl != 0) { v3_raise_exception(info, GPF_EXCEPTION); } else { - PrintDebug("CPU Yield\n"); + uint64_t start_cycles; + + PrintDebug(info->vm_info, info, "CPU Yield\n"); + + start_cycles = v3_get_host_time(&info->time_state); while (!v3_intr_pending(info) && (info->vm_info->run_state == VM_RUNNING)) { uint64_t t, cycles; - /* Yield, allowing time to pass while yielded */ + t = v3_get_host_time(&info->time_state); - v3_yield(info,YIELD_TIME_USEC); + + /* Yield, allowing time to pass while yielded */ + v3_strategy_driven_yield(info, v3_cycle_diff_in_usec(info, start_cycles, t)); + cycles = v3_get_host_time(&info->time_state) - t; + v3_advance_time(info, &cycles); v3_update_timers(info); + + /* At this point, we either have some combination of interrupts, including perhaps a timer interrupt, or @@ -61,9 +70,17 @@ int v3_handle_halt(struct guest_info * info) { /* asm("hlt"); */ } + // participate in any barrier that might be raised + v3_wait_at_barrier(info); + + // stop if the VM is being halted or core is being reset + if (info->core_run_state == CORE_STOPPED || info->core_run_state == CORE_RESETTING) { + break; + } + } - /* V3_Print("palacios: done with halt\n"); */ + /* V3_Print(info->vm_info, info, "palacios: done with halt\n"); */ info->rip += 1; }