2017-09-01 10:30:46 +02:00
|
|
|
/** @file
|
|
|
|
The definition for DMA access Library.
|
|
|
|
|
2018-01-17 04:10:57 +01:00
|
|
|
Copyright (c) 2017 - 2018, Intel Corporation. All rights reserved.<BR>
|
2019-04-04 01:04:11 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2017-09-01 10:30:46 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#ifndef __DMA_ACCESS_LIB_H__
|
|
|
|
#define __DMA_ACCESS_LIB_H__
|
|
|
|
|
2017-09-15 06:29:10 +02:00
|
|
|
typedef struct {
|
2017-09-23 10:27:50 +02:00
|
|
|
EFI_ACPI_DMAR_HEADER *AcpiDmarTable;
|
|
|
|
UINT64 EngineMask;
|
2017-09-15 06:29:10 +02:00
|
|
|
UINT8 HostAddressWidth;
|
|
|
|
UINTN VTdEngineCount;
|
|
|
|
UINT64 VTdEngineAddress[1];
|
|
|
|
} VTD_INFO;
|
|
|
|
|
2017-09-01 10:30:46 +02:00
|
|
|
/**
|
|
|
|
Set DMA protected region.
|
|
|
|
|
2017-09-23 10:27:50 +02:00
|
|
|
@param VTdInfo The VTd engine context information.
|
2017-09-15 06:29:10 +02:00
|
|
|
@param EngineMask The mask of the VTd engine to be accessed.
|
2017-09-01 10:30:46 +02:00
|
|
|
@param LowMemoryBase The protected low memory region base.
|
|
|
|
@param LowMemoryLength The protected low memory region length.
|
|
|
|
@param HighMemoryBase The protected high memory region base.
|
|
|
|
@param HighMemoryLength The protected high memory region length.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS The DMA protection is set.
|
|
|
|
@retval EFI_UNSUPPORTED The DMA protection is not set.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
SetDmaProtectedRange (
|
2017-09-23 10:27:50 +02:00
|
|
|
IN VTD_INFO *VTdInfo,
|
2017-09-15 06:29:10 +02:00
|
|
|
IN UINT64 EngineMask,
|
2017-09-01 10:30:46 +02:00
|
|
|
IN UINT32 LowMemoryBase,
|
|
|
|
IN UINT32 LowMemoryLength,
|
|
|
|
IN UINT64 HighMemoryBase,
|
|
|
|
IN UINT64 HighMemoryLength
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Diable DMA protection.
|
|
|
|
|
2017-09-23 10:27:50 +02:00
|
|
|
@param VTdInfo The VTd engine context information.
|
2017-09-15 06:29:10 +02:00
|
|
|
@param EngineMask The mask of the VTd engine to be accessed.
|
|
|
|
|
2017-09-01 10:30:46 +02:00
|
|
|
@retval DMA protection is disabled.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
DisableDmaProtection (
|
2017-09-23 10:27:50 +02:00
|
|
|
IN VTD_INFO *VTdInfo,
|
|
|
|
IN UINT64 EngineMask
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Return if the DMA protection is enabled.
|
|
|
|
|
|
|
|
@param VTdInfo The VTd engine context information.
|
|
|
|
@param EngineMask The mask of the VTd engine to be accessed.
|
|
|
|
|
|
|
|
@retval TRUE DMA protection is enabled in at least one VTd engine.
|
|
|
|
@retval FALSE DMA protection is disabled in all VTd engines.
|
|
|
|
**/
|
|
|
|
UINT64
|
|
|
|
GetDmaProtectionEnabledEngineMask (
|
|
|
|
IN VTD_INFO *VTdInfo,
|
2017-09-15 06:29:10 +02:00
|
|
|
IN UINT64 EngineMask
|
2017-09-01 10:30:46 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Get protected low memory alignment.
|
|
|
|
|
2017-09-23 10:27:50 +02:00
|
|
|
@param VTdInfo The VTd engine context information.
|
2017-09-15 06:29:10 +02:00
|
|
|
@param EngineMask The mask of the VTd engine to be accessed.
|
|
|
|
|
2017-09-01 10:30:46 +02:00
|
|
|
@return protected low memory alignment.
|
|
|
|
**/
|
|
|
|
UINT32
|
|
|
|
GetLowMemoryAlignment (
|
2017-09-23 10:27:50 +02:00
|
|
|
IN VTD_INFO *VTdInfo,
|
2017-09-15 06:29:10 +02:00
|
|
|
IN UINT64 EngineMask
|
2017-09-01 10:30:46 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Get protected high memory alignment.
|
|
|
|
|
2017-09-23 10:27:50 +02:00
|
|
|
@param VTdInfo The VTd engine context information.
|
2017-09-15 06:29:10 +02:00
|
|
|
@param EngineMask The mask of the VTd engine to be accessed.
|
|
|
|
|
2017-09-01 10:30:46 +02:00
|
|
|
@return protected high memory alignment.
|
|
|
|
**/
|
|
|
|
UINT64
|
|
|
|
GetHighMemoryAlignment (
|
2017-09-23 10:27:50 +02:00
|
|
|
IN VTD_INFO *VTdInfo,
|
|
|
|
IN UINT64 EngineMask
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Enable VTd translation table protection.
|
|
|
|
|
|
|
|
@param VTdInfo The VTd engine context information.
|
|
|
|
@param EngineMask The mask of the VTd engine to be accessed.
|
|
|
|
**/
|
|
|
|
VOID
|
|
|
|
EnableVTdTranslationProtection (
|
|
|
|
IN VTD_INFO *VTdInfo,
|
|
|
|
IN UINT64 EngineMask
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Disable VTd translation table protection.
|
|
|
|
|
|
|
|
@param VTdInfo The VTd engine context information.
|
|
|
|
@param EngineMask The mask of the VTd engine to be accessed.
|
|
|
|
**/
|
|
|
|
VOID
|
|
|
|
DisableVTdTranslationProtection (
|
|
|
|
IN VTD_INFO *VTdInfo,
|
2017-09-15 06:29:10 +02:00
|
|
|
IN UINT64 EngineMask
|
2017-09-01 10:30:46 +02:00
|
|
|
);
|
|
|
|
|
2017-09-23 10:27:50 +02:00
|
|
|
/**
|
|
|
|
Parse DMAR DRHD table.
|
|
|
|
|
|
|
|
@param[in] AcpiDmarTable DMAR ACPI table
|
|
|
|
|
|
|
|
@return EFI_SUCCESS The DMAR DRHD table is parsed.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
ParseDmarAcpiTableDrhd (
|
|
|
|
IN EFI_ACPI_DMAR_HEADER *AcpiDmarTable
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Parse DMAR DRHD table.
|
|
|
|
|
|
|
|
@param VTdInfo The VTd engine context information.
|
|
|
|
**/
|
|
|
|
VOID
|
|
|
|
ParseDmarAcpiTableRmrr (
|
|
|
|
IN VTD_INFO *VTdInfo
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Dump DMAR ACPI table.
|
|
|
|
|
|
|
|
@param[in] Dmar DMAR ACPI table
|
|
|
|
**/
|
|
|
|
VOID
|
|
|
|
DumpAcpiDMAR (
|
|
|
|
IN EFI_ACPI_DMAR_HEADER *Dmar
|
|
|
|
);
|
|
|
|
|
|
|
|
extern EFI_GUID mVTdInfoGuid;
|
|
|
|
|
2017-09-01 10:30:46 +02:00
|
|
|
#endif
|
|
|
|
|