X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?a=blobdiff_plain;f=palacios%2Fsrc%2Fpalacios%2Fsvm_halt.c;h=fea77ba87381e142d1a8f3be682b4862cfa7abb8;hb=55ced750335769366957df3c0cc3fbc8b82a3ea9;hp=54e8a3d3e68740a680f61d7cca0926fae4ccb3d0;hpb=266af4b5b19da7bee8e7445288c7c1cb3ee194c7;p=palacios.git diff --git a/palacios/src/palacios/svm_halt.c b/palacios/src/palacios/svm_halt.c index 54e8a3d..fea77ba 100644 --- a/palacios/src/palacios/svm_halt.c +++ b/palacios/src/palacios/svm_halt.c @@ -18,11 +18,6 @@ * redistribute, and modify it as specified in the file "V3VEE_LICENSE". */ - - - - - #include #include @@ -44,17 +39,11 @@ int v3_handle_svm_halt(struct guest_info * info) v3_raise_exception(info, GPF_EXCEPTION); } else { - // What we should do is starting waiting on an OS event that will - // result in an injection of an interrupt. - - // What we will hackishly do instead is resume on any event - // Plus is this totally GeekOS specific - ullong_t yield_start = 0; ullong_t yield_stop = 0; uint32_t gap = 0; - PrintDebug("GeekOS Yield\n"); + PrintDebug("CPU Yield\n"); rdtscll(yield_start); V3_Yield(); @@ -63,9 +52,11 @@ int v3_handle_svm_halt(struct guest_info * info) //v3_update_time(info, yield_stop - yield_start); gap = yield_stop - yield_start; - v3_raise_irq(info, 0); + if (!v3_intr_pending(info)) { + v3_raise_irq(info, 0); + } - PrintDebug("GeekOS Yield Done (%d cycles)\n", gap); + PrintDebug("CPU Yield Done (%d cycles)\n", gap); info->rip+=1; }