2 Main file for NULL named library for Profile1 shell command functions.
4 Copyright (c) 2010 - 2018, Intel Corporation. All rights reserved.<BR>
5 SPDX-License-Identifier: BSD-2-Clause-Patent
9 #ifndef _UEFI_SHELL_DEBUG1_COMMANDS_LIB_H_
10 #define _UEFI_SHELL_DEBUG1_COMMANDS_LIB_H_
14 #include <Guid/GlobalVariable.h>
15 #include <Guid/ConsoleInDevice.h>
16 #include <Guid/ConsoleOutDevice.h>
17 #include <Guid/FileSystemInfo.h>
18 #include <Guid/ShellLibHiiGuid.h>
20 #include <Protocol/Shell.h>
21 #include <Protocol/ShellParameters.h>
22 #include <Protocol/DevicePath.h>
23 #include <Protocol/LoadedImage.h>
24 #include <Protocol/UnicodeCollation.h>
25 #include <Protocol/DriverDiagnostics2.h>
26 #include <Protocol/DriverDiagnostics.h>
27 #include <Protocol/PlatformDriverOverride.h>
28 #include <Protocol/BusSpecificDriverOverride.h>
29 #include <Protocol/PlatformToDriverConfiguration.h>
30 #include <Protocol/DriverSupportedEfiVersion.h>
31 #include <Protocol/DriverFamilyOverride.h>
32 #include <Protocol/DriverHealth.h>
33 #include <Protocol/SimplePointer.h>
34 #include <Protocol/CpuIo2.h>
35 #include <Protocol/PciRootBridgeIo.h>
37 #include <Library/BaseLib.h>
38 #include <Library/BaseMemoryLib.h>
39 #include <Library/DebugLib.h>
40 #include <Library/MemoryAllocationLib.h>
41 #include <Library/PcdLib.h>
42 #include <Library/ShellCommandLib.h>
43 #include <Library/ShellLib.h>
44 #include <Library/SortLib.h>
45 #include <Library/UefiLib.h>
46 #include <Library/UefiRuntimeServicesTableLib.h>
47 #include <Library/UefiBootServicesTableLib.h>
48 #include <Library/HiiLib.h>
49 #include <Library/FileHandleLib.h>
50 #include <Library/DevicePathLib.h>
51 #include <Library/PrintLib.h>
52 #include <Library/HandleParsingLib.h>
54 extern EFI_HII_HANDLE gShellDebug1HiiHandle
;
57 Function returns a system configuration table that is stored in the
58 EFI System Table based on the provided GUID.
60 @param[in] TableGuid A pointer to the table's GUID type.
61 @param[in, out] Table On exit, a pointer to a system configuration table.
63 @retval EFI_SUCCESS A configuration table matching TableGuid was found.
64 @retval EFI_NOT_FOUND A configuration table matching TableGuid was not found.
67 GetSystemConfigurationTable (
68 IN EFI_GUID
*TableGuid
,
73 Function for 'setsize' command.
75 @param[in] ImageHandle Handle to the Image (NULL if Internal).
76 @param[in] SystemTable Pointer to the System Table (NULL if Internal).
80 ShellCommandRunSetSize (
81 IN EFI_HANDLE ImageHandle
,
82 IN EFI_SYSTEM_TABLE
*SystemTable
86 Function for 'comp' command.
88 @param[in] ImageHandle Handle to the Image (NULL if Internal).
89 @param[in] SystemTable Pointer to the System Table (NULL if Internal).
94 IN EFI_HANDLE ImageHandle
,
95 IN EFI_SYSTEM_TABLE
*SystemTable
99 Function for 'mode' command.
101 @param[in] ImageHandle Handle to the Image (NULL if Internal).
102 @param[in] SystemTable Pointer to the System Table (NULL if Internal).
106 ShellCommandRunMode (
107 IN EFI_HANDLE ImageHandle
,
108 IN EFI_SYSTEM_TABLE
*SystemTable
112 Function for 'memmap' command.
114 @param[in] ImageHandle Handle to the Image (NULL if Internal).
115 @param[in] SystemTable Pointer to the System Table (NULL if Internal).
119 ShellCommandRunMemMap (
120 IN EFI_HANDLE ImageHandle
,
121 IN EFI_SYSTEM_TABLE
*SystemTable
125 Function for 'compress' command.
127 @param[in] ImageHandle Handle to the Image (NULL if Internal).
128 @param[in] SystemTable Pointer to the System Table (NULL if Internal).
132 ShellCommandRunEfiCompress (
133 IN EFI_HANDLE ImageHandle
,
134 IN EFI_SYSTEM_TABLE
*SystemTable
138 Function for 'decompress' command.
140 @param[in] ImageHandle Handle to the Image (NULL if Internal).
141 @param[in] SystemTable Pointer to the System Table (NULL if Internal).
145 ShellCommandRunEfiDecompress (
146 IN EFI_HANDLE ImageHandle
,
147 IN EFI_SYSTEM_TABLE
*SystemTable
151 Function for 'dmem' command.
153 @param[in] ImageHandle Handle to the Image (NULL if Internal).
154 @param[in] SystemTable Pointer to the System Table (NULL if Internal).
158 ShellCommandRunDmem (
159 IN EFI_HANDLE ImageHandle
,
160 IN EFI_SYSTEM_TABLE
*SystemTable
164 Function for 'loadpcirom' command.
166 @param[in] ImageHandle Handle to the Image (NULL if Internal).
167 @param[in] SystemTable Pointer to the System Table (NULL if Internal).
171 ShellCommandRunLoadPciRom (
172 IN EFI_HANDLE ImageHandle
,
173 IN EFI_SYSTEM_TABLE
*SystemTable
177 Function for 'mm' command.
179 @param[in] ImageHandle Handle to the Image (NULL if Internal).
180 @param[in] SystemTable Pointer to the System Table (NULL if Internal).
185 IN EFI_HANDLE ImageHandle
,
186 IN EFI_SYSTEM_TABLE
*SystemTable
190 Function for 'setvar' command.
192 @param[in] ImageHandle Handle to the Image (NULL if Internal).
193 @param[in] SystemTable Pointer to the System Table (NULL if Internal).
197 ShellCommandRunSetVar (
198 IN EFI_HANDLE ImageHandle
,
199 IN EFI_SYSTEM_TABLE
*SystemTable
203 Function for 'sermode' command.
205 @param[in] ImageHandle Handle to the Image (NULL if Internal).
206 @param[in] SystemTable Pointer to the System Table (NULL if Internal).
210 ShellCommandRunSerMode (
211 IN EFI_HANDLE ImageHandle
,
212 IN EFI_SYSTEM_TABLE
*SystemTable
216 Function for 'bcfg' command.
218 @param[in] ImageHandle Handle to the Image (NULL if Internal).
219 @param[in] SystemTable Pointer to the System Table (NULL if Internal).
223 ShellCommandRunBcfg (
224 IN EFI_HANDLE ImageHandle
,
225 IN EFI_SYSTEM_TABLE
*SystemTable
229 Function for 'pci' command.
231 @param[in] ImageHandle Handle to the Image (NULL if Internal).
232 @param[in] SystemTable Pointer to the System Table (NULL if Internal).
237 IN EFI_HANDLE ImageHandle
,
238 IN EFI_SYSTEM_TABLE
*SystemTable
242 Function for 'smbiosview' command.
244 @param[in] ImageHandle Handle to the Image (NULL if Internal).
245 @param[in] SystemTable Pointer to the System Table (NULL if Internal).
249 ShellCommandRunSmbiosView (
250 IN EFI_HANDLE ImageHandle
,
251 IN EFI_SYSTEM_TABLE
*SystemTable
255 Function for 'dmpstore' command.
257 @param[in] ImageHandle Handle to the Image (NULL if Internal).
258 @param[in] SystemTable Pointer to the System Table (NULL if Internal).
262 ShellCommandRunDmpStore (
263 IN EFI_HANDLE ImageHandle
,
264 IN EFI_SYSTEM_TABLE
*SystemTable
268 Function for 'dblk' command.
270 @param[in] ImageHandle Handle to the Image (NULL if Internal).
271 @param[in] SystemTable Pointer to the System Table (NULL if Internal).
275 ShellCommandRunDblk (
276 IN EFI_HANDLE ImageHandle
,
277 IN EFI_SYSTEM_TABLE
*SystemTable
281 Function for 'edit' command.
283 @param[in] ImageHandle Handle to the Image (NULL if Internal).
284 @param[in] SystemTable Pointer to the System Table (NULL if Internal).
288 ShellCommandRunEdit (
289 IN EFI_HANDLE ImageHandle
,
290 IN EFI_SYSTEM_TABLE
*SystemTable
294 Function for 'hexedit' command.
296 @param[in] ImageHandle Handle to the Image (NULL if Internal).
297 @param[in] SystemTable Pointer to the System Table (NULL if Internal).
301 ShellCommandRunHexEdit (
302 IN EFI_HANDLE ImageHandle
,
303 IN EFI_SYSTEM_TABLE
*SystemTable
307 Clear the line at the specified Row.
309 @param[in] Row The row number to be cleared ( start from 1 )
310 @param[in] LastCol The last printable column.
311 @param[in] LastRow The last printable row.
321 Check if file name has illegal characters.
323 @param Name The filename to check.
325 @retval TRUE The filename is ok.
326 @retval FALSE The filename is not ok.
330 IN CONST CHAR16
*Name
334 Find a filename that is valid (not taken) with the given extension.
336 @param[in] Extension The file extension.
338 @retval NULL Something went wrong.
339 @return the valid filename.
342 EditGetDefaultFileName (
343 IN CONST CHAR16
*Extension
347 Read a file into an allocated buffer. The buffer is the responsibility
348 of the caller to free.
350 @param[in] FileName The filename of the file to open.
351 @param[out] Buffer Upon successful return, the pointer to the
352 address of the allocated buffer.
353 @param[out] BufferSize If not NULL, then the pointer to the size
354 of the allocated buffer.
355 @param[out] ReadOnly Upon successful return TRUE if the file is
356 read only. FALSE otherwise.
358 @retval EFI_NOT_FOUND The filename did not represent a file in the
359 file system. Directories cannot be read with
361 @retval EFI_SUCCESS The file was read into the buffer.
362 @retval EFI_OUT_OF_RESOURCES A memory allocation failed.
363 @retval EFI_LOAD_ERROR The file read operation failed.
364 @retval EFI_INVALID_PARAMETER A parameter was invalid.
365 @retval EFI_INVALID_PARAMETER FileName was NULL.
366 @retval EFI_INVALID_PARAMETER FileName was a directory.
370 IN CONST CHAR16
*FileName
,
372 OUT UINTN
*BufferSize OPTIONAL
,
373 OUT BOOLEAN
*ReadOnly