]> git.proxmox.com Git - mirror_edk2.git/blame - ShellPkg/Library/UefiShellDriver1CommandsLib/Unload.c
ShellPkg: Apply uncrustify changes
[mirror_edk2.git] / ShellPkg / Library / UefiShellDriver1CommandsLib / Unload.c
CommitLineData
4ba49616 1/** @file\r
2 Main file for Unload shell Driver1 function.\r
3\r
c011b6c9 4 (C) Copyright 2015 Hewlett-Packard Development Company, L.P.<BR>\r
ba0014b9 5 Copyright (c) 2010 - 2018, Intel Corporation. All rights reserved.<BR>\r
56ba3746 6 SPDX-License-Identifier: BSD-2-Clause-Patent\r
4ba49616 7\r
8**/\r
9\r
10#include "UefiShellDriver1CommandsLib.h"\r
11\r
4ba49616 12/**\r
13 Function to dump LoadedImage info from TheHandle.\r
14\r
15 @param[in] TheHandle The handle to dump info from.\r
16\r
17 @retval EFI_SUCCESS The info was dumped.\r
18 @retval EFI_INVALID_PARAMETER The handle did not have LoadedImage\r
19**/\r
20EFI_STATUS\r
4ba49616 21DumpLoadedImageProtocolInfo (\r
47d20b54 22 IN EFI_HANDLE TheHandle\r
4ba49616 23 )\r
24{\r
47d20b54 25 CHAR16 *TheString;\r
4ba49616 26\r
47d20b54 27 TheString = GetProtocolInformationDump (TheHandle, &gEfiLoadedImageProtocolGuid, TRUE);\r
ba0014b9 28\r
47d20b54 29 ShellPrintEx (-1, -1, L"%s", TheString);\r
4ba49616 30\r
47d20b54 31 SHELL_FREE_NON_NULL (TheString);\r
ba0014b9 32\r
4ba49616 33 return (EFI_SUCCESS);\r
34}\r
35\r
47d20b54
MK
36STATIC CONST SHELL_PARAM_ITEM ParamList[] = {\r
37 { L"-n", TypeFlag },\r
38 { L"-v", TypeFlag },\r
39 { L"-verbose", TypeFlag },\r
40 { NULL, TypeMax }\r
41};\r
4ba49616 42\r
43/**\r
44 Function for 'unload' command.\r
45\r
46 @param[in] ImageHandle Handle to the Image (NULL if Internal).\r
47 @param[in] SystemTable Pointer to the System Table (NULL if Internal).\r
48**/\r
49SHELL_STATUS\r
50EFIAPI\r
51ShellCommandRunUnload (\r
52 IN EFI_HANDLE ImageHandle,\r
53 IN EFI_SYSTEM_TABLE *SystemTable\r
54 )\r
55{\r
47d20b54
MK
56 EFI_STATUS Status;\r
57 LIST_ENTRY *Package;\r
58 CHAR16 *ProblemParam;\r
59 SHELL_STATUS ShellStatus;\r
60 EFI_HANDLE TheHandle;\r
61 CONST CHAR16 *Param1;\r
62 SHELL_PROMPT_RESPONSE *Resp;\r
63 UINT64 Value;\r
64\r
65 ShellStatus = SHELL_SUCCESS;\r
66 Package = NULL;\r
67 Resp = NULL;\r
68 Value = 0;\r
69 TheHandle = NULL;\r
4ba49616 70\r
71 //\r
72 // initialize the shell lib (we must be in non-auto-init...)\r
73 //\r
47d20b54
MK
74 Status = ShellInitialize ();\r
75 ASSERT_EFI_ERROR (Status);\r
4ba49616 76\r
77 //\r
78 // parse the command line\r
79 //\r
80 Status = ShellCommandLineParse (ParamList, &Package, &ProblemParam, TRUE);\r
47d20b54
MK
81 if (EFI_ERROR (Status)) {\r
82 if ((Status == EFI_VOLUME_CORRUPTED) && (ProblemParam != NULL)) {\r
83 ShellPrintHiiEx (-1, -1, NULL, STRING_TOKEN (STR_GEN_PROBLEM), gShellDriver1HiiHandle, L"unload", ProblemParam);\r
84 FreePool (ProblemParam);\r
4ba49616 85 ShellStatus = SHELL_INVALID_PARAMETER;\r
86 } else {\r
47d20b54 87 ASSERT (FALSE);\r
4ba49616 88 }\r
89 } else {\r
47d20b54 90 if (ShellCommandLineGetCount (Package) > 2) {\r
4ba49616 91 //\r
92 // error for too many parameters\r
93 //\r
47d20b54 94 ShellPrintHiiEx (-1, -1, NULL, STRING_TOKEN (STR_GEN_TOO_MANY), gShellDriver1HiiHandle, L"unload");\r
4ba49616 95 ShellStatus = SHELL_INVALID_PARAMETER;\r
47d20b54
MK
96 } else if (ShellCommandLineGetCount (Package) < 2) {\r
97 ShellPrintHiiEx (-1, -1, NULL, STRING_TOKEN (STR_GEN_TOO_FEW), gShellDriver1HiiHandle, L"unload");\r
4ba49616 98 ShellStatus = SHELL_INVALID_PARAMETER;\r
99 } else {\r
47d20b54 100 Param1 = ShellCommandLineGetRawValue (Package, 1);\r
361a8267 101 if (Param1 != NULL) {\r
47d20b54
MK
102 Status = ShellConvertStringToUint64 (Param1, &Value, TRUE, FALSE);\r
103 TheHandle = ConvertHandleIndexToHandle ((UINTN)Value);\r
361a8267 104 }\r
105\r
47d20b54
MK
106 if (EFI_ERROR (Status) || (Param1 == NULL) || (TheHandle == NULL)) {\r
107 ShellPrintHiiEx (-1, -1, NULL, STRING_TOKEN (STR_GEN_INV_HANDLE), gShellDriver1HiiHandle, L"unload", Param1);\r
4ba49616 108 ShellStatus = SHELL_INVALID_PARAMETER;\r
109 } else {\r
47d20b54
MK
110 ASSERT (TheHandle != NULL);\r
111 if (ShellCommandLineGetFlag (Package, L"-v") || ShellCommandLineGetFlag (Package, L"-verbose")) {\r
112 DumpLoadedImageProtocolInfo (TheHandle);\r
4ba49616 113 }\r
ba0014b9 114\r
47d20b54
MK
115 if (!ShellCommandLineGetFlag (Package, L"-n")) {\r
116 Status = ShellPrintHiiEx (-1, -1, NULL, STRING_TOKEN (STR_UNLOAD_CONF), gShellDriver1HiiHandle, (UINTN)TheHandle);\r
117 Status = ShellPromptForResponse (ShellPromptResponseTypeYesNo, NULL, (VOID **)&Resp);\r
4ba49616 118 }\r
47d20b54
MK
119\r
120 if (ShellCommandLineGetFlag (Package, L"-n") || ((Resp != NULL) && (*Resp == ShellPromptResponseYes))) {\r
121 Status = gBS->UnloadImage (TheHandle);\r
122 ShellPrintHiiEx (-1, -1, NULL, STRING_TOKEN (STR_HANDLE_RESULT), gShellDriver1HiiHandle, L"Unload", (UINTN)TheHandle, Status);\r
4ba49616 123 }\r
47d20b54
MK
124\r
125 SHELL_FREE_NON_NULL (Resp);\r
4ba49616 126 }\r
127 }\r
128 }\r
47d20b54 129\r
4ba49616 130 if (ShellStatus == SHELL_SUCCESS) {\r
131 if (Status == EFI_SECURITY_VIOLATION) {\r
132 ShellStatus = SHELL_SECURITY_VIOLATION;\r
133 } else if (Status == EFI_INVALID_PARAMETER) {\r
134 ShellStatus = SHELL_INVALID_PARAMETER;\r
47d20b54 135 } else if (EFI_ERROR (Status)) {\r
4ba49616 136 ShellStatus = SHELL_NOT_FOUND;\r
137 }\r
138 }\r
139\r
140 if (Package != NULL) {\r
47d20b54 141 ShellCommandLineFreeVarList (Package);\r
4ba49616 142 }\r
143\r
144 return (ShellStatus);\r
145}\r