if (ti_work & (_TIF_NEED_RESCHED | _TIF_NEED_RESCHED_LAZY))
schedule();
if (ti_work & _TIF_NOTIFY_RESUME)
resume_user_mode_work(NULL);
ret = arch_xfer_to_guest_mode_handle_work(vcpu, ti_work); if (ret) return ret;
ti_work = read_thread_flags();
} while (ti_work & XFER_TO_GUEST_MODE_WORK); return0;
}
int xfer_to_guest_mode_handle_work(struct kvm_vcpu *vcpu)
{ unsignedlong ti_work;
/* * This is invoked from the outer guest loop with interrupts and * preemption enabled. * * KVM invokes xfer_to_guest_mode_work_pending() with interrupts * disabled in the inner loop before going into guest mode. No need * to disable interrupts here.
*/
ti_work = read_thread_flags(); if (!(ti_work & XFER_TO_GUEST_MODE_WORK)) return0;
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.