]> git.proxmox.com Git - mirror_edk2.git/blame - MdePkg/Library/BaseLib/Ia32/Mwait.c
Update the text to use "x64" instead of "X64" in MdePkg.
[mirror_edk2.git] / MdePkg / Library / BaseLib / Ia32 / Mwait.c
CommitLineData
e1f414b6 1/** @file\r
2 AsmMwait function\r
3\r
44b013bd 4 Copyright (c) 2006 - 2008, Intel Corporation<BR>\r
e1f414b6 5 All rights reserved. This program and the accompanying materials\r
6 are licensed and made available under the terms and conditions of the BSD License\r
7 which accompanies this distribution. The full text of the license may be found at\r
8 http://opensource.org/licenses/bsd-license.php\r
9\r
10 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
11 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
12\r
13**/\r
14\r
42eedea9 15/**\r
16 Executes an MWAIT instruction.\r
17\r
18 Executes an MWAIT instruction with the register state specified by Eax and\r
030cd1a2 19 Ecx. Returns Eax. This function is only available on IA-32 and x64.\r
42eedea9 20\r
44b013bd 21 @param RegisterEax The value to load into EAX or RAX before executing the MONITOR\r
22 instruction.\r
23 @param RegisterEcx The value to load into ECX or RCX before executing the MONITOR\r
24 instruction.\r
42eedea9 25\r
44b013bd 26 @return RegisterEax\r
42eedea9 27\r
28**/\r
e1f414b6 29UINTN\r
30EFIAPI\r
31AsmMwait (\r
32 IN UINTN RegisterEax,\r
33 IN UINTN RegisterEcx\r
34 )\r
35{\r
36 _asm {\r
37 mov eax, RegisterEax\r
38 mov ecx, RegisterEcx\r
39 _emit 0x0f // mwait\r
40 _emit 0x01\r
41 _emit 0xC9\r
42 }\r
43}\r
44\r