2016-05-13 07:00:53 +02:00
|
|
|
/** @file
|
|
|
|
|
|
|
|
Copyright (c) 2014, Intel Corporation. All rights reserved.<BR>
|
2019-04-04 01:04:04 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2016-05-13 07:00:53 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#ifndef _CACHE_LIB_H_
|
|
|
|
#define _CACHE_LIB_H_
|
|
|
|
|
|
|
|
//
|
|
|
|
// EFI_MEMORY_CACHE_TYPE
|
|
|
|
//
|
|
|
|
typedef INT32 EFI_MEMORY_CACHE_TYPE;
|
|
|
|
|
|
|
|
#define EFI_CACHE_UNCACHEABLE 0
|
|
|
|
#define EFI_CACHE_WRITECOMBINING 1
|
|
|
|
#define EFI_CACHE_WRITETHROUGH 4
|
|
|
|
#define EFI_CACHE_WRITEPROTECTED 5
|
|
|
|
#define EFI_CACHE_WRITEBACK 6
|
|
|
|
|
|
|
|
/**
|
|
|
|
Reset all the MTRRs to a known state.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS All MTRRs have been reset successfully.
|
|
|
|
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
ResetCacheAttributes (
|
|
|
|
VOID
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Given the memory range and cache type, programs the MTRRs.
|
|
|
|
|
|
|
|
@param[in] MemoryAddress Base Address of Memory to program MTRR.
|
|
|
|
@param[in] MemoryLength Length of Memory to program MTRR.
|
|
|
|
@param[in] MemoryCacheType Cache Type.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS Mtrr are set successfully.
|
|
|
|
@retval EFI_LOAD_ERROR No empty MTRRs to use.
|
|
|
|
@retval EFI_INVALID_PARAMETER The input parameter is not valid.
|
|
|
|
@retval others An error occurs when setting MTTR.
|
|
|
|
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
SetCacheAttributes (
|
|
|
|
IN EFI_PHYSICAL_ADDRESS MemoryAddress,
|
|
|
|
IN UINT64 MemoryLength,
|
|
|
|
IN EFI_MEMORY_CACHE_TYPE MemoryCacheType
|
|
|
|
);
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|