]> git.proxmox.com Git - mirror_edk2.git/blame - ShellPkg/Library/UefiShellDriver1CommandsLib/DevTree.c
Update return value.
[mirror_edk2.git] / ShellPkg / Library / UefiShellDriver1CommandsLib / DevTree.c
CommitLineData
4ba49616 1/** @file\r
2 Main file for DevTree shell Driver1 function.\r
3\r
4 Copyright (c) 2010, Intel Corporation. All rights reserved.<BR>\r
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"-d", TypeFlag},\r
19 {L"-l", TypeValue},\r
20 {NULL, TypeMax}\r
21 };\r
22\r
23SHELL_STATUS\r
24EFIAPI\r
25DoDevTreeForHandle(\r
26 IN CONST EFI_HANDLE TheHandle,\r
27 IN CONST CHAR8 *Lang OPTIONAL,\r
28 IN CONST BOOLEAN UseDevPaths,\r
29 IN CONST UINTN IndentCharCount,\r
30 IN CONST CHAR16 *HiiString\r
31 )\r
32{\r
33 SHELL_STATUS ShellStatus;\r
34 EFI_STATUS Status;\r
35 CHAR16 *FormatString;\r
36 CHAR16 *Name;\r
37 EFI_HANDLE *ChildHandleBuffer;\r
38 UINTN ChildCount;\r
39 UINTN LoopVar;\r
40\r
41 Status = EFI_SUCCESS;\r
42 ShellStatus = SHELL_SUCCESS;\r
43 Name = NULL;\r
44 ChildHandleBuffer = NULL;\r
45 ChildCount = 0;\r
46\r
47 ASSERT(TheHandle != NULL);\r
48 //\r
49 // We want controller handles. they will not have LoadedImage or DriverBinding (or others...)\r
50 //\r
51 Status = gBS->OpenProtocol (\r
52 TheHandle,\r
53 &gEfiDriverBindingProtocolGuid,\r
54 NULL,\r
55 NULL,\r
56 NULL,\r
57 EFI_OPEN_PROTOCOL_TEST_PROTOCOL\r
58 );\r
59 if (!EFI_ERROR (Status)) {\r
60 return SHELL_SUCCESS;\r
61 }\r
62\r
63 Status = gBS->OpenProtocol (\r
64 TheHandle,\r
65 &gEfiLoadedImageProtocolGuid,\r
66 NULL,\r
67 NULL,\r
68 NULL,\r
69 EFI_OPEN_PROTOCOL_TEST_PROTOCOL\r
70 );\r
71 if (!EFI_ERROR (Status)) {\r
72 return SHELL_SUCCESS;\r
73 }\r
74\r
75 //\r
76 // If we are at the begining then we want root handles they have no parents and do have device path.\r
77 //\r
78 if (IndentCharCount == 0) {\r
79 Status = gBS->OpenProtocol (\r
80 TheHandle,\r
81 &gEfiDevicePathProtocolGuid,\r
82 NULL,\r
83 NULL,\r
84 NULL,\r
85 EFI_OPEN_PROTOCOL_TEST_PROTOCOL\r
86 );\r
87 if (EFI_ERROR (Status)) {\r
88 return SHELL_SUCCESS;\r
89 }\r
90 }\r
91\r
92 FormatString = AllocateZeroPool(StrSize(HiiString) + (10)*sizeof(FormatString[0]));\r
93\r
94 ASSERT(HiiString != NULL);\r
95 ASSERT(FormatString != NULL);\r
96\r
97 //\r
98 // we generate the format string on the fly so that we can control the\r
99 // number of space characters that the first (empty) string has. this\r
100 // handles the indenting.\r
101 //\r
102\r
103 UnicodeSPrint(FormatString, StrSize(HiiString) + (10)*sizeof(FormatString[0]), L"%%%ds %s", IndentCharCount, HiiString);\r
104 gEfiShellProtocol->GetDeviceName((EFI_HANDLE)TheHandle, !UseDevPaths?EFI_DEVICE_NAME_USE_COMPONENT_NAME|EFI_DEVICE_NAME_USE_DEVICE_PATH:EFI_DEVICE_NAME_USE_DEVICE_PATH, (CHAR8*)Lang, &Name);\r
105 //\r
106 // print out the information for ourselves\r
107 //\r
108 ShellPrintEx(\r
109 -1,\r
110 -1,\r
111 FormatString,\r
112 L"",\r
113 ConvertHandleToHandleIndex(TheHandle),\r
114 Name==NULL?L"Unknown":Name);\r
115\r
116 FreePool(FormatString);\r
117 if (Name != NULL) {\r
118 FreePool(Name);\r
119 }\r
120\r
121 //\r
122 // recurse on each child handle with IndentCharCount + 2\r
123 //\r
124 ParseHandleDatabaseForChildControllers(TheHandle, &ChildCount, &ChildHandleBuffer);\r
125 for (LoopVar = 0 ; LoopVar < ChildCount && ShellStatus == SHELL_SUCCESS; LoopVar++){\r
126 ShellStatus = DoDevTreeForHandle(ChildHandleBuffer[LoopVar], Lang, UseDevPaths, IndentCharCount+2, HiiString);\r
127 }\r
128\r
129 if (ChildHandleBuffer != NULL) {\r
130 FreePool(ChildHandleBuffer);\r
131 }\r
132\r
133 return (ShellStatus);\r
134}\r
135\r
136/**\r
137 Function for 'devtree' command.\r
138\r
139 @param[in] ImageHandle Handle to the Image (NULL if Internal).\r
140 @param[in] SystemTable Pointer to the System Table (NULL if Internal).\r
141**/\r
142SHELL_STATUS\r
143EFIAPI\r
144ShellCommandRunDevTree (\r
145 IN EFI_HANDLE ImageHandle,\r
146 IN EFI_SYSTEM_TABLE *SystemTable\r
147 )\r
148{\r
149 EFI_STATUS Status;\r
150 LIST_ENTRY *Package;\r
151 CHAR16 *ProblemParam;\r
152 SHELL_STATUS ShellStatus;\r
153 CHAR8 *Language;\r
154 CONST CHAR16 *Lang;\r
155 CHAR16 *HiiString;\r
156 UINTN LoopVar;\r
157 EFI_HANDLE TheHandle;\r
158 BOOLEAN FlagD;\r
159\r
160 ShellStatus = SHELL_SUCCESS;\r
161 Status = EFI_SUCCESS;\r
162 Language = NULL;\r
163\r
164 //\r
165 // initialize the shell lib (we must be in non-auto-init...)\r
166 //\r
167 Status = ShellInitialize();\r
168 ASSERT_EFI_ERROR(Status);\r
169\r
170 Status = CommandInit();\r
171 ASSERT_EFI_ERROR(Status);\r
172\r
173 //\r
174 // parse the command line\r
175 //\r
176 Status = ShellCommandLineParse (ParamList, &Package, &ProblemParam, TRUE);\r
177 if (EFI_ERROR(Status)) {\r
178 if (Status == EFI_VOLUME_CORRUPTED && ProblemParam != NULL) {\r
179 ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_PROBLEM), gShellDriver1HiiHandle, ProblemParam);\r
180 FreePool(ProblemParam);\r
181 ShellStatus = SHELL_INVALID_PARAMETER;\r
182 } else {\r
183 ASSERT(FALSE);\r
184 }\r
185 } else {\r
186 if (ShellCommandLineGetCount(Package) > 2) {\r
187 ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_TOO_MANY), gShellDriver1HiiHandle);\r
188 ShellCommandLineFreeVarList (Package);\r
189 return (SHELL_INVALID_PARAMETER);\r
190 }\r
191 Lang = ShellCommandLineGetValue(Package, L"-l");\r
192 if (Lang != NULL) {\r
193 Language = AllocateZeroPool(StrSize(Lang));\r
194 AsciiSPrint(Language, StrSize(Lang), "%S", Lang);\r
195 } else if (!ShellCommandLineGetFlag(Package, L"-l")){\r
196 ASSERT(Language == NULL);\r
197// Language = AllocateZeroPool(10);\r
198// AsciiSPrint(Language, 10, "en-us");\r
199 } else {\r
200 ASSERT(Language == NULL);\r
201 ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_NO_VALUE), gShellDriver1HiiHandle, L"-l");\r
202 ShellCommandLineFreeVarList (Package);\r
203 return (SHELL_INVALID_PARAMETER);\r
204 }\r
205 FlagD = ShellCommandLineGetFlag(Package, L"-d");\r
206\r
207 Lang = ShellCommandLineGetRawValue(Package, 1);\r
208 HiiString = HiiGetString(gShellDriver1HiiHandle, STRING_TOKEN (STR_DEV_TREE_OUTPUT), Language);\r
209\r
210 if (Lang == NULL) {\r
211 for (LoopVar = 1 ; ; LoopVar++){\r
212 TheHandle = ConvertHandleIndexToHandle(LoopVar);\r
213 if (TheHandle == NULL){\r
214 break;\r
215 }\r
216 ShellStatus = DoDevTreeForHandle(TheHandle, Language, FlagD, 0, HiiString);\r
217 }\r
218 } else {\r
219 if (!ShellIsHexOrDecimalNumber(Lang, TRUE, FALSE) || ConvertHandleIndexToHandle(StrHexToUintn(Lang)) == NULL) {\r
220 ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_INV_HANDLE), gShellDriver1HiiHandle, Lang);\r
221 ShellStatus = SHELL_INVALID_PARAMETER;\r
222 } else {\r
223 ShellStatus = DoDevTreeForHandle(ConvertHandleIndexToHandle(StrHexToUintn(Lang)), Language, FlagD, 0, HiiString);\r
224 }\r
225 }\r
226\r
227 if (HiiString != NULL) {\r
228 FreePool(HiiString);\r
229 }\r
230 SHELL_FREE_NON_NULL(Language);\r
231 ShellCommandLineFreeVarList (Package);\r
232 }\r
233\r
234 return (ShellStatus);\r
235}\r