2007-06-22 05:21:45 +02:00
|
|
|
/** @file
|
|
|
|
AsmMwait function
|
|
|
|
|
2010-04-23 18:00:47 +02:00
|
|
|
Copyright (c) 2006 - 2008, Intel Corporation. All rights reserved.<BR>
|
2019-04-04 01:06:00 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2007-06-22 05:21:45 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
2008-07-25 14:21:57 +02:00
|
|
|
/**
|
|
|
|
Executes an MWAIT instruction.
|
|
|
|
|
|
|
|
Executes an MWAIT instruction with the register state specified by Eax and
|
2008-12-05 04:23:13 +01:00
|
|
|
Ecx. Returns Eax. This function is only available on IA-32 and x64.
|
2008-07-25 14:21:57 +02:00
|
|
|
|
2008-10-24 08:06:42 +02:00
|
|
|
@param RegisterEax The value to load into EAX or RAX before executing the MONITOR
|
|
|
|
instruction.
|
|
|
|
@param RegisterEcx The value to load into ECX or RCX before executing the MONITOR
|
|
|
|
instruction.
|
2008-07-25 14:21:57 +02:00
|
|
|
|
2008-10-24 08:06:42 +02:00
|
|
|
@return RegisterEax
|
2008-07-25 14:21:57 +02:00
|
|
|
|
|
|
|
**/
|
2007-06-22 05:21:45 +02:00
|
|
|
UINTN
|
|
|
|
EFIAPI
|
|
|
|
AsmMwait (
|
|
|
|
IN UINTN RegisterEax,
|
|
|
|
IN UINTN RegisterEcx
|
|
|
|
)
|
|
|
|
{
|
|
|
|
_asm {
|
|
|
|
mov eax, RegisterEax
|
|
|
|
mov ecx, RegisterEcx
|
|
|
|
_emit 0x0f // mwait
|
|
|
|
_emit 0x01
|
|
|
|
_emit 0xC9
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|