2 Main file for Mode shell Debug1 function.
4 Copyright (c) 2013 - 2015, Hewlett-Packard Development Company, L.P.<BR>
5 Copyright (c) 2010 - 2014, Intel Corporation. All rights reserved.<BR>
6 This program and the accompanying materials
7 are licensed and made available under the terms and conditions of the BSD License
8 which acModeanies this distribution. The full text of the license may be found at
9 http://opensource.org/licenses/bsd-license.php
11 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
12 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
17 // Need full names for Standard-Format Output
19 STATIC CONST CHAR16 NameEfiReservedMemoryType
[] = L
"Reserved";
20 STATIC CONST CHAR16 NameEfiLoaderCode
[] = L
"LoaderCode";
21 STATIC CONST CHAR16 NameEfiLoaderData
[] = L
"LoaderData";
22 STATIC CONST CHAR16 NameEfiBootServicesCode
[] = L
"BootServiceCode";
23 STATIC CONST CHAR16 NameEfiBootServicesData
[] = L
"BootServiceData";
24 STATIC CONST CHAR16 NameEfiRuntimeServicesCode
[] = L
"RuntimeCode";
25 STATIC CONST CHAR16 NameEfiRuntimeServicesData
[] = L
"RuntimeData";
26 STATIC CONST CHAR16 NameEfiConventionalMemory
[] = L
"Available";
27 STATIC CONST CHAR16 NameEfiUnusableMemory
[] = L
"UnusableMemory";
28 STATIC CONST CHAR16 NameEfiACPIReclaimMemory
[] = L
"ACPIReclaimMemory";
29 STATIC CONST CHAR16 NameEfiACPIMemoryNVS
[] = L
"ACPIMemoryNVS";
30 STATIC CONST CHAR16 NameEfiMemoryMappedIO
[] = L
"MemoryMappedIO";
31 STATIC CONST CHAR16 NameEfiMemoryMappedIOPortSpace
[] = L
"MemoryMappedIOPortSpace";
32 STATIC CONST CHAR16 NameEfiPalCode
[] = L
"PalCode";
35 // Need short names for some memory types
37 STATIC CONST CHAR16 NameEfiBootServicesCodeShort
[] = L
"BS_Code";
38 STATIC CONST CHAR16 NameEfiBootServicesDataShort
[] = L
"BS_Data";
39 STATIC CONST CHAR16 NameEfiRuntimeServicesCodeShort
[] = L
"RT_Code";
40 STATIC CONST CHAR16 NameEfiRuntimeServicesDataShort
[] = L
"RT_Data";
41 STATIC CONST CHAR16 NameEfiUnusableMemoryShort
[] = L
"Unusable";
42 STATIC CONST CHAR16 NameEfiACPIReclaimMemoryShort
[] = L
"ACPI_Recl";
43 STATIC CONST CHAR16 NameEfiACPIMemoryNVSShort
[] = L
"ACPI_NVS";
44 STATIC CONST CHAR16 NameEfiMemoryMappedIOShort
[] = L
"MMIO";
45 STATIC CONST CHAR16 NameEfiMemoryMappedIOPortSpaceShort
[] = L
"MMIO_Port";
47 #include "UefiShellDebug1CommandsLib.h"
50 Function for 'memmap' command.
52 @param[in] ImageHandle Handle to the Image (NULL if Internal).
53 @param[in] SystemTable Pointer to the System Table (NULL if Internal).
57 ShellCommandRunMemMap (
58 IN EFI_HANDLE ImageHandle
,
59 IN EFI_SYSTEM_TABLE
*SystemTable
65 SHELL_STATUS ShellStatus
;
67 EFI_MEMORY_DESCRIPTOR
*Buffer
;
81 UINT64 ReservedPagesSize
;
82 UINT64 LoadCodePagesSize
;
83 UINT64 LoadDataPagesSize
;
84 UINT64 BSCodePagesSize
;
85 UINT64 BSDataPagesSize
;
86 UINT64 RTDataPagesSize
;
87 UINT64 RTCodePagesSize
;
88 UINT64 AvailPagesSize
;
89 UINT64 TotalPagesSize
;
90 UINT64 AcpiReclaimPages
;
92 UINT64 MmioSpacePages
;
93 UINT64 AcpiReclaimPagesSize
;
94 UINT64 AcpiNvsPagesSize
;
95 UINT64 MmioSpacePagesSize
;
97 UINT64 MmioPortPagesSize
;
98 UINT64 UnusableMemoryPages
;
99 UINT64 UnusableMemoryPagesSize
;
101 UINT64 PalCodePagesSize
;
104 AcpiReclaimPages
= 0;
117 UnusableMemoryPages
= 0;
121 ShellStatus
= SHELL_SUCCESS
;
122 Status
= EFI_SUCCESS
;
125 // initialize the shell lib (we must be in non-auto-init...)
127 Status
= ShellInitialize();
128 ASSERT_EFI_ERROR(Status
);
130 Status
= CommandInit();
131 ASSERT_EFI_ERROR(Status
);
134 // parse the command line
136 Status
= ShellCommandLineParse (SfoParamList
, &Package
, &ProblemParam
, TRUE
);
137 if (EFI_ERROR(Status
)) {
138 if (Status
== EFI_VOLUME_CORRUPTED
&& ProblemParam
!= NULL
) {
139 ShellPrintHiiEx(-1, -1, NULL
, STRING_TOKEN (STR_GEN_PROBLEM
), gShellDebug1HiiHandle
, L
"memmap", ProblemParam
);
140 FreePool(ProblemParam
);
141 ShellStatus
= SHELL_INVALID_PARAMETER
;
146 if (ShellCommandLineGetCount(Package
) > 1) {
147 ShellPrintHiiEx(-1, -1, NULL
, STRING_TOKEN (STR_GEN_TOO_MANY
), gShellDebug1HiiHandle
, L
"memmap");
148 ShellStatus
= SHELL_INVALID_PARAMETER
;
150 Status
= gBS
->GetMemoryMap(&Size
, Buffer
, &MapKey
, &ItemSize
, &Version
);
151 if (Status
== EFI_BUFFER_TOO_SMALL
){
153 Buffer
= AllocateZeroPool(Size
);
154 Status
= gBS
->GetMemoryMap(&Size
, Buffer
, &MapKey
, &ItemSize
, &Version
);
156 if (EFI_ERROR(Status
)) {
157 ShellPrintHiiEx(-1, -1, NULL
, STRING_TOKEN (STR_MEMMAP_GET_FAILED
), gShellDebug1HiiHandle
, L
"memmap");
158 ShellStatus
= SHELL_ACCESS_DENIED
;
160 ASSERT(Version
== EFI_MEMORY_DESCRIPTOR_VERSION
);
162 Sfo
= ShellCommandLineGetFlag(Package
, L
"-sfo");
164 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_MEMMAP_LIST_HEAD
), gShellDebug1HiiHandle
);
166 ShellPrintHiiEx (-1, -1, NULL
, STRING_TOKEN (STR_GEN_SFO_HEADER
), gShellDebug1HiiHandle
, L
"memmap");
169 for (Walker
= (UINT8
*)Buffer
; Walker
< (((UINT8
*)Buffer
)+Size
) && Walker
!= NULL
; Walker
+= ItemSize
){
170 switch (((EFI_MEMORY_DESCRIPTOR
*)Walker
)->Type
) {
171 case EfiReservedMemoryType
:
172 ShellPrintHiiEx(-1, -1, NULL
, (EFI_STRING_ID
)(!Sfo
?STRING_TOKEN (STR_MEMMAP_LIST_ITEM
):STRING_TOKEN (STR_MEMMAP_LIST_ITEM_SFO
)), gShellDebug1HiiHandle
, NameEfiReservedMemoryType
, ((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
);
173 ReservedPages
+= ((EFI_MEMORY_DESCRIPTOR
*)Walker
)->NumberOfPages
;
176 ShellPrintHiiEx(-1, -1, NULL
, (EFI_STRING_ID
)(!Sfo
?STRING_TOKEN (STR_MEMMAP_LIST_ITEM
):STRING_TOKEN (STR_MEMMAP_LIST_ITEM_SFO
)), gShellDebug1HiiHandle
, NameEfiLoaderCode
, ((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
);
177 LoadCodePages
+= ((EFI_MEMORY_DESCRIPTOR
*)Walker
)->NumberOfPages
;
178 TotalPages
+= ((EFI_MEMORY_DESCRIPTOR
*)Walker
)->NumberOfPages
;
181 ShellPrintHiiEx(-1, -1, NULL
, (EFI_STRING_ID
)(!Sfo
?STRING_TOKEN (STR_MEMMAP_LIST_ITEM
):STRING_TOKEN (STR_MEMMAP_LIST_ITEM_SFO
)), gShellDebug1HiiHandle
, NameEfiLoaderData
, ((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
);
182 LoadDataPages
+= ((EFI_MEMORY_DESCRIPTOR
*)Walker
)->NumberOfPages
;
183 TotalPages
+= ((EFI_MEMORY_DESCRIPTOR
*)Walker
)->NumberOfPages
;
185 case EfiBootServicesCode
:
186 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
, ((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
);
187 BSCodePages
+= ((EFI_MEMORY_DESCRIPTOR
*)Walker
)->NumberOfPages
;
188 TotalPages
+= ((EFI_MEMORY_DESCRIPTOR
*)Walker
)->NumberOfPages
;
190 case EfiBootServicesData
:
191 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
, ((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
);
192 BSDataPages
+= ((EFI_MEMORY_DESCRIPTOR
*)Walker
)->NumberOfPages
;
193 TotalPages
+= ((EFI_MEMORY_DESCRIPTOR
*)Walker
)->NumberOfPages
;
195 case EfiRuntimeServicesCode
:
196 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
, ((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
);
197 RTCodePages
+= ((EFI_MEMORY_DESCRIPTOR
*)Walker
)->NumberOfPages
;
198 TotalPages
+= ((EFI_MEMORY_DESCRIPTOR
*)Walker
)->NumberOfPages
;
200 case EfiRuntimeServicesData
:
201 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
, ((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
);
202 RTDataPages
+= ((EFI_MEMORY_DESCRIPTOR
*)Walker
)->NumberOfPages
;
203 TotalPages
+= ((EFI_MEMORY_DESCRIPTOR
*)Walker
)->NumberOfPages
;
205 case EfiConventionalMemory
:
206 ShellPrintHiiEx(-1, -1, NULL
, (EFI_STRING_ID
)(!Sfo
?STRING_TOKEN (STR_MEMMAP_LIST_ITEM
):STRING_TOKEN (STR_MEMMAP_LIST_ITEM_SFO
)), gShellDebug1HiiHandle
, NameEfiConventionalMemory
, ((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
);
207 AvailPages
+= ((EFI_MEMORY_DESCRIPTOR
*)Walker
)->NumberOfPages
;
208 TotalPages
+= ((EFI_MEMORY_DESCRIPTOR
*)Walker
)->NumberOfPages
;
210 case EfiUnusableMemory
:
211 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
);
212 UnusableMemoryPages
+= ((EFI_MEMORY_DESCRIPTOR
*)Walker
)->NumberOfPages
;
214 case EfiACPIReclaimMemory
:
215 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
, ((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
);
216 TotalPages
+= ((EFI_MEMORY_DESCRIPTOR
*)Walker
)->NumberOfPages
;
217 AcpiReclaimPages
+= ((EFI_MEMORY_DESCRIPTOR
*)Walker
)->NumberOfPages
;
219 case EfiACPIMemoryNVS
:
220 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
, ((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
);
221 TotalPages
+= ((EFI_MEMORY_DESCRIPTOR
*)Walker
)->NumberOfPages
;
222 AcpiNvsPages
+= ((EFI_MEMORY_DESCRIPTOR
*)Walker
)->NumberOfPages
;
224 case EfiMemoryMappedIO
:
225 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
, ((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
);
226 MmioSpacePages
+= ((EFI_MEMORY_DESCRIPTOR
*)Walker
)->NumberOfPages
;
228 case EfiMemoryMappedIOPortSpace
:
229 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
, ((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
);
230 MmioPortPages
+= ((EFI_MEMORY_DESCRIPTOR
*)Walker
)->NumberOfPages
;
233 ShellPrintHiiEx(-1, -1, NULL
, (EFI_STRING_ID
)(!Sfo
?STRING_TOKEN (STR_MEMMAP_LIST_ITEM
):STRING_TOKEN (STR_MEMMAP_LIST_ITEM_SFO
)), gShellDebug1HiiHandle
, NameEfiPalCode
, ((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
);
234 TotalPages
+= ((EFI_MEMORY_DESCRIPTOR
*)Walker
)->NumberOfPages
;
235 PalCodePages
+= ((EFI_MEMORY_DESCRIPTOR
*)Walker
)->NumberOfPages
;
244 ReservedPagesSize
= MultU64x64(SIZE_4KB
,ReservedPages
);
245 LoadCodePagesSize
= MultU64x64(SIZE_4KB
,LoadCodePages
);
246 LoadDataPagesSize
= MultU64x64(SIZE_4KB
,LoadDataPages
);
247 BSCodePagesSize
= MultU64x64(SIZE_4KB
,BSCodePages
);
248 BSDataPagesSize
= MultU64x64(SIZE_4KB
,BSDataPages
);
249 RTDataPagesSize
= MultU64x64(SIZE_4KB
,RTDataPages
);
250 RTCodePagesSize
= MultU64x64(SIZE_4KB
,RTCodePages
);
251 AvailPagesSize
= MultU64x64(SIZE_4KB
,AvailPages
);
252 TotalPagesSize
= MultU64x64(SIZE_4KB
,TotalPages
);
253 AcpiReclaimPagesSize
= MultU64x64(SIZE_4KB
,AcpiReclaimPages
);
254 AcpiNvsPagesSize
= MultU64x64(SIZE_4KB
,AcpiNvsPages
);
255 MmioSpacePagesSize
= MultU64x64(SIZE_4KB
,MmioSpacePages
);
256 MmioPortPagesSize
= MultU64x64(SIZE_4KB
,MmioPortPages
);
257 PalCodePagesSize
= MultU64x64(SIZE_4KB
,PalCodePages
);
258 UnusableMemoryPagesSize
= MultU64x64(SIZE_4KB
,UnusableMemoryPages
);
260 ShellPrintHiiEx(-1, -1, NULL
, STRING_TOKEN (STR_MEMMAP_LIST_SUMM
), gShellDebug1HiiHandle
,
261 ReservedPages
, ReservedPagesSize
,
262 LoadCodePages
, LoadCodePagesSize
,
263 LoadDataPages
, LoadDataPagesSize
,
264 BSCodePages
, BSCodePagesSize
,
265 BSDataPages
, BSDataPagesSize
,
266 RTCodePages
, RTCodePagesSize
,
267 RTDataPages
, RTDataPagesSize
,
268 AcpiReclaimPages
, AcpiReclaimPagesSize
,
269 AcpiNvsPages
, AcpiNvsPagesSize
,
270 MmioSpacePages
, MmioSpacePagesSize
,
271 MmioPortPages
, MmioPortPagesSize
,
272 PalCodePages
, PalCodePagesSize
,
273 AvailPages
, AvailPagesSize
,
274 DivU64x32(MultU64x64(SIZE_4KB
,TotalPages
), SIZE_1MB
), TotalPagesSize
277 ShellPrintHiiEx(-1, -1, NULL
, STRING_TOKEN (STR_MEMMAP_LIST_SUMM_SFO
), gShellDebug1HiiHandle
,
289 UnusableMemoryPagesSize
,
290 AcpiReclaimPagesSize
,
297 ShellCommandLineFreeVarList (Package
);
300 if (Buffer
!= NULL
) {
304 return (ShellStatus
);