;------------------------------------------------------------------------------ ; ; Copyright (c) 2006 - 2015, Intel Corporation. All rights reserved.
; SPDX-License-Identifier: BSD-2-Clause-Patent ; ; Module Name: ; ; FlushCacheLine.Asm ; ; Abstract: ; ; AsmFlushCacheLine function ; ; Notes: ; ;------------------------------------------------------------------------------ SECTION .text ;------------------------------------------------------------------------------ ; VOID * ; EFIAPI ; AsmFlushCacheLine ( ; IN VOID *LinearAddress ; ); ;------------------------------------------------------------------------------ global ASM_PFX(AsmFlushCacheLine) ASM_PFX(AsmFlushCacheLine): ; ; If the CPU does not support CLFLUSH instruction, ; then promote flush range to flush entire cache. ; mov eax, 1 push ebx cpuid pop ebx mov eax, [esp + 4] test edx, BIT19 jz .0 clflush [eax] ret .0: wbinvd ret