]> git.proxmox.com Git - mirror_edk2.git/blame - ShellPkg/Library/UefiShellDriver1CommandsLib/Disconnect.c
ShellPkg: Fixes and updates for the 'devices' command
[mirror_edk2.git] / ShellPkg / Library / UefiShellDriver1CommandsLib / Disconnect.c
CommitLineData
4ba49616 1/** @file\r
2 Main file for Disconnect shell Driver1 function.\r
3\r
f330ff35 4 Copyright (c) 2010 - 2012, Intel Corporation. All rights reserved.<BR>\r
4ba49616 5 This program and the accompanying materials\r
6 are licensed and made available under the terms and conditions of the BSD License\r
7 which accompanies this distribution. The full text of the license may be found at\r
8 http://opensource.org/licenses/bsd-license.php\r
9\r
10 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
11 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
12\r
13**/\r
14\r
15#include "UefiShellDriver1CommandsLib.h"\r
16\r
17STATIC CONST SHELL_PARAM_ITEM ParamList[] = {\r
18 {L"-r", TypeFlag},\r
19 {NULL, TypeMax}\r
20 };\r
21\r
361a8267 22/**\r
23 Disconnect everything.\r
24\r
25 @retval EFI_SUCCESS The operation was successful.\r
26**/\r
4ba49616 27EFI_STATUS\r
28EFIAPI\r
29DisconnectAll(\r
30 VOID\r
31 )\r
32{\r
33 //\r
34 // Stolen from UEFI 2.3 spec (May 2009 version)\r
35 // Pages 171/172\r
36 // Removed gBS local definition\r
37 //\r
38\r
39 //\r
40 // Disconnect All Handles Example\r
41 // The following example recusively disconnects all drivers from all\r
42 // controllers in a platform.\r
43 //\r
44 EFI_STATUS Status;\r
45// EFI_BOOT_SERVICES *gBS;\r
46 UINTN HandleCount;\r
47 EFI_HANDLE *HandleBuffer;\r
48 UINTN HandleIndex;\r
49 //\r
50 // Retrieve the list of all handles from the handle database\r
51 //\r
52 Status = gBS->LocateHandleBuffer (\r
53 AllHandles,\r
54 NULL,\r
55 NULL,\r
56 &HandleCount,\r
57 &HandleBuffer\r
58 );\r
59 if (!EFI_ERROR (Status)) {\r
60 for (HandleIndex = 0; HandleIndex < HandleCount; HandleIndex++) {\r
61 Status = gBS->DisconnectController (\r
62 HandleBuffer[HandleIndex],\r
63 NULL,\r
64 NULL\r
65 );\r
66 }\r
67 gBS->FreePool(HandleBuffer);\r
68 //\r
69 // end of stealing\r
70 //\r
71 }\r
72 return (EFI_SUCCESS);\r
73}\r
74\r
361a8267 75/**\r
76 Function for 'disconnect' command.\r
77\r
78 @param[in] ImageHandle Handle to the Image (NULL if Internal).\r
79 @param[in] SystemTable Pointer to the System Table (NULL if Internal).\r
80**/\r
4ba49616 81SHELL_STATUS\r
82EFIAPI\r
83ShellCommandRunDisconnect (\r
84 IN EFI_HANDLE ImageHandle,\r
85 IN EFI_SYSTEM_TABLE *SystemTable\r
86 )\r
87{\r
88 EFI_STATUS Status;\r
89 LIST_ENTRY *Package;\r
90 CHAR16 *ProblemParam;\r
91 SHELL_STATUS ShellStatus;\r
92 CONST CHAR16 *Param1;\r
93 CONST CHAR16 *Param2;\r
94 CONST CHAR16 *Param3;\r
95 EFI_HANDLE Handle1;\r
96 EFI_HANDLE Handle2;\r
97 EFI_HANDLE Handle3;\r
361a8267 98 UINT64 Intermediate1;\r
99 UINT64 Intermediate2;\r
100 UINT64 Intermediate3;\r
4ba49616 101\r
102 ShellStatus = SHELL_SUCCESS;\r
103\r
104 //\r
105 // initialize the shell lib (we must be in non-auto-init...)\r
106 //\r
107 Status = ShellInitialize();\r
108 ASSERT_EFI_ERROR(Status);\r
109\r
110 Status = CommandInit();\r
111 ASSERT_EFI_ERROR(Status);\r
112\r
113 //\r
114 // parse the command line\r
115 //\r
116 Status = ShellCommandLineParse (ParamList, &Package, &ProblemParam, TRUE);\r
117 if (EFI_ERROR(Status)) {\r
118 if (Status == EFI_VOLUME_CORRUPTED && ProblemParam != NULL) {\r
119 ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_PROBLEM), gShellDriver1HiiHandle, ProblemParam);\r
120 FreePool(ProblemParam);\r
121 ShellStatus = SHELL_INVALID_PARAMETER;\r
122 } else {\r
123 ASSERT(FALSE);\r
124 }\r
125 } else {\r
126 if (ShellCommandLineGetFlag(Package, L"-r")){\r
127 if (ShellCommandLineGetCount(Package) > 1){\r
128 ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_TOO_MANY), gShellDriver1HiiHandle);\r
129 ShellStatus = SHELL_INVALID_PARAMETER;\r
130 } else if (ShellCommandLineGetCount(Package) < 1) {\r
131 ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_TOO_FEW), gShellDriver1HiiHandle);\r
132 ShellStatus = SHELL_INVALID_PARAMETER;\r
133 } else {\r
134 Status = DisconnectAll();\r
135 }\r
136 } else {\r
137 if (ShellCommandLineGetCount(Package) > 4){\r
138 ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_TOO_MANY), gShellDriver1HiiHandle);\r
139 ShellStatus = SHELL_INVALID_PARAMETER;\r
140 } else if (ShellCommandLineGetCount(Package) < 2) {\r
141 ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_TOO_FEW), gShellDriver1HiiHandle);\r
142 ShellStatus = SHELL_INVALID_PARAMETER;\r
143 } else {\r
144 //\r
145 // must have between 1 and 3 handles passed in ...\r
146 //\r
147 Param1 = ShellCommandLineGetRawValue(Package, 1);\r
148 Param2 = ShellCommandLineGetRawValue(Package, 2);\r
149 Param3 = ShellCommandLineGetRawValue(Package, 3);\r
361a8267 150 ShellConvertStringToUint64(Param1, &Intermediate1, TRUE, FALSE);\r
151 Handle1 = Param1!=NULL?ConvertHandleIndexToHandle((UINTN)Intermediate1):NULL;\r
152 ShellConvertStringToUint64(Param2, &Intermediate2, TRUE, FALSE);\r
153 Handle2 = Param2!=NULL?ConvertHandleIndexToHandle((UINTN)Intermediate2):NULL;\r
154 ShellConvertStringToUint64(Param3, &Intermediate3, TRUE, FALSE);\r
155 Handle3 = Param3!=NULL?ConvertHandleIndexToHandle((UINTN)Intermediate3):NULL;\r
4ba49616 156\r
157 if (Param1 != NULL && Handle1 == NULL) {\r
158 ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_INV_HANDLE), gShellDriver1HiiHandle, Param1);\r
159 ShellStatus = SHELL_INVALID_PARAMETER;\r
160 } else if (Param2 != NULL && Handle2 == NULL) {\r
161 ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_INV_HANDLE), gShellDriver1HiiHandle, Param2);\r
162 ShellStatus = SHELL_INVALID_PARAMETER;\r
163 } else if (Param3 != NULL && Handle3 == NULL) {\r
164 ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_INV_HANDLE), gShellDriver1HiiHandle, Param3);\r
165 ShellStatus = SHELL_INVALID_PARAMETER;\r
4ba49616 166 } else if (Handle2 != NULL && EFI_ERROR(gBS->OpenProtocol(Handle2, &gEfiDriverBindingProtocolGuid, NULL, gImageHandle, NULL, EFI_OPEN_PROTOCOL_TEST_PROTOCOL))) {\r
167 ASSERT(Param2 != NULL);\r
361a8267 168 ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_HANDLE_NOT), gShellDriver1HiiHandle, ShellStrToUintn(Param2), L"driver handle");\r
4ba49616 169 ShellStatus = SHELL_INVALID_PARAMETER;\r
170 } else {\r
171 ASSERT(Param1 != NULL);\r
4ba49616 172 Status = gBS->DisconnectController(Handle1, Handle2, Handle3);\r
6878e7a7 173 ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_3P_RESULT), gShellDriver1HiiHandle, L"Disconnect", (UINTN)Intermediate1, (UINTN)Intermediate2, (UINTN)Intermediate3, Status);\r
4ba49616 174 }\r
175 }\r
176 }\r
177 }\r
178 if (ShellStatus == SHELL_SUCCESS) {\r
179 if (Status == EFI_SECURITY_VIOLATION) {\r
180 ShellStatus = SHELL_SECURITY_VIOLATION;\r
181 } else if (Status == EFI_INVALID_PARAMETER) {\r
182 ShellStatus = SHELL_INVALID_PARAMETER;\r
183 } else if (EFI_ERROR(Status)) {\r
184 ShellStatus = SHELL_NOT_FOUND;\r
185 }\r
186 }\r
187 return (ShellStatus);\r
188}\r