ahdecode.c revision 1.1.1.3.2.4 1 1.1 jruoho /******************************************************************************
2 1.1 jruoho *
3 1.1 jruoho * Module Name: ahdecode - Operator/Opcode decoding for acpihelp utility
4 1.1 jruoho *
5 1.1 jruoho *****************************************************************************/
6 1.1 jruoho
7 1.1 jruoho /*
8 1.1.1.3.2.3 skrll * Copyright (C) 2000 - 2016, Intel Corp.
9 1.1 jruoho * All rights reserved.
10 1.1 jruoho *
11 1.1 jruoho * Redistribution and use in source and binary forms, with or without
12 1.1 jruoho * modification, are permitted provided that the following conditions
13 1.1 jruoho * are met:
14 1.1 jruoho * 1. Redistributions of source code must retain the above copyright
15 1.1 jruoho * notice, this list of conditions, and the following disclaimer,
16 1.1 jruoho * without modification.
17 1.1 jruoho * 2. Redistributions in binary form must reproduce at minimum a disclaimer
18 1.1 jruoho * substantially similar to the "NO WARRANTY" disclaimer below
19 1.1 jruoho * ("Disclaimer") and any redistribution must be conditioned upon
20 1.1 jruoho * including a substantially similar Disclaimer requirement for further
21 1.1 jruoho * binary redistribution.
22 1.1 jruoho * 3. Neither the names of the above-listed copyright holders nor the names
23 1.1 jruoho * of any contributors may be used to endorse or promote products derived
24 1.1 jruoho * from this software without specific prior written permission.
25 1.1 jruoho *
26 1.1 jruoho * Alternatively, this software may be distributed under the terms of the
27 1.1 jruoho * GNU General Public License ("GPL") version 2 as published by the Free
28 1.1 jruoho * Software Foundation.
29 1.1 jruoho *
30 1.1 jruoho * NO WARRANTY
31 1.1 jruoho * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
32 1.1 jruoho * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
33 1.1 jruoho * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
34 1.1 jruoho * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
35 1.1 jruoho * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
36 1.1 jruoho * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
37 1.1 jruoho * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
38 1.1 jruoho * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
39 1.1 jruoho * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
40 1.1 jruoho * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
41 1.1 jruoho * POSSIBILITY OF SUCH DAMAGES.
42 1.1 jruoho */
43 1.1 jruoho
44 1.1 jruoho #define ACPI_CREATE_PREDEFINED_TABLE
45 1.1.1.2 christos #define ACPI_CREATE_RESOURCE_TABLE
46 1.1.1.2 christos
47 1.1.1.2 christos #include "acpihelp.h"
48 1.1 jruoho #include "acpredef.h"
49 1.1 jruoho
50 1.1.1.2 christos
51 1.1.1.2 christos #define AH_DISPLAY_EXCEPTION(Status, Name) \
52 1.1.1.2 christos printf ("%.4X: %s\n", Status, Name)
53 1.1.1.2 christos
54 1.1.1.2 christos #define AH_DISPLAY_EXCEPTION_TEXT(Status, Exception) \
55 1.1.1.2 christos printf ("%.4X: %-28s (%s)\n", Status, Exception->Name, Exception->Description)
56 1.1.1.2 christos
57 1.1.1.2 christos #define BUFFER_LENGTH 128
58 1.1.1.2 christos #define LINE_BUFFER_LENGTH 512
59 1.1.1.2 christos
60 1.1.1.2 christos static char Gbl_Buffer[BUFFER_LENGTH];
61 1.1.1.2 christos static char Gbl_LineBuffer[LINE_BUFFER_LENGTH];
62 1.1 jruoho
63 1.1.1.3.2.2 skrll
64 1.1 jruoho /* Local prototypes */
65 1.1 jruoho
66 1.1 jruoho static BOOLEAN
67 1.1 jruoho AhDisplayPredefinedName (
68 1.1 jruoho char *Name,
69 1.1 jruoho UINT32 Length);
70 1.1 jruoho
71 1.1 jruoho static void
72 1.1 jruoho AhDisplayPredefinedInfo (
73 1.1 jruoho char *Name);
74 1.1 jruoho
75 1.1 jruoho static void
76 1.1.1.2 christos AhDisplayResourceName (
77 1.1.1.2 christos const ACPI_PREDEFINED_INFO *ThisName);
78 1.1 jruoho
79 1.1 jruoho static void
80 1.1 jruoho AhDisplayAmlOpcode (
81 1.1 jruoho const AH_AML_OPCODE *Op);
82 1.1 jruoho
83 1.1 jruoho static void
84 1.1.1.3.2.4 skrll AhDisplayAmlType (
85 1.1.1.3.2.4 skrll const AH_AML_TYPE *Op);
86 1.1.1.3.2.4 skrll
87 1.1.1.3.2.4 skrll static void
88 1.1 jruoho AhDisplayAslOperator (
89 1.1 jruoho const AH_ASL_OPERATOR *Op);
90 1.1 jruoho
91 1.1 jruoho static void
92 1.1.1.2 christos AhDisplayOperatorKeywords (
93 1.1.1.2 christos const AH_ASL_OPERATOR *Op);
94 1.1.1.2 christos
95 1.1.1.2 christos static void
96 1.1 jruoho AhDisplayAslKeyword (
97 1.1 jruoho const AH_ASL_KEYWORD *Op);
98 1.1 jruoho
99 1.1 jruoho static void
100 1.1 jruoho AhPrintOneField (
101 1.1 jruoho UINT32 Indent,
102 1.1 jruoho UINT32 CurrentPosition,
103 1.1 jruoho UINT32 MaxPosition,
104 1.1 jruoho const char *Field);
105 1.1 jruoho
106 1.1 jruoho
107 1.1 jruoho /*******************************************************************************
108 1.1 jruoho *
109 1.1.1.3.2.2 skrll * FUNCTION: AhDisplayDirectives
110 1.1.1.3.2.2 skrll *
111 1.1.1.3.2.2 skrll * PARAMETERS: None
112 1.1.1.3.2.2 skrll *
113 1.1.1.3.2.2 skrll * RETURN: None
114 1.1.1.3.2.2 skrll *
115 1.1.1.3.2.2 skrll * DESCRIPTION: Display all iASL preprocessor directives.
116 1.1.1.3.2.2 skrll *
117 1.1.1.3.2.2 skrll ******************************************************************************/
118 1.1.1.3.2.2 skrll
119 1.1.1.3.2.2 skrll void
120 1.1.1.3.2.2 skrll AhDisplayDirectives (
121 1.1.1.3.2.2 skrll void)
122 1.1.1.3.2.2 skrll {
123 1.1.1.3.2.2 skrll const AH_DIRECTIVE_INFO *Info;
124 1.1.1.3.2.2 skrll
125 1.1.1.3.2.2 skrll
126 1.1.1.3.2.2 skrll printf ("iASL Preprocessor Directives\n\n");
127 1.1.1.3.2.2 skrll
128 1.1.1.3.2.2 skrll for (Info = PreprocessorDirectives; Info->Name; Info++)
129 1.1.1.3.2.2 skrll {
130 1.1.1.3.2.2 skrll printf (" %-36s : %s\n", Info->Name, Info->Description);
131 1.1.1.3.2.2 skrll }
132 1.1.1.3.2.2 skrll }
133 1.1.1.3.2.2 skrll
134 1.1.1.3.2.2 skrll
135 1.1.1.3.2.2 skrll /*******************************************************************************
136 1.1.1.3.2.2 skrll *
137 1.1 jruoho * FUNCTION: AhFindPredefinedNames (entry point for predefined name search)
138 1.1 jruoho *
139 1.1 jruoho * PARAMETERS: NamePrefix - Name or prefix to find. Must start with
140 1.1 jruoho * an underscore. NULL means "find all"
141 1.1 jruoho *
142 1.1 jruoho * RETURN: None
143 1.1 jruoho *
144 1.1 jruoho * DESCRIPTION: Find and display all ACPI predefined names that match the
145 1.1 jruoho * input name or prefix. Includes the required number of arguments
146 1.1 jruoho * and the expected return type, if any.
147 1.1 jruoho *
148 1.1 jruoho ******************************************************************************/
149 1.1 jruoho
150 1.1 jruoho void
151 1.1 jruoho AhFindPredefinedNames (
152 1.1 jruoho char *NamePrefix)
153 1.1 jruoho {
154 1.1 jruoho UINT32 Length;
155 1.1 jruoho BOOLEAN Found;
156 1.1 jruoho char Name[9];
157 1.1 jruoho
158 1.1 jruoho
159 1.1.1.3.2.4 skrll if (!NamePrefix || (NamePrefix[0] == '*'))
160 1.1 jruoho {
161 1.1.1.3.2.2 skrll Found = AhDisplayPredefinedName (NULL, 0);
162 1.1 jruoho return;
163 1.1 jruoho }
164 1.1 jruoho
165 1.1 jruoho /* Contruct a local name or name prefix */
166 1.1 jruoho
167 1.1.1.3.2.2 skrll AcpiUtStrupr (NamePrefix);
168 1.1 jruoho if (*NamePrefix == '_')
169 1.1 jruoho {
170 1.1 jruoho NamePrefix++;
171 1.1 jruoho }
172 1.1 jruoho
173 1.1 jruoho Name[0] = '_';
174 1.1 jruoho strncpy (&Name[1], NamePrefix, 7);
175 1.1 jruoho
176 1.1 jruoho Length = strlen (Name);
177 1.1.1.3.2.3 skrll if (Length > ACPI_NAME_SIZE)
178 1.1 jruoho {
179 1.1 jruoho printf ("%.8s: Predefined name must be 4 characters maximum\n", Name);
180 1.1 jruoho return;
181 1.1 jruoho }
182 1.1 jruoho
183 1.1 jruoho Found = AhDisplayPredefinedName (Name, Length);
184 1.1 jruoho if (!Found)
185 1.1 jruoho {
186 1.1 jruoho printf ("%s, no matching predefined names\n", Name);
187 1.1 jruoho }
188 1.1 jruoho }
189 1.1 jruoho
190 1.1 jruoho
191 1.1 jruoho /*******************************************************************************
192 1.1 jruoho *
193 1.1 jruoho * FUNCTION: AhDisplayPredefinedName
194 1.1 jruoho *
195 1.1 jruoho * PARAMETERS: Name - Name or name prefix
196 1.1 jruoho *
197 1.1 jruoho * RETURN: TRUE if any names matched, FALSE otherwise
198 1.1 jruoho *
199 1.1 jruoho * DESCRIPTION: Display information about ACPI predefined names that match
200 1.1 jruoho * the input name or name prefix.
201 1.1 jruoho *
202 1.1 jruoho ******************************************************************************/
203 1.1 jruoho
204 1.1 jruoho static BOOLEAN
205 1.1 jruoho AhDisplayPredefinedName (
206 1.1 jruoho char *Name,
207 1.1 jruoho UINT32 Length)
208 1.1 jruoho {
209 1.1 jruoho const AH_PREDEFINED_NAME *Info;
210 1.1 jruoho BOOLEAN Found = FALSE;
211 1.1 jruoho BOOLEAN Matched;
212 1.1.1.3.2.2 skrll UINT32 i = 0;
213 1.1 jruoho
214 1.1 jruoho
215 1.1 jruoho /* Find/display all names that match the input name prefix */
216 1.1 jruoho
217 1.1 jruoho for (Info = AslPredefinedInfo; Info->Name; Info++)
218 1.1 jruoho {
219 1.1 jruoho if (!Name)
220 1.1 jruoho {
221 1.1 jruoho Found = TRUE;
222 1.1 jruoho printf ("%s: <%s>\n", Info->Name, Info->Description);
223 1.1 jruoho printf ("%*s%s\n", 6, " ", Info->Action);
224 1.1 jruoho
225 1.1 jruoho AhDisplayPredefinedInfo (Info->Name);
226 1.1.1.3.2.2 skrll i++;
227 1.1 jruoho continue;
228 1.1 jruoho }
229 1.1 jruoho
230 1.1 jruoho Matched = TRUE;
231 1.1 jruoho for (i = 0; i < Length; i++)
232 1.1 jruoho {
233 1.1 jruoho if (Info->Name[i] != Name[i])
234 1.1 jruoho {
235 1.1 jruoho Matched = FALSE;
236 1.1 jruoho break;
237 1.1 jruoho }
238 1.1 jruoho }
239 1.1 jruoho
240 1.1 jruoho if (Matched)
241 1.1 jruoho {
242 1.1 jruoho Found = TRUE;
243 1.1 jruoho printf ("%s: <%s>\n", Info->Name, Info->Description);
244 1.1 jruoho printf ("%*s%s\n", 6, " ", Info->Action);
245 1.1 jruoho
246 1.1 jruoho AhDisplayPredefinedInfo (Info->Name);
247 1.1 jruoho }
248 1.1 jruoho }
249 1.1 jruoho
250 1.1.1.3.2.2 skrll if (!Name)
251 1.1.1.3.2.2 skrll {
252 1.1.1.3.2.2 skrll printf ("\nFound %d Predefined ACPI Names\n", i);
253 1.1.1.3.2.2 skrll }
254 1.1 jruoho return (Found);
255 1.1 jruoho }
256 1.1 jruoho
257 1.1 jruoho
258 1.1 jruoho /*******************************************************************************
259 1.1 jruoho *
260 1.1 jruoho * FUNCTION: AhDisplayPredefinedInfo
261 1.1 jruoho *
262 1.1 jruoho * PARAMETERS: Name - Exact 4-character ACPI name.
263 1.1 jruoho *
264 1.1 jruoho * RETURN: None
265 1.1 jruoho *
266 1.1 jruoho * DESCRIPTION: Find the name in the main ACPICA predefined info table and
267 1.1 jruoho * display the # of arguments and the return value type.
268 1.1 jruoho *
269 1.1 jruoho * Note: Resource Descriptor field names do not appear in this
270 1.1 jruoho * table -- thus, nothing will be displayed for them.
271 1.1 jruoho *
272 1.1 jruoho ******************************************************************************/
273 1.1 jruoho
274 1.1 jruoho static void
275 1.1 jruoho AhDisplayPredefinedInfo (
276 1.1.1.2 christos char *Name)
277 1.1 jruoho {
278 1.1 jruoho const ACPI_PREDEFINED_INFO *ThisName;
279 1.1 jruoho
280 1.1 jruoho
281 1.1.1.2 christos /* NOTE: we check both tables always because there are some dupes */
282 1.1 jruoho
283 1.1.1.2 christos /* Check against the predefine methods first */
284 1.1 jruoho
285 1.1.1.2 christos ThisName = AcpiUtMatchPredefinedMethod (Name);
286 1.1.1.2 christos if (ThisName)
287 1.1.1.2 christos {
288 1.1.1.2 christos AcpiUtDisplayPredefinedMethod (Gbl_Buffer, ThisName, TRUE);
289 1.1.1.2 christos }
290 1.1 jruoho
291 1.1.1.2 christos /* Check against the predefined resource descriptor names */
292 1.1 jruoho
293 1.1.1.2 christos ThisName = AcpiUtMatchResourceName (Name);
294 1.1.1.2 christos if (ThisName)
295 1.1.1.2 christos {
296 1.1.1.2 christos AhDisplayResourceName (ThisName);
297 1.1 jruoho }
298 1.1 jruoho }
299 1.1 jruoho
300 1.1 jruoho
301 1.1 jruoho /*******************************************************************************
302 1.1 jruoho *
303 1.1.1.2 christos * FUNCTION: AhDisplayResourceName
304 1.1 jruoho *
305 1.1.1.2 christos * PARAMETERS: ThisName - Entry in the predefined method/name table
306 1.1 jruoho *
307 1.1.1.2 christos * RETURN: None
308 1.1 jruoho *
309 1.1.1.2 christos * DESCRIPTION: Display information about a resource descriptor name.
310 1.1 jruoho *
311 1.1 jruoho ******************************************************************************/
312 1.1 jruoho
313 1.1 jruoho static void
314 1.1.1.2 christos AhDisplayResourceName (
315 1.1.1.2 christos const ACPI_PREDEFINED_INFO *ThisName)
316 1.1 jruoho {
317 1.1.1.2 christos UINT32 NumTypes;
318 1.1 jruoho
319 1.1 jruoho
320 1.1.1.2 christos NumTypes = AcpiUtGetResourceBitWidth (Gbl_Buffer,
321 1.1.1.2 christos ThisName->Info.ArgumentList);
322 1.1 jruoho
323 1.1.1.2 christos printf (" %4.4s resource descriptor field is %s bits wide%s\n",
324 1.1.1.2 christos ThisName->Info.Name,
325 1.1.1.2 christos Gbl_Buffer,
326 1.1.1.2 christos (NumTypes > 1) ? " (depending on descriptor type)" : "");
327 1.1 jruoho }
328 1.1 jruoho
329 1.1 jruoho
330 1.1 jruoho /*******************************************************************************
331 1.1 jruoho *
332 1.1 jruoho * FUNCTION: AhFindAmlOpcode (entry point for AML opcode name search)
333 1.1 jruoho *
334 1.1 jruoho * PARAMETERS: Name - Name or prefix for an AML opcode.
335 1.1 jruoho * NULL means "find all"
336 1.1 jruoho *
337 1.1 jruoho * RETURN: None
338 1.1 jruoho *
339 1.1 jruoho * DESCRIPTION: Find all AML opcodes that match the input Name or name
340 1.1 jruoho * prefix.
341 1.1 jruoho *
342 1.1 jruoho ******************************************************************************/
343 1.1 jruoho
344 1.1 jruoho void
345 1.1 jruoho AhFindAmlOpcode (
346 1.1 jruoho char *Name)
347 1.1 jruoho {
348 1.1 jruoho const AH_AML_OPCODE *Op;
349 1.1 jruoho BOOLEAN Found = FALSE;
350 1.1 jruoho
351 1.1 jruoho
352 1.1.1.3.2.2 skrll AcpiUtStrupr (Name);
353 1.1 jruoho
354 1.1 jruoho /* Find/display all opcode names that match the input name prefix */
355 1.1 jruoho
356 1.1 jruoho for (Op = AmlOpcodeInfo; Op->OpcodeString; Op++)
357 1.1 jruoho {
358 1.1 jruoho if (!Op->OpcodeName) /* Unused opcodes */
359 1.1 jruoho {
360 1.1 jruoho continue;
361 1.1 jruoho }
362 1.1 jruoho
363 1.1.1.3.2.4 skrll if (!Name || (Name[0] == '*'))
364 1.1 jruoho {
365 1.1 jruoho AhDisplayAmlOpcode (Op);
366 1.1 jruoho Found = TRUE;
367 1.1 jruoho continue;
368 1.1 jruoho }
369 1.1 jruoho
370 1.1 jruoho /* Upper case the opcode name before substring compare */
371 1.1 jruoho
372 1.1 jruoho strcpy (Gbl_Buffer, Op->OpcodeName);
373 1.1.1.3.2.2 skrll AcpiUtStrupr (Gbl_Buffer);
374 1.1 jruoho
375 1.1 jruoho if (strstr (Gbl_Buffer, Name) == Gbl_Buffer)
376 1.1 jruoho {
377 1.1 jruoho AhDisplayAmlOpcode (Op);
378 1.1 jruoho Found = TRUE;
379 1.1 jruoho }
380 1.1 jruoho }
381 1.1 jruoho
382 1.1 jruoho if (!Found)
383 1.1 jruoho {
384 1.1 jruoho printf ("%s, no matching AML operators\n", Name);
385 1.1 jruoho }
386 1.1 jruoho }
387 1.1 jruoho
388 1.1 jruoho
389 1.1 jruoho /*******************************************************************************
390 1.1 jruoho *
391 1.1 jruoho * FUNCTION: AhDecodeAmlOpcode (entry point for AML opcode search)
392 1.1 jruoho *
393 1.1 jruoho * PARAMETERS: OpcodeString - String version of AML opcode
394 1.1 jruoho *
395 1.1 jruoho * RETURN: None
396 1.1 jruoho *
397 1.1 jruoho * DESCRIPTION: Display information about the input AML opcode
398 1.1 jruoho *
399 1.1 jruoho ******************************************************************************/
400 1.1 jruoho
401 1.1 jruoho void
402 1.1 jruoho AhDecodeAmlOpcode (
403 1.1 jruoho char *OpcodeString)
404 1.1 jruoho {
405 1.1 jruoho const AH_AML_OPCODE *Op;
406 1.1 jruoho UINT32 Opcode;
407 1.1 jruoho UINT8 Prefix;
408 1.1 jruoho
409 1.1 jruoho
410 1.1 jruoho if (!OpcodeString)
411 1.1 jruoho {
412 1.1 jruoho AhFindAmlOpcode (NULL);
413 1.1 jruoho return;
414 1.1 jruoho }
415 1.1 jruoho
416 1.1.1.3.2.2 skrll Opcode = strtoul (OpcodeString, NULL, 16);
417 1.1 jruoho if (Opcode > ACPI_UINT16_MAX)
418 1.1 jruoho {
419 1.1 jruoho printf ("Invalid opcode (more than 16 bits)\n");
420 1.1 jruoho return;
421 1.1 jruoho }
422 1.1 jruoho
423 1.1 jruoho /* Only valid opcode extension is 0x5B */
424 1.1 jruoho
425 1.1 jruoho Prefix = (Opcode & 0x0000FF00) >> 8;
426 1.1 jruoho if (Prefix && (Prefix != 0x5B))
427 1.1 jruoho {
428 1.1 jruoho printf ("Invalid opcode (invalid extension prefix 0x%X)\n",
429 1.1 jruoho Prefix);
430 1.1 jruoho return;
431 1.1 jruoho }
432 1.1 jruoho
433 1.1 jruoho /* Find/Display the opcode. May fall within an opcode range */
434 1.1 jruoho
435 1.1 jruoho for (Op = AmlOpcodeInfo; Op->OpcodeString; Op++)
436 1.1 jruoho {
437 1.1 jruoho if ((Opcode >= Op->OpcodeRangeStart) &&
438 1.1 jruoho (Opcode <= Op->OpcodeRangeEnd))
439 1.1 jruoho {
440 1.1 jruoho AhDisplayAmlOpcode (Op);
441 1.1 jruoho }
442 1.1 jruoho }
443 1.1 jruoho }
444 1.1 jruoho
445 1.1 jruoho
446 1.1 jruoho /*******************************************************************************
447 1.1 jruoho *
448 1.1 jruoho * FUNCTION: AhDisplayAmlOpcode
449 1.1 jruoho *
450 1.1 jruoho * PARAMETERS: Op - An opcode info struct
451 1.1 jruoho *
452 1.1 jruoho * RETURN: None
453 1.1 jruoho *
454 1.1 jruoho * DESCRIPTION: Display the contents of an AML opcode information struct
455 1.1 jruoho *
456 1.1 jruoho ******************************************************************************/
457 1.1 jruoho
458 1.1 jruoho static void
459 1.1 jruoho AhDisplayAmlOpcode (
460 1.1 jruoho const AH_AML_OPCODE *Op)
461 1.1 jruoho {
462 1.1 jruoho
463 1.1 jruoho if (!Op->OpcodeName)
464 1.1 jruoho {
465 1.1 jruoho printf ("%18s: Opcode=%-9s\n", "Reserved opcode", Op->OpcodeString);
466 1.1 jruoho return;
467 1.1 jruoho }
468 1.1 jruoho
469 1.1 jruoho /* Opcode name and value(s) */
470 1.1 jruoho
471 1.1 jruoho printf ("%18s: Opcode=%-9s Type (%s)",
472 1.1 jruoho Op->OpcodeName, Op->OpcodeString, Op->Type);
473 1.1 jruoho
474 1.1 jruoho /* Optional fixed/static arguments */
475 1.1 jruoho
476 1.1 jruoho if (Op->FixedArguments)
477 1.1 jruoho {
478 1.1 jruoho printf (" FixedArgs (");
479 1.1 jruoho AhPrintOneField (37, 36 + 7 + strlen (Op->Type) + 12,
480 1.1 jruoho AH_MAX_AML_LINE_LENGTH, Op->FixedArguments);
481 1.1 jruoho printf (")");
482 1.1 jruoho }
483 1.1 jruoho
484 1.1 jruoho /* Optional variable-length argument list */
485 1.1 jruoho
486 1.1 jruoho if (Op->VariableArguments)
487 1.1 jruoho {
488 1.1 jruoho if (Op->FixedArguments)
489 1.1 jruoho {
490 1.1 jruoho printf ("\n%*s", 36, " ");
491 1.1 jruoho }
492 1.1 jruoho printf (" VariableArgs (");
493 1.1 jruoho AhPrintOneField (37, 15, AH_MAX_AML_LINE_LENGTH, Op->VariableArguments);
494 1.1 jruoho printf (")");
495 1.1 jruoho }
496 1.1 jruoho printf ("\n");
497 1.1 jruoho
498 1.1 jruoho /* Grammar specification */
499 1.1 jruoho
500 1.1 jruoho if (Op->Grammar)
501 1.1 jruoho {
502 1.1 jruoho AhPrintOneField (37, 0, AH_MAX_AML_LINE_LENGTH, Op->Grammar);
503 1.1 jruoho printf ("\n");
504 1.1 jruoho }
505 1.1 jruoho }
506 1.1 jruoho
507 1.1 jruoho
508 1.1 jruoho /*******************************************************************************
509 1.1 jruoho *
510 1.1.1.3.2.4 skrll * FUNCTION: AhFindAmlTypes (entry point for AML grammar keyword search)
511 1.1.1.3.2.4 skrll *
512 1.1.1.3.2.4 skrll * PARAMETERS: Name - Name or prefix for an AML grammar element.
513 1.1.1.3.2.4 skrll * NULL means "find all"
514 1.1.1.3.2.4 skrll *
515 1.1.1.3.2.4 skrll * RETURN: None
516 1.1.1.3.2.4 skrll *
517 1.1.1.3.2.4 skrll * DESCRIPTION: Find all AML grammar keywords that match the input Name or name
518 1.1.1.3.2.4 skrll * prefix.
519 1.1.1.3.2.4 skrll *
520 1.1.1.3.2.4 skrll ******************************************************************************/
521 1.1.1.3.2.4 skrll
522 1.1.1.3.2.4 skrll void
523 1.1.1.3.2.4 skrll AhFindAmlTypes (
524 1.1.1.3.2.4 skrll char *Name)
525 1.1.1.3.2.4 skrll {
526 1.1.1.3.2.4 skrll const AH_AML_TYPE *Keyword;
527 1.1.1.3.2.4 skrll BOOLEAN Found = FALSE;
528 1.1.1.3.2.4 skrll
529 1.1.1.3.2.4 skrll
530 1.1.1.3.2.4 skrll AcpiUtStrupr (Name);
531 1.1.1.3.2.4 skrll
532 1.1.1.3.2.4 skrll for (Keyword = AmlTypesInfo; Keyword->Name; Keyword++)
533 1.1.1.3.2.4 skrll {
534 1.1.1.3.2.4 skrll if (!Name)
535 1.1.1.3.2.4 skrll {
536 1.1.1.3.2.4 skrll printf (" %s\n", Keyword->Name);
537 1.1.1.3.2.4 skrll Found = TRUE;
538 1.1.1.3.2.4 skrll continue;
539 1.1.1.3.2.4 skrll }
540 1.1.1.3.2.4 skrll
541 1.1.1.3.2.4 skrll if (*Name == '*')
542 1.1.1.3.2.4 skrll {
543 1.1.1.3.2.4 skrll AhDisplayAmlType (Keyword);
544 1.1.1.3.2.4 skrll Found = TRUE;
545 1.1.1.3.2.4 skrll continue;
546 1.1.1.3.2.4 skrll }
547 1.1.1.3.2.4 skrll
548 1.1.1.3.2.4 skrll /* Upper case the operator name before substring compare */
549 1.1.1.3.2.4 skrll
550 1.1.1.3.2.4 skrll strcpy (Gbl_Buffer, Keyword->Name);
551 1.1.1.3.2.4 skrll AcpiUtStrupr (Gbl_Buffer);
552 1.1.1.3.2.4 skrll
553 1.1.1.3.2.4 skrll if (strstr (Gbl_Buffer, Name) == Gbl_Buffer)
554 1.1.1.3.2.4 skrll {
555 1.1.1.3.2.4 skrll AhDisplayAmlType (Keyword);
556 1.1.1.3.2.4 skrll Found = TRUE;
557 1.1.1.3.2.4 skrll }
558 1.1.1.3.2.4 skrll }
559 1.1.1.3.2.4 skrll
560 1.1.1.3.2.4 skrll if (!Found)
561 1.1.1.3.2.4 skrll {
562 1.1.1.3.2.4 skrll printf ("%s, no matching AML grammar type\n", Name);
563 1.1.1.3.2.4 skrll }
564 1.1.1.3.2.4 skrll }
565 1.1.1.3.2.4 skrll
566 1.1.1.3.2.4 skrll
567 1.1.1.3.2.4 skrll /*******************************************************************************
568 1.1.1.3.2.4 skrll *
569 1.1.1.3.2.4 skrll * FUNCTION: AhDisplayAmlType
570 1.1.1.3.2.4 skrll *
571 1.1.1.3.2.4 skrll * PARAMETERS: Op - Pointer to AML grammar info
572 1.1.1.3.2.4 skrll *
573 1.1.1.3.2.4 skrll * RETURN: None
574 1.1.1.3.2.4 skrll *
575 1.1.1.3.2.4 skrll * DESCRIPTION: Format and display info for an AML grammar element.
576 1.1.1.3.2.4 skrll *
577 1.1.1.3.2.4 skrll ******************************************************************************/
578 1.1.1.3.2.4 skrll
579 1.1.1.3.2.4 skrll static void
580 1.1.1.3.2.4 skrll AhDisplayAmlType (
581 1.1.1.3.2.4 skrll const AH_AML_TYPE *Op)
582 1.1.1.3.2.4 skrll {
583 1.1.1.3.2.4 skrll char *Description;
584 1.1.1.3.2.4 skrll
585 1.1.1.3.2.4 skrll
586 1.1.1.3.2.4 skrll Description = Op->Description;
587 1.1.1.3.2.4 skrll printf ("%4s", " "); /* Primary indent */
588 1.1.1.3.2.4 skrll
589 1.1.1.3.2.4 skrll /* Emit the entire description string */
590 1.1.1.3.2.4 skrll
591 1.1.1.3.2.4 skrll while (*Description)
592 1.1.1.3.2.4 skrll {
593 1.1.1.3.2.4 skrll /* Description can be multiple lines, must indent each */
594 1.1.1.3.2.4 skrll
595 1.1.1.3.2.4 skrll while (*Description != '\n')
596 1.1.1.3.2.4 skrll {
597 1.1.1.3.2.4 skrll printf ("%c", *Description);
598 1.1.1.3.2.4 skrll Description++;
599 1.1.1.3.2.4 skrll }
600 1.1.1.3.2.4 skrll
601 1.1.1.3.2.4 skrll printf ("\n");
602 1.1.1.3.2.4 skrll Description++;
603 1.1.1.3.2.4 skrll
604 1.1.1.3.2.4 skrll /* Do indent */
605 1.1.1.3.2.4 skrll
606 1.1.1.3.2.4 skrll if (*Description)
607 1.1.1.3.2.4 skrll {
608 1.1.1.3.2.4 skrll printf ("%8s", " "); /* Secondary indent */
609 1.1.1.3.2.4 skrll
610 1.1.1.3.2.4 skrll /* Index extra for a comment */
611 1.1.1.3.2.4 skrll
612 1.1.1.3.2.4 skrll if ((Description[0] == '/') &&
613 1.1.1.3.2.4 skrll (Description[1] == '/'))
614 1.1.1.3.2.4 skrll {
615 1.1.1.3.2.4 skrll printf ("%4s", " ");
616 1.1.1.3.2.4 skrll }
617 1.1.1.3.2.4 skrll }
618 1.1.1.3.2.4 skrll }
619 1.1.1.3.2.4 skrll
620 1.1.1.3.2.4 skrll printf ("\n");
621 1.1.1.3.2.4 skrll }
622 1.1.1.3.2.4 skrll
623 1.1.1.3.2.4 skrll
624 1.1.1.3.2.4 skrll /*******************************************************************************
625 1.1.1.3.2.4 skrll *
626 1.1 jruoho * FUNCTION: AhFindAslKeywords (entry point for ASL keyword search)
627 1.1 jruoho *
628 1.1 jruoho * PARAMETERS: Name - Name or prefix for an ASL keyword.
629 1.1 jruoho * NULL means "find all"
630 1.1 jruoho *
631 1.1 jruoho * RETURN: None
632 1.1 jruoho *
633 1.1 jruoho * DESCRIPTION: Find all ASL keywords that match the input Name or name
634 1.1 jruoho * prefix.
635 1.1 jruoho *
636 1.1 jruoho ******************************************************************************/
637 1.1 jruoho
638 1.1 jruoho void
639 1.1 jruoho AhFindAslKeywords (
640 1.1 jruoho char *Name)
641 1.1 jruoho {
642 1.1 jruoho const AH_ASL_KEYWORD *Keyword;
643 1.1 jruoho BOOLEAN Found = FALSE;
644 1.1 jruoho
645 1.1 jruoho
646 1.1.1.3.2.2 skrll AcpiUtStrupr (Name);
647 1.1 jruoho
648 1.1 jruoho for (Keyword = AslKeywordInfo; Keyword->Name; Keyword++)
649 1.1 jruoho {
650 1.1.1.3.2.4 skrll if (!Name || (Name[0] == '*'))
651 1.1 jruoho {
652 1.1 jruoho AhDisplayAslKeyword (Keyword);
653 1.1 jruoho Found = TRUE;
654 1.1 jruoho continue;
655 1.1 jruoho }
656 1.1 jruoho
657 1.1 jruoho /* Upper case the operator name before substring compare */
658 1.1 jruoho
659 1.1 jruoho strcpy (Gbl_Buffer, Keyword->Name);
660 1.1.1.3.2.2 skrll AcpiUtStrupr (Gbl_Buffer);
661 1.1 jruoho
662 1.1 jruoho if (strstr (Gbl_Buffer, Name) == Gbl_Buffer)
663 1.1 jruoho {
664 1.1 jruoho AhDisplayAslKeyword (Keyword);
665 1.1 jruoho Found = TRUE;
666 1.1 jruoho }
667 1.1 jruoho }
668 1.1 jruoho
669 1.1 jruoho if (!Found)
670 1.1 jruoho {
671 1.1 jruoho printf ("%s, no matching ASL keywords\n", Name);
672 1.1 jruoho }
673 1.1 jruoho }
674 1.1 jruoho
675 1.1 jruoho
676 1.1 jruoho /*******************************************************************************
677 1.1 jruoho *
678 1.1 jruoho * FUNCTION: AhDisplayAslKeyword
679 1.1 jruoho *
680 1.1 jruoho * PARAMETERS: Op - Pointer to ASL keyword with syntax info
681 1.1 jruoho *
682 1.1 jruoho * RETURN: None
683 1.1 jruoho *
684 1.1 jruoho * DESCRIPTION: Format and display syntax info for an ASL keyword. Splits
685 1.1 jruoho * long lines appropriately for reading.
686 1.1 jruoho *
687 1.1 jruoho ******************************************************************************/
688 1.1 jruoho
689 1.1 jruoho static void
690 1.1 jruoho AhDisplayAslKeyword (
691 1.1 jruoho const AH_ASL_KEYWORD *Op)
692 1.1 jruoho {
693 1.1 jruoho
694 1.1 jruoho /* ASL keyword name and description */
695 1.1 jruoho
696 1.1.1.2 christos printf ("%22s: %s\n", Op->Name, Op->Description);
697 1.1 jruoho if (!Op->KeywordList)
698 1.1 jruoho {
699 1.1 jruoho return;
700 1.1 jruoho }
701 1.1 jruoho
702 1.1 jruoho /* List of actual keywords */
703 1.1 jruoho
704 1.1.1.2 christos AhPrintOneField (24, 0, AH_MAX_ASL_LINE_LENGTH, Op->KeywordList);
705 1.1 jruoho printf ("\n");
706 1.1 jruoho }
707 1.1 jruoho
708 1.1 jruoho
709 1.1 jruoho /*******************************************************************************
710 1.1 jruoho *
711 1.1.1.3 christos * FUNCTION: AhFindAslAndAmlOperators
712 1.1 jruoho *
713 1.1 jruoho * PARAMETERS: Name - Name or prefix for an ASL operator.
714 1.1 jruoho * NULL means "find all"
715 1.1 jruoho *
716 1.1 jruoho * RETURN: None
717 1.1 jruoho *
718 1.1 jruoho * DESCRIPTION: Find all ASL operators that match the input Name or name
719 1.1.1.3 christos * prefix. Also displays the AML information if only one entry
720 1.1.1.3 christos * matches.
721 1.1 jruoho *
722 1.1 jruoho ******************************************************************************/
723 1.1 jruoho
724 1.1 jruoho void
725 1.1.1.3 christos AhFindAslAndAmlOperators (
726 1.1.1.3 christos char *Name)
727 1.1.1.3 christos {
728 1.1.1.3 christos UINT32 MatchCount;
729 1.1.1.3 christos
730 1.1.1.3 christos
731 1.1.1.3 christos MatchCount = AhFindAslOperators (Name);
732 1.1.1.3 christos if (MatchCount == 1)
733 1.1.1.3 christos {
734 1.1.1.3 christos AhFindAmlOpcode (Name);
735 1.1.1.3 christos }
736 1.1.1.3 christos }
737 1.1.1.3 christos
738 1.1.1.3 christos
739 1.1.1.3 christos /*******************************************************************************
740 1.1.1.3 christos *
741 1.1.1.3 christos * FUNCTION: AhFindAslOperators (entry point for ASL operator search)
742 1.1.1.3 christos *
743 1.1.1.3 christos * PARAMETERS: Name - Name or prefix for an ASL operator.
744 1.1.1.3 christos * NULL means "find all"
745 1.1.1.3 christos *
746 1.1.1.3 christos * RETURN: Number of operators that matched the name prefix.
747 1.1.1.3 christos *
748 1.1.1.3 christos * DESCRIPTION: Find all ASL operators that match the input Name or name
749 1.1.1.3 christos * prefix.
750 1.1.1.3 christos *
751 1.1.1.3 christos ******************************************************************************/
752 1.1.1.3 christos
753 1.1.1.3 christos UINT32
754 1.1 jruoho AhFindAslOperators (
755 1.1 jruoho char *Name)
756 1.1 jruoho {
757 1.1 jruoho const AH_ASL_OPERATOR *Operator;
758 1.1.1.3 christos BOOLEAN MatchCount = 0;
759 1.1 jruoho
760 1.1 jruoho
761 1.1.1.3.2.2 skrll AcpiUtStrupr (Name);
762 1.1 jruoho
763 1.1 jruoho /* Find/display all names that match the input name prefix */
764 1.1 jruoho
765 1.1 jruoho for (Operator = AslOperatorInfo; Operator->Name; Operator++)
766 1.1 jruoho {
767 1.1.1.3.2.4 skrll if (!Name || (Name[0] == '*'))
768 1.1 jruoho {
769 1.1 jruoho AhDisplayAslOperator (Operator);
770 1.1.1.3 christos MatchCount++;
771 1.1 jruoho continue;
772 1.1 jruoho }
773 1.1 jruoho
774 1.1 jruoho /* Upper case the operator name before substring compare */
775 1.1 jruoho
776 1.1 jruoho strcpy (Gbl_Buffer, Operator->Name);
777 1.1.1.3.2.2 skrll AcpiUtStrupr (Gbl_Buffer);
778 1.1 jruoho
779 1.1 jruoho if (strstr (Gbl_Buffer, Name) == Gbl_Buffer)
780 1.1 jruoho {
781 1.1 jruoho AhDisplayAslOperator (Operator);
782 1.1.1.3 christos MatchCount++;
783 1.1 jruoho }
784 1.1 jruoho }
785 1.1 jruoho
786 1.1.1.3 christos if (!MatchCount)
787 1.1 jruoho {
788 1.1 jruoho printf ("%s, no matching ASL operators\n", Name);
789 1.1 jruoho }
790 1.1.1.3 christos
791 1.1.1.3 christos return (MatchCount);
792 1.1 jruoho }
793 1.1 jruoho
794 1.1 jruoho
795 1.1 jruoho /*******************************************************************************
796 1.1 jruoho *
797 1.1 jruoho * FUNCTION: AhDisplayAslOperator
798 1.1 jruoho *
799 1.1 jruoho * PARAMETERS: Op - Pointer to ASL operator with syntax info
800 1.1 jruoho *
801 1.1 jruoho * RETURN: None
802 1.1 jruoho *
803 1.1 jruoho * DESCRIPTION: Format and display syntax info for an ASL operator. Splits
804 1.1 jruoho * long lines appropriately for reading.
805 1.1 jruoho *
806 1.1 jruoho ******************************************************************************/
807 1.1 jruoho
808 1.1 jruoho static void
809 1.1 jruoho AhDisplayAslOperator (
810 1.1 jruoho const AH_ASL_OPERATOR *Op)
811 1.1 jruoho {
812 1.1 jruoho
813 1.1 jruoho /* ASL operator name and description */
814 1.1 jruoho
815 1.1 jruoho printf ("%16s: %s\n", Op->Name, Op->Description);
816 1.1 jruoho if (!Op->Syntax)
817 1.1 jruoho {
818 1.1 jruoho return;
819 1.1 jruoho }
820 1.1 jruoho
821 1.1 jruoho /* Syntax for the operator */
822 1.1 jruoho
823 1.1 jruoho AhPrintOneField (18, 0, AH_MAX_ASL_LINE_LENGTH, Op->Syntax);
824 1.1 jruoho printf ("\n");
825 1.1.1.2 christos
826 1.1.1.2 christos AhDisplayOperatorKeywords (Op);
827 1.1.1.2 christos printf ("\n");
828 1.1.1.2 christos }
829 1.1.1.2 christos
830 1.1.1.2 christos
831 1.1.1.2 christos /*******************************************************************************
832 1.1.1.2 christos *
833 1.1.1.2 christos * FUNCTION: AhDisplayOperatorKeywords
834 1.1.1.2 christos *
835 1.1.1.2 christos * PARAMETERS: Op - Pointer to ASL keyword with syntax info
836 1.1.1.2 christos *
837 1.1.1.2 christos * RETURN: None
838 1.1.1.2 christos *
839 1.1.1.2 christos * DESCRIPTION: Display any/all keywords that are associated with the ASL
840 1.1.1.2 christos * operator.
841 1.1.1.2 christos *
842 1.1.1.2 christos ******************************************************************************/
843 1.1.1.2 christos
844 1.1.1.2 christos static void
845 1.1.1.2 christos AhDisplayOperatorKeywords (
846 1.1.1.2 christos const AH_ASL_OPERATOR *Op)
847 1.1.1.2 christos {
848 1.1.1.2 christos char *Token;
849 1.1.1.2 christos char *Separators = "(){}, ";
850 1.1.1.2 christos BOOLEAN FirstKeyword = TRUE;
851 1.1.1.2 christos
852 1.1.1.2 christos
853 1.1.1.2 christos if (!Op || !Op->Syntax)
854 1.1.1.2 christos {
855 1.1.1.2 christos return;
856 1.1.1.2 christos }
857 1.1.1.2 christos
858 1.1.1.2 christos /*
859 1.1.1.2 christos * Find all parameters that have the word "keyword" within, and then
860 1.1.1.2 christos * display the info about that keyword
861 1.1.1.2 christos */
862 1.1.1.2 christos strcpy (Gbl_LineBuffer, Op->Syntax);
863 1.1.1.2 christos Token = strtok (Gbl_LineBuffer, Separators);
864 1.1.1.2 christos while (Token)
865 1.1.1.2 christos {
866 1.1.1.2 christos if (strstr (Token, "Keyword"))
867 1.1.1.2 christos {
868 1.1.1.2 christos if (FirstKeyword)
869 1.1.1.2 christos {
870 1.1.1.2 christos printf ("\n");
871 1.1.1.2 christos FirstKeyword = FALSE;
872 1.1.1.2 christos }
873 1.1.1.2 christos
874 1.1.1.2 christos /* Found a keyword, display keyword information */
875 1.1.1.2 christos
876 1.1.1.2 christos AhFindAslKeywords (Token);
877 1.1.1.2 christos }
878 1.1.1.2 christos
879 1.1.1.2 christos Token = strtok (NULL, Separators);
880 1.1.1.2 christos }
881 1.1 jruoho }
882 1.1 jruoho
883 1.1 jruoho
884 1.1 jruoho /*******************************************************************************
885 1.1 jruoho *
886 1.1 jruoho * FUNCTION: AhPrintOneField
887 1.1 jruoho *
888 1.1 jruoho * PARAMETERS: Indent - Indent length for new line(s)
889 1.1 jruoho * CurrentPosition - Position on current line
890 1.1 jruoho * MaxPosition - Max allowed line length
891 1.1 jruoho * Field - Data to output
892 1.1 jruoho *
893 1.1 jruoho * RETURN: Line position after field is written
894 1.1 jruoho *
895 1.1 jruoho * DESCRIPTION: Split long lines appropriately for ease of reading.
896 1.1 jruoho *
897 1.1 jruoho ******************************************************************************/
898 1.1 jruoho
899 1.1 jruoho static void
900 1.1 jruoho AhPrintOneField (
901 1.1 jruoho UINT32 Indent,
902 1.1 jruoho UINT32 CurrentPosition,
903 1.1 jruoho UINT32 MaxPosition,
904 1.1 jruoho const char *Field)
905 1.1 jruoho {
906 1.1 jruoho UINT32 Position;
907 1.1 jruoho UINT32 TokenLength;
908 1.1 jruoho const char *This;
909 1.1 jruoho const char *Next;
910 1.1 jruoho const char *Last;
911 1.1 jruoho
912 1.1 jruoho
913 1.1 jruoho This = Field;
914 1.1 jruoho Position = CurrentPosition;
915 1.1 jruoho
916 1.1 jruoho if (Position == 0)
917 1.1 jruoho {
918 1.1 jruoho printf ("%*s", (int) Indent, " ");
919 1.1 jruoho Position = Indent;
920 1.1 jruoho }
921 1.1 jruoho
922 1.1 jruoho Last = This + strlen (This);
923 1.1 jruoho while ((Next = strpbrk (This, " ")))
924 1.1 jruoho {
925 1.1 jruoho TokenLength = Next - This;
926 1.1 jruoho Position += TokenLength;
927 1.1 jruoho
928 1.1 jruoho /* Split long lines */
929 1.1 jruoho
930 1.1 jruoho if (Position > MaxPosition)
931 1.1 jruoho {
932 1.1 jruoho printf ("\n%*s", (int) Indent, " ");
933 1.1 jruoho Position = TokenLength;
934 1.1 jruoho }
935 1.1 jruoho
936 1.1 jruoho printf ("%.*s ", (int) TokenLength, This);
937 1.1 jruoho This = Next + 1;
938 1.1 jruoho }
939 1.1 jruoho
940 1.1 jruoho /* Handle last token on the input line */
941 1.1 jruoho
942 1.1 jruoho TokenLength = Last - This;
943 1.1 jruoho if (TokenLength > 0)
944 1.1 jruoho {
945 1.1 jruoho Position += TokenLength;
946 1.1 jruoho if (Position > MaxPosition)
947 1.1 jruoho {
948 1.1 jruoho printf ("\n%*s", (int) Indent, " ");
949 1.1 jruoho }
950 1.1.1.3.2.3 skrll
951 1.1 jruoho printf ("%s", This);
952 1.1 jruoho }
953 1.1 jruoho }
954 1.1.1.2 christos
955 1.1.1.2 christos
956 1.1.1.2 christos /*******************************************************************************
957 1.1.1.2 christos *
958 1.1.1.2 christos * FUNCTION: AhDisplayDeviceIds
959 1.1.1.2 christos *
960 1.1.1.3 christos * PARAMETERS: Name - Device Hardware ID string.
961 1.1.1.3 christos * NULL means "find all"
962 1.1.1.2 christos *
963 1.1.1.2 christos * RETURN: None
964 1.1.1.2 christos *
965 1.1.1.3 christos * DESCRIPTION: Display PNP* and ACPI* device IDs.
966 1.1.1.2 christos *
967 1.1.1.2 christos ******************************************************************************/
968 1.1.1.2 christos
969 1.1.1.2 christos void
970 1.1.1.2 christos AhDisplayDeviceIds (
971 1.1.1.3 christos char *Name)
972 1.1.1.3 christos {
973 1.1.1.3 christos const AH_DEVICE_ID *Info;
974 1.1.1.3 christos UINT32 Length;
975 1.1.1.3 christos BOOLEAN Matched;
976 1.1.1.3 christos UINT32 i;
977 1.1.1.3 christos BOOLEAN Found = FALSE;
978 1.1.1.3 christos
979 1.1.1.3 christos
980 1.1.1.3 christos /* Null input name indicates "display all" */
981 1.1.1.3 christos
982 1.1.1.3.2.4 skrll if (!Name || (Name[0] == '*'))
983 1.1.1.3 christos {
984 1.1.1.3 christos printf ("ACPI and PNP Device/Hardware IDs:\n\n");
985 1.1.1.3 christos for (Info = AslDeviceIds; Info->Name; Info++)
986 1.1.1.3 christos {
987 1.1.1.3 christos printf ("%8s %s\n", Info->Name, Info->Description);
988 1.1.1.3 christos }
989 1.1.1.3 christos
990 1.1.1.3 christos return;
991 1.1.1.3 christos }
992 1.1.1.3 christos
993 1.1.1.3 christos Length = strlen (Name);
994 1.1.1.3 christos if (Length > 8)
995 1.1.1.3 christos {
996 1.1.1.3 christos printf ("%.8s: Hardware ID must be 8 characters maximum\n", Name);
997 1.1.1.3 christos return;
998 1.1.1.3 christos }
999 1.1.1.3 christos
1000 1.1.1.3 christos /* Find/display all names that match the input name prefix */
1001 1.1.1.3 christos
1002 1.1.1.3.2.2 skrll AcpiUtStrupr (Name);
1003 1.1.1.3 christos for (Info = AslDeviceIds; Info->Name; Info++)
1004 1.1.1.3 christos {
1005 1.1.1.3 christos Matched = TRUE;
1006 1.1.1.3 christos for (i = 0; i < Length; i++)
1007 1.1.1.3 christos {
1008 1.1.1.3 christos if (Info->Name[i] != Name[i])
1009 1.1.1.3 christos {
1010 1.1.1.3 christos Matched = FALSE;
1011 1.1.1.3 christos break;
1012 1.1.1.3 christos }
1013 1.1.1.3 christos }
1014 1.1.1.3 christos
1015 1.1.1.3 christos if (Matched)
1016 1.1.1.3 christos {
1017 1.1.1.3 christos Found = TRUE;
1018 1.1.1.3 christos printf ("%8s %s\n", Info->Name, Info->Description);
1019 1.1.1.3 christos }
1020 1.1.1.3 christos }
1021 1.1.1.3 christos
1022 1.1.1.3 christos if (!Found)
1023 1.1.1.3 christos {
1024 1.1.1.3 christos printf ("%s, Hardware ID not found\n", Name);
1025 1.1.1.3 christos }
1026 1.1.1.3 christos }
1027 1.1.1.3 christos
1028 1.1.1.3 christos
1029 1.1.1.3 christos /*******************************************************************************
1030 1.1.1.3 christos *
1031 1.1.1.3 christos * FUNCTION: AhDisplayUuids
1032 1.1.1.3 christos *
1033 1.1.1.3 christos * PARAMETERS: None
1034 1.1.1.3 christos *
1035 1.1.1.3 christos * RETURN: None
1036 1.1.1.3 christos *
1037 1.1.1.3 christos * DESCRIPTION: Display all known UUIDs.
1038 1.1.1.3 christos *
1039 1.1.1.3 christos ******************************************************************************/
1040 1.1.1.3 christos
1041 1.1.1.3 christos void
1042 1.1.1.3 christos AhDisplayUuids (
1043 1.1.1.2 christos void)
1044 1.1.1.2 christos {
1045 1.1.1.3 christos const AH_UUID *Info;
1046 1.1.1.3 christos
1047 1.1.1.2 christos
1048 1.1.1.3.2.2 skrll printf ("ACPI-related UUIDs/GUIDs:\n");
1049 1.1.1.3.2.2 skrll
1050 1.1.1.3.2.2 skrll /* Display entire table of known ACPI-related UUIDs/GUIDs */
1051 1.1.1.2 christos
1052 1.1.1.3 christos for (Info = AcpiUuids; Info->Description; Info++)
1053 1.1.1.2 christos {
1054 1.1.1.3.2.2 skrll if (!Info->String) /* Null UUID string means group description */
1055 1.1.1.3.2.2 skrll {
1056 1.1.1.3.2.2 skrll printf ("\n%36s\n", Info->Description);
1057 1.1.1.3.2.2 skrll }
1058 1.1.1.3.2.2 skrll else
1059 1.1.1.3.2.2 skrll {
1060 1.1.1.3.2.2 skrll printf ("%32s : %s\n", Info->Description, Info->String);
1061 1.1.1.3.2.2 skrll }
1062 1.1.1.3.2.2 skrll }
1063 1.1.1.3.2.2 skrll
1064 1.1.1.3.2.2 skrll /* Help info on how UUIDs/GUIDs strings are encoded */
1065 1.1.1.3.2.2 skrll
1066 1.1.1.3.2.2 skrll printf ("\n\nByte encoding of UUID/GUID strings"
1067 1.1.1.3.2.2 skrll " into ACPI Buffer objects (use ToUUID from ASL):\n\n");
1068 1.1.1.3.2.2 skrll
1069 1.1.1.3.2.2 skrll printf ("%32s : %s\n", "Input UUID/GUID String format",
1070 1.1.1.3.2.2 skrll "aabbccdd-eeff-gghh-iijj-kkllmmnnoopp");
1071 1.1.1.3.2.2 skrll
1072 1.1.1.3.2.2 skrll printf ("%32s : %s\n", "Expected output ACPI buffer",
1073 1.1.1.3.2.2 skrll "dd,cc,bb,aa, ff,ee, hh,gg, ii,jj, kk,ll,mm,nn,oo,pp");
1074 1.1.1.3.2.2 skrll }
1075 1.1.1.3.2.2 skrll
1076 1.1.1.3.2.2 skrll
1077 1.1.1.3.2.2 skrll /*******************************************************************************
1078 1.1.1.3.2.2 skrll *
1079 1.1.1.3.2.2 skrll * FUNCTION: AhDisplayTables
1080 1.1.1.3.2.2 skrll *
1081 1.1.1.3.2.2 skrll * PARAMETERS: None
1082 1.1.1.3.2.2 skrll *
1083 1.1.1.3.2.2 skrll * RETURN: None
1084 1.1.1.3.2.2 skrll *
1085 1.1.1.3.2.2 skrll * DESCRIPTION: Display all known ACPI tables
1086 1.1.1.3.2.2 skrll *
1087 1.1.1.3.2.2 skrll ******************************************************************************/
1088 1.1.1.3.2.2 skrll
1089 1.1.1.3.2.2 skrll void
1090 1.1.1.3.2.2 skrll AhDisplayTables (
1091 1.1.1.3.2.2 skrll void)
1092 1.1.1.3.2.2 skrll {
1093 1.1.1.3.2.2 skrll const AH_TABLE *Info;
1094 1.1.1.3.2.2 skrll UINT32 i = 0;
1095 1.1.1.3.2.2 skrll
1096 1.1.1.3.2.2 skrll
1097 1.1.1.3.2.2 skrll printf ("Known ACPI tables:\n");
1098 1.1.1.3.2.2 skrll
1099 1.1.1.3.2.2 skrll for (Info = AcpiSupportedTables; Info->Signature; Info++)
1100 1.1.1.3.2.2 skrll {
1101 1.1.1.3.2.2 skrll printf ("%8s : %s\n", Info->Signature, Info->Description);
1102 1.1.1.3.2.2 skrll i++;
1103 1.1.1.2 christos }
1104 1.1.1.3.2.2 skrll
1105 1.1.1.3.2.2 skrll printf ("\nTotal %u ACPI tables\n\n", i);
1106 1.1.1.2 christos }
1107 1.1.1.2 christos
1108 1.1.1.2 christos
1109 1.1.1.2 christos /*******************************************************************************
1110 1.1.1.2 christos *
1111 1.1.1.2 christos * FUNCTION: AhDecodeException
1112 1.1.1.2 christos *
1113 1.1.1.2 christos * PARAMETERS: HexString - ACPI status string from command line, in
1114 1.1.1.2 christos * hex. If null, display all exceptions.
1115 1.1.1.2 christos *
1116 1.1.1.2 christos * RETURN: None
1117 1.1.1.2 christos *
1118 1.1.1.2 christos * DESCRIPTION: Decode and display an ACPI_STATUS exception code.
1119 1.1.1.2 christos *
1120 1.1.1.2 christos ******************************************************************************/
1121 1.1.1.2 christos
1122 1.1.1.2 christos void
1123 1.1.1.2 christos AhDecodeException (
1124 1.1.1.2 christos char *HexString)
1125 1.1.1.2 christos {
1126 1.1.1.2 christos const ACPI_EXCEPTION_INFO *ExceptionInfo;
1127 1.1.1.2 christos UINT32 Status;
1128 1.1.1.2 christos UINT32 i;
1129 1.1.1.2 christos
1130 1.1.1.2 christos
1131 1.1.1.2 christos /*
1132 1.1.1.2 christos * A null input string means to decode and display all known
1133 1.1.1.2 christos * exception codes.
1134 1.1.1.2 christos */
1135 1.1.1.2 christos if (!HexString)
1136 1.1.1.2 christos {
1137 1.1.1.2 christos printf ("All defined ACPICA exception codes:\n\n");
1138 1.1.1.3.2.3 skrll AH_DISPLAY_EXCEPTION (0,
1139 1.1.1.3.2.3 skrll "AE_OK (No error occurred)");
1140 1.1.1.2 christos
1141 1.1.1.2 christos /* Display codes in each block of exception types */
1142 1.1.1.2 christos
1143 1.1.1.2 christos for (i = 1; (i & AE_CODE_MASK) <= AE_CODE_MAX; i += 0x1000)
1144 1.1.1.2 christos {
1145 1.1.1.2 christos Status = i;
1146 1.1.1.2 christos do
1147 1.1.1.2 christos {
1148 1.1.1.2 christos ExceptionInfo = AcpiUtValidateException ((ACPI_STATUS) Status);
1149 1.1.1.2 christos if (ExceptionInfo)
1150 1.1.1.2 christos {
1151 1.1.1.2 christos AH_DISPLAY_EXCEPTION_TEXT (Status, ExceptionInfo);
1152 1.1.1.2 christos }
1153 1.1.1.3.2.3 skrll
1154 1.1.1.2 christos Status++;
1155 1.1.1.2 christos
1156 1.1.1.2 christos } while (ExceptionInfo);
1157 1.1.1.2 christos }
1158 1.1.1.2 christos return;
1159 1.1.1.2 christos }
1160 1.1.1.2 christos
1161 1.1.1.2 christos /* Decode a single user-supplied exception code */
1162 1.1.1.2 christos
1163 1.1.1.3.2.2 skrll Status = strtoul (HexString, NULL, 16);
1164 1.1.1.2 christos if (!Status)
1165 1.1.1.2 christos {
1166 1.1.1.2 christos printf ("%s: Invalid hexadecimal exception code value\n", HexString);
1167 1.1.1.2 christos return;
1168 1.1.1.2 christos }
1169 1.1.1.2 christos
1170 1.1.1.2 christos if (Status > ACPI_UINT16_MAX)
1171 1.1.1.2 christos {
1172 1.1.1.2 christos AH_DISPLAY_EXCEPTION (Status, "Invalid exception code (more than 16 bits)");
1173 1.1.1.2 christos return;
1174 1.1.1.2 christos }
1175 1.1.1.2 christos
1176 1.1.1.2 christos ExceptionInfo = AcpiUtValidateException ((ACPI_STATUS) Status);
1177 1.1.1.2 christos if (!ExceptionInfo)
1178 1.1.1.2 christos {
1179 1.1.1.2 christos AH_DISPLAY_EXCEPTION (Status, "Unknown exception code");
1180 1.1.1.2 christos return;
1181 1.1.1.2 christos }
1182 1.1.1.2 christos
1183 1.1.1.2 christos AH_DISPLAY_EXCEPTION_TEXT (Status, ExceptionInfo);
1184 1.1.1.2 christos }
1185