include vmm.inc
mov eax, PriorityBoost
mov ebx, VMHandle
mov ecx, Flags
mov edx, RefData
mov esi, OFFSET32 PriorityEventCallback
mov edi, TimeOut
VMMCall Call_Priority_VM_Event
mov [EventHandle], esi
Calls the callback function immediately or schedules a priority event for the specified virtual machine. This is an asynchronous service. Uses Flags and ESI.
Value | Meaning |
---|---|
Reserved_Low_Boost | Reserved for use by system. |
Cur_Run_VM_Boost | Use to boost the priority of each virtual machine, in turn, forcing them to run for their allotted time slices. |
Low_Pri_Device_Boost | Use for operations that need timely processing but are not time critical. |
High_Pri_Device_Boost | Use for time-critical operations that should not circumvent the critical section boost. |
Critical_Section_Boost | Use to boost the priority of the virtual machine whenever it enters a critical section (calls Begin_Critical_Section). |
Time_Critical_Boost | Use for operations that require immediate processing, even when another virtual machine is in a critical section. For example, VPICD uses this when simulating hardware interrupts. |
Reserved_High_Boost | Reserved for use by system. |
Forgetting to pass a priority value in the EAX register is a common error.
Value | Meaning |
---|---|
PEF_Always_Sched | Event is always scheduled, meaning the callback function is never called immediately. |
PEF_Dont_Unboost | Priority of the virtual machine is not reduced after return from callback function. |
PEF_Time_Out | Specifies that time-out value in the EDI register should be used. Available in Windows version 3.1 or later. |
PEF_Wait_For_STI | Callback function is not called until the virtual machine enables interrupts in all threads. |
PEF_Wait_Not_Crit | Callback function is not called until the virtual machine is not in a critical section or time-critical operation. |
PEF_Wait_Not_Time_Crit, PEF_Wait_Not_HW_Int | Callback function is not called until the thread priority is below TIME_CRITICAL_BOOST. Useful to prevent an event from occurring while an interrupt is being simulated into a VM. |
All other values are reserved.
The system carries out a task switch to the specified virtual machine if it is not the current virtual machine. If PriorityBoost is not zero, the service boosts the priority of the virtual machine before calling the callback function.
If the amount of time specified by TimeOut elapses before the system can switch to the virtual machine, the system sets the carry flag and calls the callback function immediately regardless of which virtual machine is currently running. In this case, any requested priority boost is canceled even if Flags specified the PEF_Dont_Unboost value. The callback function should always check the carry flag to determine whether a time out occurred.
For additional information about event callbacks, see Event Callbacks.
Adjust_Exec_Priority, Begin_Critical_Section, Call_When_Not_Critical, Call_VM_Event, Cancel_Priority_VM_Event, PriorityEventCallback, Call_Restricted_Event