/** @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> | |
SPDX-License-Identifier: BSD-2-Clause-Patent | |
**/ | |
// | |
// 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"; | |
STATIC CONST CHAR16 NameEfiUnacceptedMemoryType[] = L"Unaccepted"; | |
// | |
// 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 UnacceptedPages; | |
UINT64 UnacceptedPagesSize; | |
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; | |
UnacceptedPages = 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; | |
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: | |
// | |
// 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); | |
UnacceptedPagesSize = MultU64x64 (SIZE_4KB, UnacceptedPages); | |
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, | |
UnacceptedPages, | |
UnacceptedPagesSize, | |
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, | |
UnacceptedPagesSize, | |
PersistentPagesSize | |
); | |
} | |
} | |
} | |
ShellCommandLineFreeVarList (Package); | |
} | |
if (Descriptors != NULL) { | |
FreePool (Descriptors); | |
} | |
// | |
// Free the memory list. | |
// | |
for (Link = GetFirstNode (&MemoryList); !IsNull (&MemoryList, Link); ) { | |
Link = RemoveEntryList (Link); | |
} | |
return (ShellStatus); | |
} |