Home | History | Annotate | Download | only in Ia32
      1 ;------------------------------------------------------------------------------
      2 ;
      3 ; Copyright (c) 2006 - 2008, Intel Corporation. All rights reserved.<BR>
      4 ; This program and the accompanying materials
      5 ; are licensed and made available under the terms and conditions of the BSD License
      6 ; which accompanies this distribution.  The full text of the license may be found at
      7 ; http://opensource.org/licenses/bsd-license.php.
      8 ;
      9 ; THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
     10 ; WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
     11 ;
     12 ; Module Name:
     13 ;
     14 ;   EnableCache.Asm
     15 ;
     16 ; Abstract:
     17 ;
     18 ;  Flush all caches with a WBINVD instruction, clear the CD bit of CR0 to 0, and clear 
     19 ;  the NW bit of CR0 to 0
     20 ;
     21 ; Notes:
     22 ;
     23 ;------------------------------------------------------------------------------
     24 
     25     .486p
     26     .model  flat,C
     27     .code
     28 
     29 ;------------------------------------------------------------------------------
     30 ; VOID
     31 ; EFIAPI
     32 ; AsmEnableCache (
     33 ;   VOID
     34 ;   );
     35 ;------------------------------------------------------------------------------
     36 AsmEnableCache PROC
     37     wbinvd
     38     mov     eax, cr0
     39     btr     eax, 29
     40     btr     eax, 30
     41     mov     cr0, eax
     42     ret
     43 AsmEnableCache ENDP
     44 
     45     END
     46