X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?p=palacios.git;a=blobdiff_plain;f=palacios%2Fsrc%2Fpalacios%2Fsvm_halt.c;h=16239e841df7571aed22a20b5156f8cc670f1d37;hp=fea77ba87381e142d1a8f3be682b4862cfa7abb8;hb=e23a867d9dcecc70fc76adc0f89404dbc50e5b78;hpb=33916e4213bf7bb340361669bcdb2f3169ea5f06 diff --git a/palacios/src/palacios/svm_halt.c b/palacios/src/palacios/svm_halt.c index fea77ba..16239e8 100644 --- a/palacios/src/palacios/svm_halt.c +++ b/palacios/src/palacios/svm_halt.c @@ -33,9 +33,9 @@ // This should trigger a #GP if cpl!=0, otherwise, yield to host // -int v3_handle_svm_halt(struct guest_info * info) -{ - if (info->cpl!=0) { +int v3_handle_svm_halt(struct guest_info * info) { + + if (info->cpl != 0) { v3_raise_exception(info, GPF_EXCEPTION); } else { @@ -46,19 +46,20 @@ int v3_handle_svm_halt(struct guest_info * info) PrintDebug("CPU Yield\n"); rdtscll(yield_start); - V3_Yield(); + v3_yield(info); rdtscll(yield_stop); //v3_update_time(info, yield_stop - yield_start); gap = yield_stop - yield_start; - if (!v3_intr_pending(info)) { - v3_raise_irq(info, 0); - } + + v3_raise_irq(info, 0); + PrintDebug("CPU Yield Done (%d cycles)\n", gap); info->rip+=1; } + return 0; }