CorebootModulePkg: Fix memmap issue
Some reserved memory (e.g. CSE reserved memory) might be in the middle of usable physical memory. The current memory map caculation could not handle this case. This patch fixed this issue. Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: gdong1 <guo.dong@intel.com> Reviewed-by: Maurice Ma <maurice.ma@intel.com>
This commit is contained in:
@ -140,6 +140,72 @@ CbPeiReportRemainedFvs (
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
Based on memory base, size and type, build resource descripter HOB.
|
||||
|
||||
@param Base Memory base address.
|
||||
@param Size Memory size.
|
||||
@param Type Memory type.
|
||||
@param Param A pointer to CB_MEM_INFO.
|
||||
|
||||
@retval EFI_SUCCESS if it completed successfully.
|
||||
**/
|
||||
EFI_STATUS
|
||||
CbMemInfoCallback (
|
||||
UINT64 Base,
|
||||
UINT64 Size,
|
||||
UINT32 Type,
|
||||
VOID *Param
|
||||
)
|
||||
{
|
||||
CB_MEM_INFO *MemInfo;
|
||||
UINTN Attribue;
|
||||
|
||||
Attribue = EFI_RESOURCE_ATTRIBUTE_PRESENT |
|
||||
EFI_RESOURCE_ATTRIBUTE_INITIALIZED |
|
||||
EFI_RESOURCE_ATTRIBUTE_TESTED |
|
||||
EFI_RESOURCE_ATTRIBUTE_UNCACHEABLE |
|
||||
EFI_RESOURCE_ATTRIBUTE_WRITE_COMBINEABLE |
|
||||
EFI_RESOURCE_ATTRIBUTE_WRITE_THROUGH_CACHEABLE |
|
||||
EFI_RESOURCE_ATTRIBUTE_WRITE_BACK_CACHEABLE;
|
||||
|
||||
MemInfo = (CB_MEM_INFO *)Param;
|
||||
if (Base >= 0x100000) {
|
||||
if (Type == CB_MEM_RAM) {
|
||||
if (Base < 0x100000000ULL) {
|
||||
MemInfo->UsableLowMemTop = (UINT32)(Base + Size);
|
||||
} else {
|
||||
Attribue &= ~EFI_RESOURCE_ATTRIBUTE_TESTED;
|
||||
}
|
||||
BuildResourceDescriptorHob (
|
||||
EFI_RESOURCE_SYSTEM_MEMORY,
|
||||
Attribue,
|
||||
(EFI_PHYSICAL_ADDRESS)Base,
|
||||
Size
|
||||
);
|
||||
} else if (Type == CB_MEM_TABLE) {
|
||||
BuildResourceDescriptorHob (
|
||||
EFI_RESOURCE_MEMORY_RESERVED,
|
||||
Attribue,
|
||||
(EFI_PHYSICAL_ADDRESS)Base,
|
||||
Size
|
||||
);
|
||||
MemInfo->SystemLowMemTop = ((UINT32)(Base + Size) + 0x0FFFFFFF) & 0xF0000000;
|
||||
} else if (Type == CB_MEM_RESERVED) {
|
||||
if ((MemInfo->SystemLowMemTop == 0) || (Base < MemInfo->SystemLowMemTop)) {
|
||||
BuildResourceDescriptorHob (
|
||||
EFI_RESOURCE_MEMORY_RESERVED,
|
||||
Attribue,
|
||||
(EFI_PHYSICAL_ADDRESS)Base,
|
||||
Size
|
||||
);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return EFI_SUCCESS;
|
||||
}
|
||||
|
||||
/**
|
||||
This is the entrypoint of PEIM
|
||||
|
||||
@ -156,7 +222,7 @@ CbPeiEntryPoint (
|
||||
)
|
||||
{
|
||||
EFI_STATUS Status;
|
||||
UINT64 LowMemorySize, HighMemorySize;
|
||||
UINT64 LowMemorySize;
|
||||
UINT64 PeiMemSize = SIZE_64MB; // 64 MB
|
||||
EFI_PHYSICAL_ADDRESS PeiMemBase = 0;
|
||||
UINT32 RegEax;
|
||||
@ -173,18 +239,7 @@ CbPeiEntryPoint (
|
||||
UINTN PmCtrlRegBase, PmTimerRegBase, ResetRegAddress, ResetValue;
|
||||
UINTN PmEvtBase;
|
||||
UINTN PmGpeEnBase;
|
||||
|
||||
LowMemorySize = 0;
|
||||
HighMemorySize = 0;
|
||||
|
||||
Status = CbParseMemoryInfo (&LowMemorySize, &HighMemorySize);
|
||||
if (EFI_ERROR(Status))
|
||||
return Status;
|
||||
|
||||
DEBUG((EFI_D_ERROR, "LowMemorySize: 0x%lx.\n", LowMemorySize));
|
||||
DEBUG((EFI_D_ERROR, "HighMemorySize: 0x%lx.\n", HighMemorySize));
|
||||
|
||||
ASSERT (LowMemorySize > 0);
|
||||
CB_MEM_INFO CbMemInfo;
|
||||
|
||||
//
|
||||
// Report lower 640KB of RAM. Attribute EFI_RESOURCE_ATTRIBUTE_TESTED
|
||||
@ -221,37 +276,16 @@ CbPeiEntryPoint (
|
||||
(UINT64)(0x60000)
|
||||
);
|
||||
|
||||
BuildResourceDescriptorHob (
|
||||
EFI_RESOURCE_SYSTEM_MEMORY,
|
||||
(
|
||||
EFI_RESOURCE_ATTRIBUTE_PRESENT |
|
||||
EFI_RESOURCE_ATTRIBUTE_INITIALIZED |
|
||||
EFI_RESOURCE_ATTRIBUTE_TESTED |
|
||||
EFI_RESOURCE_ATTRIBUTE_UNCACHEABLE |
|
||||
EFI_RESOURCE_ATTRIBUTE_WRITE_COMBINEABLE |
|
||||
EFI_RESOURCE_ATTRIBUTE_WRITE_THROUGH_CACHEABLE |
|
||||
EFI_RESOURCE_ATTRIBUTE_WRITE_BACK_CACHEABLE
|
||||
),
|
||||
(EFI_PHYSICAL_ADDRESS)(0x100000),
|
||||
(UINT64) (LowMemorySize - 0x100000)
|
||||
);
|
||||
|
||||
if (HighMemorySize > 0) {
|
||||
BuildResourceDescriptorHob (
|
||||
EFI_RESOURCE_SYSTEM_MEMORY,
|
||||
(
|
||||
EFI_RESOURCE_ATTRIBUTE_PRESENT |
|
||||
EFI_RESOURCE_ATTRIBUTE_INITIALIZED |
|
||||
EFI_RESOURCE_ATTRIBUTE_UNCACHEABLE |
|
||||
EFI_RESOURCE_ATTRIBUTE_WRITE_COMBINEABLE |
|
||||
EFI_RESOURCE_ATTRIBUTE_WRITE_THROUGH_CACHEABLE |
|
||||
EFI_RESOURCE_ATTRIBUTE_WRITE_BACK_CACHEABLE
|
||||
),
|
||||
(EFI_PHYSICAL_ADDRESS)(0x100000000ULL),
|
||||
HighMemorySize
|
||||
);
|
||||
ZeroMem (&CbMemInfo, sizeof(CbMemInfo));
|
||||
Status = CbParseMemoryInfo (CbMemInfoCallback, (VOID *)&CbMemInfo);
|
||||
if (EFI_ERROR(Status)) {
|
||||
return Status;
|
||||
}
|
||||
|
||||
LowMemorySize = CbMemInfo.UsableLowMemTop;
|
||||
DEBUG ((EFI_D_INFO, "Low memory 0x%lx\n", LowMemorySize));
|
||||
DEBUG ((EFI_D_INFO, "SystemLowMemTop 0x%x\n", CbMemInfo.SystemLowMemTop));
|
||||
|
||||
//
|
||||
// Should be 64k aligned
|
||||
//
|
||||
|
@ -38,5 +38,11 @@ WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
|
||||
#include <Guid/AcpiBoardInfoGuid.h>
|
||||
|
||||
#include <Ppi/MasterBootMode.h>
|
||||
#include "Coreboot.h"
|
||||
|
||||
typedef struct {
|
||||
UINT32 UsableLowMemTop;
|
||||
UINT32 SystemLowMemTop;
|
||||
} CB_MEM_INFO;
|
||||
|
||||
#endif
|
||||
|
@ -14,21 +14,23 @@
|
||||
**/
|
||||
#include <Guid/FrameBufferInfoGuid.h>
|
||||
|
||||
typedef RETURN_STATUS \
|
||||
(*CB_MEM_INFO_CALLBACK) (UINT64 Base, UINT64 Size, UINT32 Type, VOID *Param);
|
||||
|
||||
/**
|
||||
Acquire the memory information from the coreboot table in memory.
|
||||
|
||||
@param pLowMemorySize Pointer to the variable of low memory size
|
||||
@param pHighMemorySize Pointer to the variable of high memory size
|
||||
@param MemInfoCallback The callback routine
|
||||
@param pParam Pointer to the callback routine parameter
|
||||
|
||||
@retval RETURN_SUCCESS Successfully find out the memory information.
|
||||
@retval RETURN_INVALID_PARAMETER Invalid input parameters.
|
||||
@retval RETURN_NOT_FOUND Failed to find the memory information.
|
||||
|
||||
**/
|
||||
RETURN_STATUS
|
||||
CbParseMemoryInfo (
|
||||
IN UINT64* pLowMemorySize,
|
||||
IN UINT64* pHighMemorySize
|
||||
IN CB_MEM_INFO_CALLBACK MemInfoCallback,
|
||||
IN VOID *pParam
|
||||
);
|
||||
|
||||
/**
|
||||
|
@ -2,7 +2,7 @@
|
||||
This library will parse the coreboot table in memory and extract those required
|
||||
information.
|
||||
|
||||
Copyright (c) 2014 - 2015, Intel Corporation. All rights reserved.<BR>
|
||||
Copyright (c) 2014 - 2016, Intel Corporation. All rights reserved.<BR>
|
||||
This program and the accompanying materials
|
||||
are licensed and made available under the terms and conditions of the BSD License
|
||||
which accompanies this distribution. The full text of the license may be found at
|
||||
@ -229,18 +229,17 @@ FindCbMemTable (
|
||||
/**
|
||||
Acquire the memory information from the coreboot table in memory.
|
||||
|
||||
@param pLowMemorySize Pointer to the variable of low memory size
|
||||
@param pHighMemorySize Pointer to the variable of high memory size
|
||||
@param MemInfoCallback The callback routine
|
||||
@param pParam Pointer to the callback routine parameter
|
||||
|
||||
@retval RETURN_SUCCESS Successfully find out the memory information.
|
||||
@retval RETURN_INVALID_PARAMETER Invalid input parameters.
|
||||
@retval RETURN_NOT_FOUND Failed to find the memory information.
|
||||
|
||||
**/
|
||||
RETURN_STATUS
|
||||
CbParseMemoryInfo (
|
||||
OUT UINT64 *pLowMemorySize,
|
||||
OUT UINT64 *pHighMemorySize
|
||||
IN CB_MEM_INFO_CALLBACK MemInfoCallback,
|
||||
IN VOID *pParam
|
||||
)
|
||||
{
|
||||
struct cb_memory *rec;
|
||||
@ -249,10 +248,6 @@ CbParseMemoryInfo (
|
||||
UINT64 Size;
|
||||
UINTN Index;
|
||||
|
||||
if ((pLowMemorySize == NULL) || (pHighMemorySize == NULL)) {
|
||||
return RETURN_INVALID_PARAMETER;
|
||||
}
|
||||
|
||||
//
|
||||
// Get the coreboot memory table
|
||||
//
|
||||
@ -265,9 +260,6 @@ CbParseMemoryInfo (
|
||||
return RETURN_NOT_FOUND;
|
||||
}
|
||||
|
||||
*pLowMemorySize = 0;
|
||||
*pHighMemorySize = 0;
|
||||
|
||||
for (Index = 0; Index < MEM_RANGE_COUNT(rec); Index++) {
|
||||
Range = MEM_RANGE_PTR(rec, Index);
|
||||
Start = cb_unpack64(Range->start);
|
||||
@ -275,19 +267,9 @@ CbParseMemoryInfo (
|
||||
DEBUG ((EFI_D_INFO, "%d. %016lx - %016lx [%02x]\n",
|
||||
Index, Start, Start + Size - 1, Range->type));
|
||||
|
||||
if (Range->type != CB_MEM_RAM) {
|
||||
continue;
|
||||
MemInfoCallback (Start, Size, Range->type, pParam);
|
||||
}
|
||||
|
||||
if (Start + Size < 0x100000000ULL) {
|
||||
*pLowMemorySize = Start + Size;
|
||||
} else {
|
||||
*pHighMemorySize = Start + Size - 0x100000000ULL;
|
||||
}
|
||||
}
|
||||
|
||||
DEBUG ((EFI_D_INFO, "Low memory 0x%lx, High Memory 0x%lx\n", *pLowMemorySize, *pHighMemorySize));
|
||||
|
||||
return RETURN_SUCCESS;
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user