]> git.proxmox.com Git - mirror_edk2.git/blame - MdePkg/Library/BaseLib/Ia32/FlushCacheLine.nasm
MdePkg BaseLib: Convert Ia32/FlushCacheLine.asm to NASM
[mirror_edk2.git] / MdePkg / Library / BaseLib / Ia32 / FlushCacheLine.nasm
CommitLineData
2aefd3c3
JJ
1;------------------------------------------------------------------------------\r
2;\r
3; Copyright (c) 2006 - 2015, Intel Corporation. All rights reserved.<BR>\r
4; This program and the accompanying materials\r
5; are licensed and made available under the terms and conditions of the BSD License\r
6; which accompanies this distribution. The full text of the license may be found at\r
7; http://opensource.org/licenses/bsd-license.php.\r
8;\r
9; THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
10; WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
11;\r
12; Module Name:\r
13;\r
14; FlushCacheLine.Asm\r
15;\r
16; Abstract:\r
17;\r
18; AsmFlushCacheLine function\r
19;\r
20; Notes:\r
21;\r
22;------------------------------------------------------------------------------\r
23\r
24 SECTION .text\r
25\r
26;------------------------------------------------------------------------------\r
27; VOID *\r
28; EFIAPI\r
29; AsmFlushCacheLine (\r
30; IN VOID *LinearAddress\r
31; );\r
32;------------------------------------------------------------------------------\r
33global ASM_PFX(AsmFlushCacheLine)\r
34ASM_PFX(AsmFlushCacheLine):\r
35 ;\r
36 ; If the CPU does not support CLFLUSH instruction,\r
37 ; then promote flush range to flush entire cache.\r
38 ;\r
39 mov eax, 1\r
40 push ebx\r
41 cpuid\r
42 pop ebx\r
43 mov eax, [esp + 4]\r
44 test edx, BIT19\r
45 jz .0\r
46 clflush [eax]\r
47 ret\r
48.0:\r
49 wbinvd\r
50 ret\r
51\r