X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?p=palacios.git;a=blobdiff_plain;f=palacios%2Fsrc%2Fpalacios%2Fsvm.c;h=d2444ac915e13224d7a7a866039d7587e56cf813;hp=5fadae1d07c7b81457c78bfd71b36c9455eef26f;hb=afffedf9ab57494864f0710a2530958fa9e216cc;hpb=13fb068168e2826db39a481cf85033bb0156d2f9 diff --git a/palacios/src/palacios/svm.c b/palacios/src/palacios/svm.c index 5fadae1..d2444ac 100644 --- a/palacios/src/palacios/svm.c +++ b/palacios/src/palacios/svm.c @@ -293,7 +293,6 @@ static int start_svm_guest(struct guest_info *info) { */ // disable global interrupts for vm state transition - v3_clgi(); @@ -311,6 +310,11 @@ static int start_svm_guest(struct guest_info *info) { // reenable global interrupts after vm exit v3_stgi(); + + // Conditionally yield the CPU if the timeslice has expired + v3_yield_cond(info); + + v3_update_time(info, tmp_tsc - info->time_state.cached_host_tsc); num_exits++; @@ -322,10 +326,6 @@ static int start_svm_guest(struct guest_info *info) { } } - - // Conditionally yield the CPU if the timeslice has expired - v3_yield_cond(info); - if (v3_handle_svm_exit(info) != 0) { vmcb_ctrl_t * guest_ctrl = GET_VMCB_CTRL_AREA((vmcb_t*)(info->vmm_data)); addr_t host_addr;