mirror of https://github.com/acidanthera/audk.git
IntelSiliconPkg/VTdInfoSample: Add RMRR table.
Let system report RMRR table for the platform support PEI graphic. Cc: Star Zeng <star.zeng@intel.com> Contributed-under: TianoCore Contribution Agreement 1.1 Signed-off-by: Jiewen Yao <jiewen.yao@intel.com> Reviewed-by: Star Zeng <star.zeng@intel.com>
This commit is contained in:
parent
8e9da4ba3c
commit
70dc3ec5a7
|
@ -18,21 +18,111 @@
|
||||||
|
|
||||||
#include <Library/PeiServicesLib.h>
|
#include <Library/PeiServicesLib.h>
|
||||||
#include <Library/DebugLib.h>
|
#include <Library/DebugLib.h>
|
||||||
|
#include <Library/PciLib.h>
|
||||||
|
#include <Library/IoLib.h>
|
||||||
|
|
||||||
|
#define R_SA_MCHBAR (0x48)
|
||||||
|
#define R_SA_GGC (0x50)
|
||||||
|
#define N_SKL_SA_GGC_GGMS_OFFSET (0x6)
|
||||||
|
#define B_SKL_SA_GGC_GGMS_MASK (0xc0)
|
||||||
|
#define N_SKL_SA_GGC_GMS_OFFSET (0x8)
|
||||||
|
#define B_SKL_SA_GGC_GMS_MASK (0xff00)
|
||||||
|
#define V_SKL_SA_GGC_GGMS_8MB 3
|
||||||
|
#define R_SA_TOLUD (0xbc)
|
||||||
|
|
||||||
|
#define R_SA_MCHBAR_VTD1_OFFSET 0x5400 ///< HW UNIT for IGD
|
||||||
|
#define R_SA_MCHBAR_VTD2_OFFSET 0x5410 ///< HW UNIT for all other - PEG, USB, SATA etc
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
UINT64 Revision;
|
EFI_ACPI_DMAR_HEADER DmarHeader;
|
||||||
UINT8 HostAddressWidth;
|
//
|
||||||
UINT8 Reserved[3];
|
// VTd engine 1 - integrated graphic
|
||||||
UINT32 VTdEngineCount;
|
//
|
||||||
UINT64 VTdEngineAddress[2];
|
EFI_ACPI_DMAR_DRHD_HEADER Drhd1;
|
||||||
|
EFI_ACPI_DMAR_DEVICE_SCOPE_STRUCTURE_HEADER Drhd11;
|
||||||
|
EFI_ACPI_DMAR_PCI_PATH Drhd111;
|
||||||
|
//
|
||||||
|
// VTd engine 2 - all rest
|
||||||
|
//
|
||||||
|
EFI_ACPI_DMAR_DRHD_HEADER Drhd2;
|
||||||
|
//
|
||||||
|
// RMRR 1 - integrated graphic
|
||||||
|
//
|
||||||
|
EFI_ACPI_DMAR_RMRR_HEADER Rmrr1;
|
||||||
|
EFI_ACPI_DMAR_DEVICE_SCOPE_STRUCTURE_HEADER Rmrr11;
|
||||||
|
EFI_ACPI_DMAR_PCI_PATH Rmrr111;
|
||||||
} MY_VTD_INFO_PPI;
|
} MY_VTD_INFO_PPI;
|
||||||
|
|
||||||
MY_VTD_INFO_PPI mPlatformVTdSample = {
|
MY_VTD_INFO_PPI mPlatformVTdSample = {
|
||||||
EDKII_VTD_INFO_PPI_REVISION,
|
{ // DmarHeader
|
||||||
0x26,
|
{ // Header
|
||||||
{0},
|
EFI_ACPI_4_0_DMA_REMAPPING_TABLE_SIGNATURE,
|
||||||
2,
|
sizeof(MY_VTD_INFO_PPI),
|
||||||
{0xFED90000, 0xFED91000},
|
EFI_ACPI_DMAR_REVISION,
|
||||||
|
},
|
||||||
|
0x26, // HostAddressWidth
|
||||||
|
},
|
||||||
|
|
||||||
|
{ // Drhd1
|
||||||
|
{ // Header
|
||||||
|
EFI_ACPI_DMAR_TYPE_DRHD,
|
||||||
|
sizeof(EFI_ACPI_DMAR_DRHD_HEADER) +
|
||||||
|
sizeof(EFI_ACPI_DMAR_DEVICE_SCOPE_STRUCTURE_HEADER) +
|
||||||
|
sizeof(EFI_ACPI_DMAR_PCI_PATH)
|
||||||
|
},
|
||||||
|
0, // Flags
|
||||||
|
0, // Reserved
|
||||||
|
0, // SegmentNumber
|
||||||
|
0xFED90000 // RegisterBaseAddress -- TO BE PATCHED
|
||||||
|
},
|
||||||
|
{ // Drhd11
|
||||||
|
EFI_ACPI_DEVICE_SCOPE_ENTRY_TYPE_PCI_ENDPOINT,
|
||||||
|
sizeof(EFI_ACPI_DMAR_DEVICE_SCOPE_STRUCTURE_HEADER) +
|
||||||
|
sizeof(EFI_ACPI_DMAR_PCI_PATH),
|
||||||
|
0, // Reserved2
|
||||||
|
0, // EnumerationId
|
||||||
|
0 // StartBusNumber
|
||||||
|
},
|
||||||
|
{ // Drhd111
|
||||||
|
2, // Device
|
||||||
|
0 // Function
|
||||||
|
},
|
||||||
|
|
||||||
|
{ // Drhd2
|
||||||
|
{ // Header
|
||||||
|
EFI_ACPI_DMAR_TYPE_DRHD,
|
||||||
|
sizeof(EFI_ACPI_DMAR_DRHD_HEADER)
|
||||||
|
},
|
||||||
|
EFI_ACPI_DMAR_DRHD_FLAGS_INCLUDE_PCI_ALL, // Flags
|
||||||
|
0, // Reserved
|
||||||
|
0, // SegmentNumber
|
||||||
|
0xFED91000 // RegisterBaseAddress -- TO BE PATCHED
|
||||||
|
},
|
||||||
|
|
||||||
|
{ // Rmrr1
|
||||||
|
{ // Header
|
||||||
|
EFI_ACPI_DMAR_TYPE_RMRR,
|
||||||
|
sizeof(EFI_ACPI_DMAR_RMRR_HEADER) +
|
||||||
|
sizeof(EFI_ACPI_DMAR_DEVICE_SCOPE_STRUCTURE_HEADER) +
|
||||||
|
sizeof(EFI_ACPI_DMAR_PCI_PATH)
|
||||||
|
},
|
||||||
|
{0}, // Reserved
|
||||||
|
0, // SegmentNumber
|
||||||
|
0x0, // ReservedMemoryRegionBaseAddress -- TO BE PATCHED
|
||||||
|
0x0 // ReservedMemoryRegionLimitAddress -- TO BE PATCHED
|
||||||
|
},
|
||||||
|
{ // Rmrr11
|
||||||
|
EFI_ACPI_DEVICE_SCOPE_ENTRY_TYPE_PCI_ENDPOINT,
|
||||||
|
sizeof(EFI_ACPI_DMAR_DEVICE_SCOPE_STRUCTURE_HEADER) +
|
||||||
|
sizeof(EFI_ACPI_DMAR_PCI_PATH),
|
||||||
|
0, // Reserved2
|
||||||
|
0, // EnumerationId
|
||||||
|
0 // StartBusNumber
|
||||||
|
},
|
||||||
|
{ // Rmrr111
|
||||||
|
2, // Device
|
||||||
|
0 // Function
|
||||||
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
EFI_PEI_PPI_DESCRIPTOR mPlatformVTdInfoSampleDesc = {
|
EFI_PEI_PPI_DESCRIPTOR mPlatformVTdInfoSampleDesc = {
|
||||||
|
@ -41,6 +131,50 @@ EFI_PEI_PPI_DESCRIPTOR mPlatformVTdInfoSampleDesc = {
|
||||||
&mPlatformVTdSample
|
&mPlatformVTdSample
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
Patch Graphic UMA address in RMRR and base address.
|
||||||
|
**/
|
||||||
|
VOID
|
||||||
|
PatchDmar (
|
||||||
|
VOID
|
||||||
|
)
|
||||||
|
{
|
||||||
|
UINT32 MchBar;
|
||||||
|
UINT16 IgdMode;
|
||||||
|
UINT16 GttMode;
|
||||||
|
UINT32 IgdMemSize;
|
||||||
|
UINT32 GttMemSize;
|
||||||
|
|
||||||
|
///
|
||||||
|
/// Calculate IGD memsize
|
||||||
|
///
|
||||||
|
IgdMode = ((PciRead16 (PCI_LIB_ADDRESS(0, 0, 0, R_SA_GGC)) & B_SKL_SA_GGC_GMS_MASK) >> N_SKL_SA_GGC_GMS_OFFSET) & 0xFF;
|
||||||
|
if (IgdMode < 0xF0) {
|
||||||
|
IgdMemSize = IgdMode * 32 * (1024) * (1024);
|
||||||
|
} else {
|
||||||
|
IgdMemSize = 4 * (IgdMode - 0xF0 + 1) * (1024) * (1024);
|
||||||
|
}
|
||||||
|
|
||||||
|
///
|
||||||
|
/// Calculate GTT mem size
|
||||||
|
///
|
||||||
|
GttMemSize = 0;
|
||||||
|
GttMode = PciRead16 (PCI_LIB_ADDRESS(0, 0, 0, R_SA_GGC) & B_SKL_SA_GGC_GGMS_MASK) >> N_SKL_SA_GGC_GGMS_OFFSET;
|
||||||
|
if (GttMode <= V_SKL_SA_GGC_GGMS_8MB) {
|
||||||
|
GttMemSize = (1 << GttMode) * (1024) * (1024);
|
||||||
|
}
|
||||||
|
|
||||||
|
mPlatformVTdSample.Rmrr1.ReservedMemoryRegionBaseAddress = (PciRead32 (PCI_LIB_ADDRESS(0, 0, 0, R_SA_TOLUD)) & ~(0x01)) - IgdMemSize - GttMemSize;
|
||||||
|
mPlatformVTdSample.Rmrr1.ReservedMemoryRegionLimitAddress = mPlatformVTdSample.Rmrr1.ReservedMemoryRegionBaseAddress + IgdMemSize + GttMemSize - 1;
|
||||||
|
|
||||||
|
///
|
||||||
|
/// Update DRHD structures of DmarTable
|
||||||
|
///
|
||||||
|
MchBar = PciRead32 (PCI_LIB_ADDRESS(0, 0, 0, R_SA_MCHBAR)) & ~BIT0;
|
||||||
|
mPlatformVTdSample.Drhd1.RegisterBaseAddress = (MmioRead32 (MchBar + R_SA_MCHBAR_VTD1_OFFSET) &~1);
|
||||||
|
mPlatformVTdSample.Drhd2.RegisterBaseAddress = (MmioRead32 (MchBar + R_SA_MCHBAR_VTD2_OFFSET) &~1);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Platform VTd Info sample driver.
|
Platform VTd Info sample driver.
|
||||||
|
|
||||||
|
@ -58,6 +192,8 @@ PlatformVTdInfoSampleInitialize (
|
||||||
{
|
{
|
||||||
EFI_STATUS Status;
|
EFI_STATUS Status;
|
||||||
|
|
||||||
|
PatchDmar ();
|
||||||
|
|
||||||
Status = PeiServicesInstallPpi (&mPlatformVTdInfoSampleDesc);
|
Status = PeiServicesInstallPpi (&mPlatformVTdInfoSampleDesc);
|
||||||
ASSERT_EFI_ERROR (Status);
|
ASSERT_EFI_ERROR (Status);
|
||||||
|
|
||||||
|
|
|
@ -39,6 +39,9 @@
|
||||||
[LibraryClasses]
|
[LibraryClasses]
|
||||||
PeimEntryPoint
|
PeimEntryPoint
|
||||||
PeiServicesLib
|
PeiServicesLib
|
||||||
|
DebugLib
|
||||||
|
PciLib
|
||||||
|
IoLib
|
||||||
|
|
||||||
[Ppis]
|
[Ppis]
|
||||||
gEdkiiVTdInfoPpiGuid ## PRODUCES
|
gEdkiiVTdInfoPpiGuid ## PRODUCES
|
||||||
|
|
Loading…
Reference in New Issue