/** @file | |
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> | |
Copyright (c) 2010 - 2018, 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 acModeanies this distribution. The full text of the license may be found at | |
http://opensource.org/licenses/bsd-license.php | |
THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | |
WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | |
**/ | |
// | |
// Need full names for Standard-Format Output | |
// | |
STATIC CONST CHAR16 NameEfiReservedMemoryType[] = L"Reserved"; | |
STATIC CONST CHAR16 NameEfiLoaderCode[] = L"LoaderCode"; | |
STATIC CONST CHAR16 NameEfiLoaderData[] = L"LoaderData"; | |
STATIC CONST CHAR16 NameEfiBootServicesCode[] = L"BootServiceCode"; | |
STATIC CONST CHAR16 NameEfiBootServicesData[] = L"BootServiceData"; | |
STATIC CONST CHAR16 NameEfiRuntimeServicesCode[] = L"RuntimeCode"; | |
STATIC CONST CHAR16 NameEfiRuntimeServicesData[] = L"RuntimeData"; | |
STATIC CONST CHAR16 NameEfiConventionalMemory[] = L"Available"; | |
STATIC CONST CHAR16 NameEfiPersistentMemory[] = L"Persistent"; | |
STATIC CONST CHAR16 NameEfiUnusableMemory[] = L"UnusableMemory"; | |
STATIC CONST CHAR16 NameEfiACPIReclaimMemory[] = L"ACPIReclaimMemory"; | |
STATIC CONST CHAR16 NameEfiACPIMemoryNVS[] = L"ACPIMemoryNVS"; | |
STATIC CONST CHAR16 NameEfiMemoryMappedIO[] = L"MemoryMappedIO"; | |
STATIC CONST CHAR16 NameEfiMemoryMappedIOPortSpace[] = L"MemoryMappedIOPortSpace"; | |
STATIC CONST CHAR16 NameEfiPalCode[] = L"PalCode"; | |
// | |
// Need short names for some memory types | |
// | |
STATIC CONST CHAR16 NameEfiBootServicesCodeShort[] = L"BS_Code"; | |
STATIC CONST CHAR16 NameEfiBootServicesDataShort[] = L"BS_Data"; | |
STATIC CONST CHAR16 NameEfiRuntimeServicesCodeShort[] = L"RT_Code"; | |
STATIC CONST CHAR16 NameEfiRuntimeServicesDataShort[] = L"RT_Data"; | |
STATIC CONST CHAR16 NameEfiUnusableMemoryShort[] = L"Unusable"; | |
STATIC CONST CHAR16 NameEfiACPIReclaimMemoryShort[] = L"ACPI_Recl"; | |
STATIC CONST CHAR16 NameEfiACPIMemoryNVSShort[] = L"ACPI_NVS"; | |
STATIC CONST CHAR16 NameEfiMemoryMappedIOShort[] = L"MMIO"; | |
STATIC CONST CHAR16 NameEfiMemoryMappedIOPortSpaceShort[] = L"MMIO_Port"; | |
#include "UefiShellDebug1CommandsLib.h" | |
typedef struct { | |
UINT32 Type; | |
UINT64 NumberOfPages; | |
LIST_ENTRY Link; | |
} MEMORY_LENGTH_ENTRY; | |
/** | |
Add the length of the specified type to List. | |
@param List A list to hold all pairs of <Type, NumberOfPages>. | |
@param Type Memory type. | |
@param NumberOfPages Number of pages. | |
**/ | |
VOID | |
AddMemoryLength ( | |
LIST_ENTRY *List, | |
UINT32 Type, | |
UINT64 NumberOfPages | |
) | |
{ | |
MEMORY_LENGTH_ENTRY *Entry; | |
MEMORY_LENGTH_ENTRY *NewEntry; | |
LIST_ENTRY *Link; | |
Entry = NULL; | |
for (Link = GetFirstNode (List); !IsNull (List, Link); Link = GetNextNode (List, Link)) { | |
Entry = BASE_CR (Link, MEMORY_LENGTH_ENTRY, Link); | |
if (Entry->Type >= Type) { | |
break; | |
} | |
} | |
if ((Entry != NULL) && (Entry->Type == Type)) { | |
// | |
// The Entry is the one we look for. | |
// | |
NewEntry = Entry; | |
} else { | |
// | |
// The search operation breaks due to: | |
// 1. Type of every entry < Type --> Insert to tail | |
// 2. Type of an entry > Type --> Insert to previous of this entry | |
// | |
NewEntry = AllocatePool (sizeof (*NewEntry)); | |
if (NewEntry == NULL) { | |
return; | |
} | |
NewEntry->Type = Type; | |
NewEntry->NumberOfPages = 0; | |
InsertTailList (Link, &NewEntry->Link); | |
} | |
NewEntry->NumberOfPages += NumberOfPages; | |
} | |
/** | |
Function for 'memmap' command. | |
@param[in] ImageHandle Handle to the Image (NULL if Internal). | |
@param[in] SystemTable Pointer to the System Table (NULL if Internal). | |
**/ | |
SHELL_STATUS | |
EFIAPI | |
ShellCommandRunMemMap ( | |
IN EFI_HANDLE ImageHandle, | |
IN EFI_SYSTEM_TABLE *SystemTable | |
) | |
{ | |
EFI_STATUS Status; | |
LIST_ENTRY *Package; | |
CHAR16 *ProblemParam; | |
SHELL_STATUS ShellStatus; | |
UINTN Size; | |
EFI_MEMORY_DESCRIPTOR *Descriptors; | |
UINTN MapKey; | |
UINTN ItemSize; | |
UINT32 Version; | |
EFI_MEMORY_DESCRIPTOR *Walker; | |
UINT64 ReservedPages; | |
UINT64 LoadCodePages; | |
UINT64 LoadDataPages; | |
UINT64 BSCodePages; | |
UINT64 BSDataPages; | |
UINT64 RTDataPages; | |
UINT64 RTCodePages; | |
UINT64 AvailPages; | |
UINT64 TotalPages; | |
UINT64 ReservedPagesSize; | |
UINT64 LoadCodePagesSize; | |
UINT64 LoadDataPagesSize; | |
UINT64 BSCodePagesSize; | |
UINT64 BSDataPagesSize; | |
UINT64 RTDataPagesSize; | |
UINT64 RTCodePagesSize; | |
UINT64 AvailPagesSize; | |
UINT64 TotalPagesSize; | |
UINT64 AcpiReclaimPages; | |
UINT64 AcpiNvsPages; | |
UINT64 MmioSpacePages; | |
UINT64 AcpiReclaimPagesSize; | |
UINT64 AcpiNvsPagesSize; | |
UINT64 MmioSpacePagesSize; | |
UINT64 MmioPortPages; | |
UINT64 MmioPortPagesSize; | |
UINT64 UnusableMemoryPages; | |
UINT64 UnusableMemoryPagesSize; | |
UINT64 PalCodePages; | |
UINT64 PalCodePagesSize; | |
UINT64 PersistentPages; | |
UINT64 PersistentPagesSize; | |
BOOLEAN Sfo; | |
LIST_ENTRY MemoryList; | |
MEMORY_LENGTH_ENTRY *Entry; | |
LIST_ENTRY *Link; | |
AcpiReclaimPages = 0; | |
AcpiNvsPages = 0; | |
MmioSpacePages = 0; | |
TotalPages = 0; | |
ReservedPages = 0; | |
LoadCodePages = 0; | |
LoadDataPages = 0; | |
BSCodePages = 0; | |
BSDataPages = 0; | |
RTDataPages = 0; | |
RTCodePages = 0; | |
AvailPages = 0; | |
MmioPortPages = 0; | |
UnusableMemoryPages = 0; | |
PalCodePages = 0; | |
PersistentPages = 0; | |
Size = 0; | |
Descriptors = NULL; | |
ShellStatus = SHELL_SUCCESS; | |
Status = EFI_SUCCESS; | |
InitializeListHead (&MemoryList); | |
// | |
// initialize the shell lib (we must be in non-auto-init...) | |
// | |
Status = ShellInitialize(); | |
ASSERT_EFI_ERROR(Status); | |
Status = CommandInit(); | |
ASSERT_EFI_ERROR(Status); | |
// | |
// parse the command line | |
// | |
Status = ShellCommandLineParse (SfoParamList, &Package, &ProblemParam, TRUE); | |
if (EFI_ERROR(Status)) { | |
if (Status == EFI_VOLUME_CORRUPTED && ProblemParam != NULL) { | |
ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_PROBLEM), gShellDebug1HiiHandle, L"memmap", ProblemParam); | |
FreePool(ProblemParam); | |
ShellStatus = SHELL_INVALID_PARAMETER; | |
} else { | |
ASSERT(FALSE); | |
} | |
} else { | |
if (ShellCommandLineGetCount(Package) > 1) { | |
ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_TOO_MANY), gShellDebug1HiiHandle, L"memmap"); | |
ShellStatus = SHELL_INVALID_PARAMETER; | |
} else { | |
Status = gBS->GetMemoryMap(&Size, Descriptors, &MapKey, &ItemSize, &Version); | |
if (Status == EFI_BUFFER_TOO_SMALL){ | |
Size += SIZE_1KB; | |
Descriptors = AllocateZeroPool(Size); | |
Status = gBS->GetMemoryMap(&Size, Descriptors, &MapKey, &ItemSize, &Version); | |
} | |
if (EFI_ERROR(Status)) { | |
ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_MEMMAP_GET_FAILED), gShellDebug1HiiHandle, L"memmap"); | |
ShellStatus = SHELL_ACCESS_DENIED; | |
} else { | |
ASSERT(Version == EFI_MEMORY_DESCRIPTOR_VERSION); | |
Sfo = ShellCommandLineGetFlag(Package, L"-sfo"); | |
if (!Sfo) { | |
ShellPrintHiiEx (-1, -1, NULL, STRING_TOKEN (STR_MEMMAP_LIST_HEAD), gShellDebug1HiiHandle); | |
} else { | |
ShellPrintHiiEx (-1, -1, NULL, STRING_TOKEN (STR_GEN_SFO_HEADER), gShellDebug1HiiHandle, L"memmap"); | |
} | |
for ( Walker = Descriptors | |
; (Walker < (EFI_MEMORY_DESCRIPTOR *) ((UINT8*)Descriptors + Size)) && (Walker != NULL) | |
; Walker = (EFI_MEMORY_DESCRIPTOR *) ((UINT8 *)Walker + ItemSize) | |
){ | |
switch (Walker->Type) { | |
case EfiReservedMemoryType: | |
ShellPrintHiiEx(-1, -1, NULL, (EFI_STRING_ID)(!Sfo?STRING_TOKEN (STR_MEMMAP_LIST_ITEM):STRING_TOKEN (STR_MEMMAP_LIST_ITEM_SFO)), gShellDebug1HiiHandle, NameEfiReservedMemoryType, Walker->PhysicalStart, Walker->PhysicalStart+MultU64x64(SIZE_4KB,Walker->NumberOfPages)-1, Walker->NumberOfPages, Walker->Attribute); | |
ReservedPages += Walker->NumberOfPages; | |
break; | |
case EfiLoaderCode: | |
ShellPrintHiiEx(-1, -1, NULL, (EFI_STRING_ID)(!Sfo?STRING_TOKEN (STR_MEMMAP_LIST_ITEM):STRING_TOKEN (STR_MEMMAP_LIST_ITEM_SFO)), gShellDebug1HiiHandle, NameEfiLoaderCode, Walker->PhysicalStart, Walker->PhysicalStart+MultU64x64(SIZE_4KB,Walker->NumberOfPages)-1, Walker->NumberOfPages, Walker->Attribute); | |
LoadCodePages += Walker->NumberOfPages; | |
TotalPages += Walker->NumberOfPages; | |
break; | |
case EfiLoaderData: | |
ShellPrintHiiEx(-1, -1, NULL, (EFI_STRING_ID)(!Sfo?STRING_TOKEN (STR_MEMMAP_LIST_ITEM):STRING_TOKEN (STR_MEMMAP_LIST_ITEM_SFO)), gShellDebug1HiiHandle, NameEfiLoaderData, Walker->PhysicalStart, Walker->PhysicalStart+MultU64x64(SIZE_4KB,Walker->NumberOfPages)-1, Walker->NumberOfPages, Walker->Attribute); | |
LoadDataPages += Walker->NumberOfPages; | |
TotalPages += Walker->NumberOfPages; | |
break; | |
case EfiBootServicesCode: | |
ShellPrintHiiEx(-1, -1, NULL, (EFI_STRING_ID)(!Sfo?STRING_TOKEN (STR_MEMMAP_LIST_ITEM):STRING_TOKEN (STR_MEMMAP_LIST_ITEM_SFO)), gShellDebug1HiiHandle, !Sfo?NameEfiBootServicesCodeShort:NameEfiBootServicesCode, Walker->PhysicalStart, Walker->PhysicalStart+MultU64x64(SIZE_4KB,Walker->NumberOfPages)-1, Walker->NumberOfPages, Walker->Attribute); | |
BSCodePages += Walker->NumberOfPages; | |
TotalPages += Walker->NumberOfPages; | |
break; | |
case EfiBootServicesData: | |
ShellPrintHiiEx(-1, -1, NULL, (EFI_STRING_ID)(!Sfo?STRING_TOKEN (STR_MEMMAP_LIST_ITEM):STRING_TOKEN (STR_MEMMAP_LIST_ITEM_SFO)), gShellDebug1HiiHandle, !Sfo?NameEfiBootServicesDataShort:NameEfiBootServicesData, Walker->PhysicalStart, Walker->PhysicalStart+MultU64x64(SIZE_4KB,Walker->NumberOfPages)-1, Walker->NumberOfPages, Walker->Attribute); | |
BSDataPages += Walker->NumberOfPages; | |
TotalPages += Walker->NumberOfPages; | |
break; | |
case EfiRuntimeServicesCode: | |
ShellPrintHiiEx(-1, -1, NULL, (EFI_STRING_ID)(!Sfo?STRING_TOKEN (STR_MEMMAP_LIST_ITEM):STRING_TOKEN (STR_MEMMAP_LIST_ITEM_SFO)), gShellDebug1HiiHandle, !Sfo?NameEfiRuntimeServicesCodeShort:NameEfiRuntimeServicesCode, Walker->PhysicalStart, Walker->PhysicalStart+MultU64x64(SIZE_4KB,Walker->NumberOfPages)-1, Walker->NumberOfPages, Walker->Attribute); | |
RTCodePages += Walker->NumberOfPages; | |
TotalPages += Walker->NumberOfPages; | |
break; | |
case EfiRuntimeServicesData: | |
ShellPrintHiiEx(-1, -1, NULL, (EFI_STRING_ID)(!Sfo?STRING_TOKEN (STR_MEMMAP_LIST_ITEM):STRING_TOKEN (STR_MEMMAP_LIST_ITEM_SFO)), gShellDebug1HiiHandle, !Sfo?NameEfiRuntimeServicesDataShort:NameEfiRuntimeServicesData, Walker->PhysicalStart, Walker->PhysicalStart+MultU64x64(SIZE_4KB,Walker->NumberOfPages)-1, Walker->NumberOfPages, Walker->Attribute); | |
RTDataPages += Walker->NumberOfPages; | |
TotalPages += Walker->NumberOfPages; | |
break; | |
case EfiConventionalMemory: | |
ShellPrintHiiEx(-1, -1, NULL, (EFI_STRING_ID)(!Sfo?STRING_TOKEN (STR_MEMMAP_LIST_ITEM):STRING_TOKEN (STR_MEMMAP_LIST_ITEM_SFO)), gShellDebug1HiiHandle, NameEfiConventionalMemory, Walker->PhysicalStart, Walker->PhysicalStart+MultU64x64(SIZE_4KB,Walker->NumberOfPages)-1, Walker->NumberOfPages, Walker->Attribute); | |
AvailPages += Walker->NumberOfPages; | |
TotalPages += Walker->NumberOfPages; | |
break; | |
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, Walker->PhysicalStart, Walker->PhysicalStart+MultU64x64(SIZE_4KB,Walker->NumberOfPages)-1, Walker->NumberOfPages, Walker->Attribute); | |
PersistentPages += Walker->NumberOfPages; | |
TotalPages += Walker->NumberOfPages; | |
break; | |
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, Walker->PhysicalStart, Walker->PhysicalStart+MultU64x64(SIZE_4KB,Walker->NumberOfPages)-1, Walker->NumberOfPages, Walker->Attribute); | |
UnusableMemoryPages += Walker->NumberOfPages; | |
break; | |
case EfiACPIReclaimMemory: | |
ShellPrintHiiEx(-1, -1, NULL, (EFI_STRING_ID)(!Sfo?STRING_TOKEN (STR_MEMMAP_LIST_ITEM):STRING_TOKEN (STR_MEMMAP_LIST_ITEM_SFO)), gShellDebug1HiiHandle, !Sfo?NameEfiACPIReclaimMemoryShort:NameEfiACPIReclaimMemory, Walker->PhysicalStart, Walker->PhysicalStart+MultU64x64(SIZE_4KB,Walker->NumberOfPages)-1, Walker->NumberOfPages, Walker->Attribute); | |
TotalPages += Walker->NumberOfPages; | |
AcpiReclaimPages += Walker->NumberOfPages; | |
break; | |
case EfiACPIMemoryNVS: | |
ShellPrintHiiEx(-1, -1, NULL, (EFI_STRING_ID)(!Sfo?STRING_TOKEN (STR_MEMMAP_LIST_ITEM):STRING_TOKEN (STR_MEMMAP_LIST_ITEM_SFO)), gShellDebug1HiiHandle, !Sfo?NameEfiACPIMemoryNVSShort:NameEfiACPIMemoryNVS, Walker->PhysicalStart, Walker->PhysicalStart+MultU64x64(SIZE_4KB,Walker->NumberOfPages)-1, Walker->NumberOfPages, Walker->Attribute); | |
TotalPages += Walker->NumberOfPages; | |
AcpiNvsPages += Walker->NumberOfPages; | |
break; | |
case EfiMemoryMappedIO: | |
ShellPrintHiiEx(-1, -1, NULL, (EFI_STRING_ID)(!Sfo?STRING_TOKEN (STR_MEMMAP_LIST_ITEM):STRING_TOKEN (STR_MEMMAP_LIST_ITEM_SFO)), gShellDebug1HiiHandle, !Sfo?NameEfiMemoryMappedIOShort:NameEfiMemoryMappedIO, Walker->PhysicalStart, Walker->PhysicalStart+MultU64x64(SIZE_4KB,Walker->NumberOfPages)-1, Walker->NumberOfPages, Walker->Attribute); | |
MmioSpacePages += Walker->NumberOfPages; | |
break; | |
case EfiMemoryMappedIOPortSpace: | |
ShellPrintHiiEx(-1, -1, NULL, (EFI_STRING_ID)(!Sfo?STRING_TOKEN (STR_MEMMAP_LIST_ITEM):STRING_TOKEN (STR_MEMMAP_LIST_ITEM_SFO)), gShellDebug1HiiHandle, !Sfo?NameEfiMemoryMappedIOPortSpaceShort:NameEfiMemoryMappedIOPortSpace, Walker->PhysicalStart, Walker->PhysicalStart+MultU64x64(SIZE_4KB,Walker->NumberOfPages)-1, Walker->NumberOfPages, Walker->Attribute); | |
MmioPortPages += Walker->NumberOfPages; | |
break; | |
case EfiPalCode: | |
ShellPrintHiiEx(-1, -1, NULL, (EFI_STRING_ID)(!Sfo?STRING_TOKEN (STR_MEMMAP_LIST_ITEM):STRING_TOKEN (STR_MEMMAP_LIST_ITEM_SFO)), gShellDebug1HiiHandle, NameEfiPalCode, Walker->PhysicalStart, Walker->PhysicalStart+MultU64x64(SIZE_4KB,Walker->NumberOfPages)-1, Walker->NumberOfPages, Walker->Attribute); | |
TotalPages += Walker->NumberOfPages; | |
PalCodePages += Walker->NumberOfPages; | |
break; | |
default: | |
// | |
// Shell Spec defines the SFO format. | |
// Do not print the OEM/OS memory usage in the SFO format, to avoid conflict with Shell Spec. | |
// | |
if (!Sfo) { | |
ShellPrintHiiEx (-1, -1, NULL, STRING_TOKEN (STR_MEMMAP_LIST_ITEM_OTHER), gShellDebug1HiiHandle, Walker->Type, Walker->PhysicalStart, Walker->PhysicalStart + MultU64x64 (SIZE_4KB, Walker->NumberOfPages) - 1, Walker->NumberOfPages, Walker->Attribute); | |
} | |
TotalPages += Walker->NumberOfPages; | |
AddMemoryLength (&MemoryList, Walker->Type, Walker->NumberOfPages); | |
break; | |
} | |
} | |
// | |
// print the summary | |
// | |
ReservedPagesSize = MultU64x64(SIZE_4KB,ReservedPages); | |
LoadCodePagesSize = MultU64x64(SIZE_4KB,LoadCodePages); | |
LoadDataPagesSize = MultU64x64(SIZE_4KB,LoadDataPages); | |
BSCodePagesSize = MultU64x64(SIZE_4KB,BSCodePages); | |
BSDataPagesSize = MultU64x64(SIZE_4KB,BSDataPages); | |
RTDataPagesSize = MultU64x64(SIZE_4KB,RTDataPages); | |
RTCodePagesSize = MultU64x64(SIZE_4KB,RTCodePages); | |
AvailPagesSize = MultU64x64(SIZE_4KB,AvailPages); | |
TotalPagesSize = MultU64x64(SIZE_4KB,TotalPages); | |
AcpiReclaimPagesSize = MultU64x64(SIZE_4KB,AcpiReclaimPages); | |
AcpiNvsPagesSize = MultU64x64(SIZE_4KB,AcpiNvsPages); | |
MmioSpacePagesSize = MultU64x64(SIZE_4KB,MmioSpacePages); | |
MmioPortPagesSize = MultU64x64(SIZE_4KB,MmioPortPages); | |
PalCodePagesSize = MultU64x64(SIZE_4KB,PalCodePages); | |
PersistentPagesSize = MultU64x64(SIZE_4KB,PersistentPages); | |
UnusableMemoryPagesSize = MultU64x64(SIZE_4KB,UnusableMemoryPages); | |
if (!Sfo) { | |
ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_MEMMAP_LIST_SUMM), gShellDebug1HiiHandle, | |
ReservedPages, ReservedPagesSize, | |
LoadCodePages, LoadCodePagesSize, | |
LoadDataPages, LoadDataPagesSize, | |
BSCodePages, BSCodePagesSize, | |
BSDataPages, BSDataPagesSize, | |
RTCodePages, RTCodePagesSize, | |
RTDataPages, RTDataPagesSize, | |
AcpiReclaimPages, AcpiReclaimPagesSize, | |
AcpiNvsPages, AcpiNvsPagesSize, | |
MmioSpacePages, MmioSpacePagesSize, | |
MmioPortPages, MmioPortPagesSize, | |
PalCodePages, PalCodePagesSize, | |
AvailPages, AvailPagesSize, | |
PersistentPages, PersistentPagesSize | |
); | |
// | |
// Print out the total memory usage for OEM/OS types in the order of type. | |
// | |
for (Link = GetFirstNode (&MemoryList); !IsNull (&MemoryList, Link); Link = GetNextNode (&MemoryList, Link)) { | |
Entry = BASE_CR (Link, MEMORY_LENGTH_ENTRY, Link); | |
ShellPrintHiiEx (-1, -1, NULL, STRING_TOKEN (STR_MEMMAP_LIST_SUMM_OTHER), gShellDebug1HiiHandle, | |
Entry->Type, Entry->NumberOfPages, MultU64x64 (SIZE_4KB, Entry->NumberOfPages) | |
); | |
} | |
ShellPrintHiiEx (-1, -1, NULL, STRING_TOKEN (STR_MEMMAP_LIST_SUMM2), gShellDebug1HiiHandle, | |
DivU64x32(MultU64x64(SIZE_4KB,TotalPages), SIZE_1MB), TotalPagesSize | |
); | |
} else { | |
ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_MEMMAP_LIST_SUMM_SFO), gShellDebug1HiiHandle, | |
TotalPagesSize, | |
ReservedPagesSize, | |
BSCodePagesSize, | |
BSDataPagesSize, | |
RTCodePagesSize, | |
RTDataPagesSize, | |
LoadCodePagesSize, | |
LoadDataPagesSize, | |
AvailPagesSize, | |
MmioSpacePagesSize, | |
MmioPortPagesSize, | |
UnusableMemoryPagesSize, | |
AcpiReclaimPagesSize, | |
AcpiNvsPagesSize, | |
PalCodePagesSize, | |
PersistentPagesSize | |
); | |
} | |
} | |
} | |
ShellCommandLineFreeVarList (Package); | |
} | |
if (Descriptors != NULL) { | |
FreePool(Descriptors); | |
} | |
// | |
// Free the memory list. | |
// | |
for (Link = GetFirstNode (&MemoryList); !IsNull (&MemoryList, Link); ) { | |
Link = RemoveEntryList (Link); | |
} | |
return (ShellStatus); | |
} | |