]> git.proxmox.com Git - mirror_edk2.git/blame - MdePkg/Library/BaseLib/Ia32/EnableCache.asm
Update copyright for files modified in this year
[mirror_edk2.git] / MdePkg / Library / BaseLib / Ia32 / EnableCache.asm
CommitLineData
9f4f2f0e 1;------------------------------------------------------------------------------\r
2;\r
373ade0e 3; Copyright (c) 2006 - 2008, Intel Corporation\r
9f4f2f0e 4; All rights reserved. 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; EnableCache.Asm\r
15;\r
16; Abstract:\r
17;\r
18; Flush all caches with a WBINVD instruction, clear the CD bit of CR0 to 0, and clear \r
19; the NW bit of CR0 to 0\r
20;\r
21; Notes:\r
22;\r
23;------------------------------------------------------------------------------\r
24\r
e73bf9f3 25 .486p\r
9f4f2f0e 26 .model flat,C\r
27 .code\r
28\r
29;------------------------------------------------------------------------------\r
30; VOID\r
31; EFIAPI\r
32; AsmEnableCache (\r
33; VOID\r
34; );\r
35;------------------------------------------------------------------------------\r
36AsmEnableCache PROC\r
37 wbinvd\r
38 mov eax, cr0\r
39 btr eax, 29\r
40 btr eax, 30\r
41 mov cr0, eax\r
42 ret\r
43AsmEnableCache ENDP\r
44\r
45 END\r