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>
		
			
				
	
	
		
			460 lines
		
	
	
		
			22 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			460 lines
		
	
	
		
			22 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /** @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);
 | |
| }
 |