mirror of https://github.com/acidanthera/audk.git
ShellPkg: Add Persistent Memory support in 'memmap' command
As per ECR 1416, latest UEFI Shell 2.2 Specification has added Persistent Memory support in 'memmap' command. Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Tapan Shah <tapandshah@hpe.com> Reviewed-by: Jaben Carsey <jaben.carsey@intel.com>
This commit is contained in:
parent
339a2b935e
commit
38707d76fc
|
@ -1,6 +1,7 @@
|
||||||
/** @file
|
/** @file
|
||||||
Main file for Mode shell Debug1 function.
|
Main file for Mode shell Debug1 function.
|
||||||
|
|
||||||
|
(C) Copyright 2016 Hewlett Packard Enterprise Development LP<BR>
|
||||||
(C) Copyright 2013-2015 Hewlett-Packard Development Company, L.P.<BR>
|
(C) Copyright 2013-2015 Hewlett-Packard Development Company, L.P.<BR>
|
||||||
Copyright (c) 2010 - 2015, Intel Corporation. All rights reserved.<BR>
|
Copyright (c) 2010 - 2015, Intel Corporation. All rights reserved.<BR>
|
||||||
This program and the accompanying materials
|
This program and the accompanying materials
|
||||||
|
@ -100,6 +101,8 @@ ShellCommandRunMemMap (
|
||||||
UINT64 UnusableMemoryPagesSize;
|
UINT64 UnusableMemoryPagesSize;
|
||||||
UINT64 PalCodePages;
|
UINT64 PalCodePages;
|
||||||
UINT64 PalCodePagesSize;
|
UINT64 PalCodePagesSize;
|
||||||
|
UINT64 PersistentPages;
|
||||||
|
UINT64 PersistentPagesSize;
|
||||||
BOOLEAN Sfo;
|
BOOLEAN Sfo;
|
||||||
|
|
||||||
AcpiReclaimPages = 0;
|
AcpiReclaimPages = 0;
|
||||||
|
@ -117,6 +120,7 @@ ShellCommandRunMemMap (
|
||||||
MmioPortPages = 0;
|
MmioPortPages = 0;
|
||||||
UnusableMemoryPages = 0;
|
UnusableMemoryPages = 0;
|
||||||
PalCodePages = 0;
|
PalCodePages = 0;
|
||||||
|
PersistentPages = 0;
|
||||||
Size = 0;
|
Size = 0;
|
||||||
Buffer = NULL;
|
Buffer = NULL;
|
||||||
ShellStatus = SHELL_SUCCESS;
|
ShellStatus = SHELL_SUCCESS;
|
||||||
|
@ -210,8 +214,8 @@ ShellCommandRunMemMap (
|
||||||
break;
|
break;
|
||||||
case EfiPersistentMemory:
|
case EfiPersistentMemory:
|
||||||
ShellPrintHiiEx(-1, -1, NULL, (EFI_STRING_ID)(!Sfo?STRING_TOKEN (STR_MEMMAP_LIST_ITEM):STRING_TOKEN (STR_MEMMAP_LIST_ITEM_SFO)), gShellDebug1HiiHandle, NameEfiPersistentMemory, ((EFI_MEMORY_DESCRIPTOR*)Walker)->PhysicalStart, ((EFI_MEMORY_DESCRIPTOR*)Walker)->PhysicalStart+MultU64x64(SIZE_4KB,((EFI_MEMORY_DESCRIPTOR*)Walker)->NumberOfPages)-1, ((EFI_MEMORY_DESCRIPTOR*)Walker)->NumberOfPages, ((EFI_MEMORY_DESCRIPTOR*)Walker)->Attribute);
|
ShellPrintHiiEx(-1, -1, NULL, (EFI_STRING_ID)(!Sfo?STRING_TOKEN (STR_MEMMAP_LIST_ITEM):STRING_TOKEN (STR_MEMMAP_LIST_ITEM_SFO)), gShellDebug1HiiHandle, NameEfiPersistentMemory, ((EFI_MEMORY_DESCRIPTOR*)Walker)->PhysicalStart, ((EFI_MEMORY_DESCRIPTOR*)Walker)->PhysicalStart+MultU64x64(SIZE_4KB,((EFI_MEMORY_DESCRIPTOR*)Walker)->NumberOfPages)-1, ((EFI_MEMORY_DESCRIPTOR*)Walker)->NumberOfPages, ((EFI_MEMORY_DESCRIPTOR*)Walker)->Attribute);
|
||||||
AvailPages += ((EFI_MEMORY_DESCRIPTOR*)Walker)->NumberOfPages;
|
PersistentPages += ((EFI_MEMORY_DESCRIPTOR*)Walker)->NumberOfPages;
|
||||||
TotalPages += ((EFI_MEMORY_DESCRIPTOR*)Walker)->NumberOfPages;
|
TotalPages += ((EFI_MEMORY_DESCRIPTOR*)Walker)->NumberOfPages;
|
||||||
break;
|
break;
|
||||||
case EfiUnusableMemory:
|
case EfiUnusableMemory:
|
||||||
ShellPrintHiiEx(-1, -1, NULL, (EFI_STRING_ID)(!Sfo?STRING_TOKEN (STR_MEMMAP_LIST_ITEM):STRING_TOKEN (STR_MEMMAP_LIST_ITEM_SFO)), gShellDebug1HiiHandle, !Sfo?NameEfiUnusableMemoryShort:NameEfiUnusableMemory, ((EFI_MEMORY_DESCRIPTOR*)Walker)->PhysicalStart, ((EFI_MEMORY_DESCRIPTOR*)Walker)->PhysicalStart+MultU64x64(SIZE_4KB,((EFI_MEMORY_DESCRIPTOR*)Walker)->NumberOfPages)-1, ((EFI_MEMORY_DESCRIPTOR*)Walker)->NumberOfPages, ((EFI_MEMORY_DESCRIPTOR*)Walker)->Attribute);
|
ShellPrintHiiEx(-1, -1, NULL, (EFI_STRING_ID)(!Sfo?STRING_TOKEN (STR_MEMMAP_LIST_ITEM):STRING_TOKEN (STR_MEMMAP_LIST_ITEM_SFO)), gShellDebug1HiiHandle, !Sfo?NameEfiUnusableMemoryShort:NameEfiUnusableMemory, ((EFI_MEMORY_DESCRIPTOR*)Walker)->PhysicalStart, ((EFI_MEMORY_DESCRIPTOR*)Walker)->PhysicalStart+MultU64x64(SIZE_4KB,((EFI_MEMORY_DESCRIPTOR*)Walker)->NumberOfPages)-1, ((EFI_MEMORY_DESCRIPTOR*)Walker)->NumberOfPages, ((EFI_MEMORY_DESCRIPTOR*)Walker)->Attribute);
|
||||||
|
@ -261,6 +265,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);
|
||||||
|
PersistentPagesSize = MultU64x64(SIZE_4KB,PersistentPages);
|
||||||
UnusableMemoryPagesSize = MultU64x64(SIZE_4KB,UnusableMemoryPages);
|
UnusableMemoryPagesSize = MultU64x64(SIZE_4KB,UnusableMemoryPages);
|
||||||
if (!Sfo) {
|
if (!Sfo) {
|
||||||
ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_MEMMAP_LIST_SUMM), gShellDebug1HiiHandle,
|
ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_MEMMAP_LIST_SUMM), gShellDebug1HiiHandle,
|
||||||
|
@ -277,6 +282,7 @@ ShellCommandRunMemMap (
|
||||||
MmioPortPages, MmioPortPagesSize,
|
MmioPortPages, MmioPortPagesSize,
|
||||||
PalCodePages, PalCodePagesSize,
|
PalCodePages, PalCodePagesSize,
|
||||||
AvailPages, AvailPagesSize,
|
AvailPages, AvailPagesSize,
|
||||||
|
PersistentPages, PersistentPagesSize,
|
||||||
DivU64x32(MultU64x64(SIZE_4KB,TotalPages), SIZE_1MB), TotalPagesSize
|
DivU64x32(MultU64x64(SIZE_4KB,TotalPages), SIZE_1MB), TotalPagesSize
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
|
@ -295,7 +301,8 @@ ShellCommandRunMemMap (
|
||||||
UnusableMemoryPagesSize,
|
UnusableMemoryPagesSize,
|
||||||
AcpiReclaimPagesSize,
|
AcpiReclaimPagesSize,
|
||||||
AcpiNvsPagesSize,
|
AcpiNvsPagesSize,
|
||||||
PalCodePagesSize
|
PalCodePagesSize,
|
||||||
|
PersistentPagesSize
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -116,10 +116,11 @@
|
||||||
" 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"
|
||||||
" Available : %,14ld Pages (%,ld Bytes)\r\n"
|
" Available : %,14ld Pages (%,ld Bytes)\r\n"
|
||||||
|
" Persistent: %,14ld Pages (%,ld Bytes)\r\n"
|
||||||
" -------------- \r\n"
|
" -------------- \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"\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_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