ShellPkg: Update shell command memmap to show unaccepted memory
RFC: https://bugzilla.tianocore.org/show_bug.cgi?id=3937 ShellCommandRunMemMap() is updated to handle the case of unaccepted memory type. Cc: Ray Ni <ray.ni@intel.com> Cc: Zhichao Gao <zhichao.gao@intel.com> Cc: Erdem Aktas <erdemaktas@google.com> Cc: Gerd Hoffmann <kraxel@redhat.com> Cc: James Bottomley <jejb@linux.ibm.com> Cc: Jiewen Yao <jiewen.yao@intel.com> Cc: Tom Lendacky <thomas.lendacky@amd.com> Acked-by: Gerd Hoffmann <kraxel@redhat.com> Acked-by: Zhichao Gao <zhichao.gao@intel.com> Signed-off-by: Min Xu <min.m.xu@intel.com>
This commit is contained in:
parent
43e306806e
commit
6ca9f410d1
|
@ -26,6 +26,7 @@ STATIC CONST CHAR16 NameEfiACPIMemoryNVS[] = L"ACPIMemoryNVS";
|
||||||
STATIC CONST CHAR16 NameEfiMemoryMappedIO[] = L"MemoryMappedIO";
|
STATIC CONST CHAR16 NameEfiMemoryMappedIO[] = L"MemoryMappedIO";
|
||||||
STATIC CONST CHAR16 NameEfiMemoryMappedIOPortSpace[] = L"MemoryMappedIOPortSpace";
|
STATIC CONST CHAR16 NameEfiMemoryMappedIOPortSpace[] = L"MemoryMappedIOPortSpace";
|
||||||
STATIC CONST CHAR16 NameEfiPalCode[] = L"PalCode";
|
STATIC CONST CHAR16 NameEfiPalCode[] = L"PalCode";
|
||||||
|
STATIC CONST CHAR16 NameEfiUnacceptedMemoryType[] = L"Unaccepted";
|
||||||
|
|
||||||
//
|
//
|
||||||
// Need short names for some memory types
|
// Need short names for some memory types
|
||||||
|
@ -151,6 +152,8 @@ ShellCommandRunMemMap (
|
||||||
UINT64 UnusableMemoryPagesSize;
|
UINT64 UnusableMemoryPagesSize;
|
||||||
UINT64 PalCodePages;
|
UINT64 PalCodePages;
|
||||||
UINT64 PalCodePagesSize;
|
UINT64 PalCodePagesSize;
|
||||||
|
UINT64 UnacceptedPages;
|
||||||
|
UINT64 UnacceptedPagesSize;
|
||||||
UINT64 PersistentPages;
|
UINT64 PersistentPages;
|
||||||
UINT64 PersistentPagesSize;
|
UINT64 PersistentPagesSize;
|
||||||
BOOLEAN Sfo;
|
BOOLEAN Sfo;
|
||||||
|
@ -175,6 +178,7 @@ ShellCommandRunMemMap (
|
||||||
PalCodePages = 0;
|
PalCodePages = 0;
|
||||||
PersistentPages = 0;
|
PersistentPages = 0;
|
||||||
Size = 0;
|
Size = 0;
|
||||||
|
UnacceptedPages = 0;
|
||||||
Descriptors = NULL;
|
Descriptors = NULL;
|
||||||
ShellStatus = SHELL_SUCCESS;
|
ShellStatus = SHELL_SUCCESS;
|
||||||
Status = EFI_SUCCESS;
|
Status = EFI_SUCCESS;
|
||||||
|
@ -303,6 +307,11 @@ ShellCommandRunMemMap (
|
||||||
TotalPages += Walker->NumberOfPages;
|
TotalPages += Walker->NumberOfPages;
|
||||||
PalCodePages += Walker->NumberOfPages;
|
PalCodePages += Walker->NumberOfPages;
|
||||||
break;
|
break;
|
||||||
|
case EfiUnacceptedMemoryType:
|
||||||
|
ShellPrintHiiEx (-1, -1, NULL, (EFI_STRING_ID)(!Sfo ? STRING_TOKEN (STR_MEMMAP_LIST_ITEM) : STRING_TOKEN (STR_MEMMAP_LIST_ITEM_SFO)), gShellDebug1HiiHandle, NameEfiUnacceptedMemoryType, Walker->PhysicalStart, Walker->PhysicalStart+MultU64x64 (SIZE_4KB, Walker->NumberOfPages)-1, Walker->NumberOfPages, Walker->Attribute);
|
||||||
|
TotalPages += Walker->NumberOfPages;
|
||||||
|
UnacceptedPages += Walker->NumberOfPages;
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
//
|
//
|
||||||
// Shell Spec defines the SFO format.
|
// Shell Spec defines the SFO format.
|
||||||
|
@ -335,6 +344,7 @@ ShellCommandRunMemMap (
|
||||||
MmioSpacePagesSize = MultU64x64 (SIZE_4KB, MmioSpacePages);
|
MmioSpacePagesSize = MultU64x64 (SIZE_4KB, MmioSpacePages);
|
||||||
MmioPortPagesSize = MultU64x64 (SIZE_4KB, MmioPortPages);
|
MmioPortPagesSize = MultU64x64 (SIZE_4KB, MmioPortPages);
|
||||||
PalCodePagesSize = MultU64x64 (SIZE_4KB, PalCodePages);
|
PalCodePagesSize = MultU64x64 (SIZE_4KB, PalCodePages);
|
||||||
|
UnacceptedPagesSize = MultU64x64 (SIZE_4KB, UnacceptedPages);
|
||||||
PersistentPagesSize = MultU64x64 (SIZE_4KB, PersistentPages);
|
PersistentPagesSize = MultU64x64 (SIZE_4KB, PersistentPages);
|
||||||
UnusableMemoryPagesSize = MultU64x64 (SIZE_4KB, UnusableMemoryPages);
|
UnusableMemoryPagesSize = MultU64x64 (SIZE_4KB, UnusableMemoryPages);
|
||||||
if (!Sfo) {
|
if (!Sfo) {
|
||||||
|
@ -368,6 +378,8 @@ ShellCommandRunMemMap (
|
||||||
MmioPortPagesSize,
|
MmioPortPagesSize,
|
||||||
PalCodePages,
|
PalCodePages,
|
||||||
PalCodePagesSize,
|
PalCodePagesSize,
|
||||||
|
UnacceptedPages,
|
||||||
|
UnacceptedPagesSize,
|
||||||
AvailPages,
|
AvailPages,
|
||||||
AvailPagesSize,
|
AvailPagesSize,
|
||||||
PersistentPages,
|
PersistentPages,
|
||||||
|
@ -422,6 +434,7 @@ ShellCommandRunMemMap (
|
||||||
AcpiReclaimPagesSize,
|
AcpiReclaimPagesSize,
|
||||||
AcpiNvsPagesSize,
|
AcpiNvsPagesSize,
|
||||||
PalCodePagesSize,
|
PalCodePagesSize,
|
||||||
|
UnacceptedPagesSize,
|
||||||
PersistentPagesSize
|
PersistentPagesSize
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -88,13 +88,14 @@
|
||||||
" MMIO : %,14ld Pages (%,ld Bytes)\r\n"
|
" MMIO : %,14ld Pages (%,ld Bytes)\r\n"
|
||||||
" MMIO_Port : %,14ld Pages (%,ld Bytes)\r\n"
|
" MMIO_Port : %,14ld Pages (%,ld Bytes)\r\n"
|
||||||
" PalCode : %,14ld Pages (%,ld Bytes)\r\n"
|
" PalCode : %,14ld Pages (%,ld Bytes)\r\n"
|
||||||
|
" Unaccepted: %,14ld Pages (%,ld Bytes)\r\n"
|
||||||
" Available : %,14ld Pages (%,ld Bytes)\r\n"
|
" Available : %,14ld Pages (%,ld Bytes)\r\n"
|
||||||
" Persistent: %,14ld Pages (%,ld Bytes)\r\n"
|
" Persistent: %,14ld Pages (%,ld Bytes)\r\n"
|
||||||
#string STR_MEMMAP_LIST_SUMM_OTHER #language en-US " %08x : %,14ld Pages (%,ld Bytes)\r\n"
|
#string STR_MEMMAP_LIST_SUMM_OTHER #language en-US " %08x : %,14ld Pages (%,ld Bytes)\r\n"
|
||||||
#string STR_MEMMAP_LIST_SUMM2 #language en-US " -------------- \r\n"
|
#string STR_MEMMAP_LIST_SUMM2 #language en-US " -------------- \r\n"
|
||||||
"Total Memory: %,14ld MB (%,ld Bytes)\r\n"
|
"Total Memory: %,14ld MB (%,ld Bytes)\r\n"
|
||||||
#string STR_MEMMAP_LIST_ITEM_SFO #language en-US "MemoryMap,"%s","%LX","%LX","%LX","%LX"\r\n"
|
#string STR_MEMMAP_LIST_ITEM_SFO #language en-US "MemoryMap,"%s","%LX","%LX","%LX","%LX"\r\n"
|
||||||
#string STR_MEMMAP_LIST_SUMM_SFO #language en-US "MemoryMapSummary,"%Ld","%Ld","%Ld","%Ld","%Ld","%Ld","%Ld","%Ld","%Ld","%Ld","%Ld","%Ld","%Ld","%Ld","%Ld","%Ld"\r\n"
|
#string STR_MEMMAP_LIST_SUMM_SFO #language en-US "MemoryMapSummary,"%Ld","%Ld","%Ld","%Ld","%Ld","%Ld","%Ld","%Ld","%Ld","%Ld","%Ld","%Ld","%Ld","%Ld","%Ld","%Ld", "%Ld"\r\n"
|
||||||
|
|
||||||
#string STR_EFI_COMPRESS_FAIL #language en-US "Unable to compress: %r.\r\n"
|
#string STR_EFI_COMPRESS_FAIL #language en-US "Unable to compress: %r.\r\n"
|
||||||
#string STR_EFI_DECOMPRESS_FAIL #language en-US "Unable to decompress: %r.\r\n"
|
#string STR_EFI_DECOMPRESS_FAIL #language en-US "Unable to decompress: %r.\r\n"
|
||||||
|
|
Loading…
Reference in New Issue