2023-03-01 07:09:52 +01:00
|
|
|
/** @file
|
|
|
|
Function to create page talbe.
|
|
|
|
Only create page table for x64, and leave the CreatePageTable empty for Ia32.
|
|
|
|
Copyright (c) 2023, Intel Corporation. All rights reserved.<BR>
|
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
|
|
|
**/
|
|
|
|
#include <Library/CpuPageTableLib.h>
|
|
|
|
#include <Library/MemoryAllocationLib.h>
|
|
|
|
#include <Base.h>
|
|
|
|
#include <Library/BaseMemoryLib.h>
|
|
|
|
#include <Library/DebugLib.h>
|
|
|
|
#include <Library/BaseLib.h>
|
|
|
|
|
|
|
|
/**
|
|
|
|
Create 1:1 mapping page table in reserved memory to map the specified address range.
|
|
|
|
@param[in] LinearAddress The start of the linear address range.
|
|
|
|
@param[in] Length The length of the linear address range.
|
|
|
|
@return The page table to be created.
|
|
|
|
**/
|
|
|
|
UINTN
|
|
|
|
CreatePageTable (
|
|
|
|
IN UINTN Address,
|
|
|
|
IN UINTN Length
|
|
|
|
)
|
|
|
|
{
|
|
|
|
EFI_STATUS Status;
|
|
|
|
VOID *PageTableBuffer;
|
|
|
|
UINTN PageTableBufferSize;
|
|
|
|
UINTN PageTable;
|
|
|
|
PAGING_MODE PagingMode;
|
|
|
|
IA32_CR4 Cr4;
|
|
|
|
|
|
|
|
IA32_MAP_ATTRIBUTE MapAttribute;
|
|
|
|
IA32_MAP_ATTRIBUTE MapMask;
|
|
|
|
|
|
|
|
MapAttribute.Uint64 = Address;
|
|
|
|
MapAttribute.Bits.Present = 1;
|
|
|
|
MapAttribute.Bits.ReadWrite = 1;
|
2023-03-17 08:43:26 +01:00
|
|
|
MapMask.Uint64 = MAX_UINT64;
|
2023-03-01 07:09:52 +01:00
|
|
|
|
|
|
|
PageTable = 0;
|
|
|
|
PageTableBufferSize = 0;
|
|
|
|
|
|
|
|
Cr4.UintN = AsmReadCr4 ();
|
|
|
|
|
|
|
|
if (Cr4.Bits.LA57 == 1) {
|
|
|
|
PagingMode = Paging5Level;
|
|
|
|
} else {
|
|
|
|
PagingMode = Paging4Level;
|
|
|
|
}
|
|
|
|
|
|
|
|
Status = PageTableMap (
|
|
|
|
&PageTable,
|
|
|
|
PagingMode,
|
|
|
|
NULL,
|
|
|
|
&PageTableBufferSize,
|
|
|
|
Address,
|
|
|
|
Length,
|
|
|
|
&MapAttribute,
|
2022-12-09 03:36:37 +01:00
|
|
|
&MapMask,
|
|
|
|
NULL
|
2023-03-01 07:09:52 +01:00
|
|
|
);
|
|
|
|
ASSERT (Status == EFI_BUFFER_TOO_SMALL);
|
|
|
|
DEBUG ((DEBUG_INFO, "AP Page Table Buffer Size = %x\n", PageTableBufferSize));
|
|
|
|
|
|
|
|
PageTableBuffer = AllocateReservedPages (EFI_SIZE_TO_PAGES (PageTableBufferSize));
|
|
|
|
ASSERT (PageTableBuffer != NULL);
|
|
|
|
Status = PageTableMap (
|
|
|
|
&PageTable,
|
|
|
|
PagingMode,
|
|
|
|
PageTableBuffer,
|
|
|
|
&PageTableBufferSize,
|
|
|
|
Address,
|
|
|
|
Length,
|
|
|
|
&MapAttribute,
|
2022-12-09 03:36:37 +01:00
|
|
|
&MapMask,
|
|
|
|
NULL
|
2023-03-01 07:09:52 +01:00
|
|
|
);
|
|
|
|
ASSERT_EFI_ERROR (Status);
|
|
|
|
return PageTable;
|
|
|
|
}
|