ahdecode.c revision 1.1.1.3.2.1 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.1 skrll * Copyright (C) 2000 - 2015, 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 jruoho /* Local prototypes */
64 1.1 jruoho
65 1.1 jruoho static BOOLEAN
66 1.1 jruoho AhDisplayPredefinedName (
67 1.1 jruoho char *Name,
68 1.1 jruoho UINT32 Length);
69 1.1 jruoho
70 1.1 jruoho static void
71 1.1 jruoho AhDisplayPredefinedInfo (
72 1.1 jruoho char *Name);
73 1.1 jruoho
74 1.1 jruoho static void
75 1.1.1.2 christos AhDisplayResourceName (
76 1.1.1.2 christos const ACPI_PREDEFINED_INFO *ThisName);
77 1.1 jruoho
78 1.1 jruoho static void
79 1.1 jruoho AhDisplayAmlOpcode (
80 1.1 jruoho const AH_AML_OPCODE *Op);
81 1.1 jruoho
82 1.1 jruoho static void
83 1.1 jruoho AhDisplayAslOperator (
84 1.1 jruoho const AH_ASL_OPERATOR *Op);
85 1.1 jruoho
86 1.1 jruoho static void
87 1.1.1.2 christos AhDisplayOperatorKeywords (
88 1.1.1.2 christos const AH_ASL_OPERATOR *Op);
89 1.1.1.2 christos
90 1.1.1.2 christos static void
91 1.1 jruoho AhDisplayAslKeyword (
92 1.1 jruoho const AH_ASL_KEYWORD *Op);
93 1.1 jruoho
94 1.1 jruoho static void
95 1.1 jruoho AhPrintOneField (
96 1.1 jruoho UINT32 Indent,
97 1.1 jruoho UINT32 CurrentPosition,
98 1.1 jruoho UINT32 MaxPosition,
99 1.1 jruoho const char *Field);
100 1.1 jruoho
101 1.1 jruoho
102 1.1 jruoho /*******************************************************************************
103 1.1 jruoho *
104 1.1 jruoho * FUNCTION: AhFindPredefinedNames (entry point for predefined name search)
105 1.1 jruoho *
106 1.1 jruoho * PARAMETERS: NamePrefix - Name or prefix to find. Must start with
107 1.1 jruoho * an underscore. NULL means "find all"
108 1.1 jruoho *
109 1.1 jruoho * RETURN: None
110 1.1 jruoho *
111 1.1 jruoho * DESCRIPTION: Find and display all ACPI predefined names that match the
112 1.1 jruoho * input name or prefix. Includes the required number of arguments
113 1.1 jruoho * and the expected return type, if any.
114 1.1 jruoho *
115 1.1 jruoho ******************************************************************************/
116 1.1 jruoho
117 1.1 jruoho void
118 1.1 jruoho AhFindPredefinedNames (
119 1.1 jruoho char *NamePrefix)
120 1.1 jruoho {
121 1.1 jruoho UINT32 Length;
122 1.1 jruoho BOOLEAN Found;
123 1.1 jruoho char Name[9];
124 1.1 jruoho
125 1.1 jruoho
126 1.1 jruoho if (!NamePrefix)
127 1.1 jruoho {
128 1.1 jruoho Found = AhDisplayPredefinedName (Name, 0);
129 1.1 jruoho return;
130 1.1 jruoho }
131 1.1 jruoho
132 1.1 jruoho /* Contruct a local name or name prefix */
133 1.1 jruoho
134 1.1 jruoho AhStrupr (NamePrefix);
135 1.1 jruoho if (*NamePrefix == '_')
136 1.1 jruoho {
137 1.1 jruoho NamePrefix++;
138 1.1 jruoho }
139 1.1 jruoho
140 1.1 jruoho Name[0] = '_';
141 1.1 jruoho strncpy (&Name[1], NamePrefix, 7);
142 1.1 jruoho
143 1.1 jruoho Length = strlen (Name);
144 1.1 jruoho if (Length > 4)
145 1.1 jruoho {
146 1.1 jruoho printf ("%.8s: Predefined name must be 4 characters maximum\n", Name);
147 1.1 jruoho return;
148 1.1 jruoho }
149 1.1 jruoho
150 1.1 jruoho Found = AhDisplayPredefinedName (Name, Length);
151 1.1 jruoho if (!Found)
152 1.1 jruoho {
153 1.1 jruoho printf ("%s, no matching predefined names\n", Name);
154 1.1 jruoho }
155 1.1 jruoho }
156 1.1 jruoho
157 1.1 jruoho
158 1.1 jruoho /*******************************************************************************
159 1.1 jruoho *
160 1.1 jruoho * FUNCTION: AhDisplayPredefinedName
161 1.1 jruoho *
162 1.1 jruoho * PARAMETERS: Name - Name or name prefix
163 1.1 jruoho *
164 1.1 jruoho * RETURN: TRUE if any names matched, FALSE otherwise
165 1.1 jruoho *
166 1.1 jruoho * DESCRIPTION: Display information about ACPI predefined names that match
167 1.1 jruoho * the input name or name prefix.
168 1.1 jruoho *
169 1.1 jruoho ******************************************************************************/
170 1.1 jruoho
171 1.1 jruoho static BOOLEAN
172 1.1 jruoho AhDisplayPredefinedName (
173 1.1 jruoho char *Name,
174 1.1 jruoho UINT32 Length)
175 1.1 jruoho {
176 1.1 jruoho const AH_PREDEFINED_NAME *Info;
177 1.1 jruoho BOOLEAN Found = FALSE;
178 1.1 jruoho BOOLEAN Matched;
179 1.1 jruoho UINT32 i;
180 1.1 jruoho
181 1.1 jruoho
182 1.1 jruoho /* Find/display all names that match the input name prefix */
183 1.1 jruoho
184 1.1 jruoho for (Info = AslPredefinedInfo; Info->Name; Info++)
185 1.1 jruoho {
186 1.1 jruoho if (!Name)
187 1.1 jruoho {
188 1.1 jruoho Found = TRUE;
189 1.1 jruoho printf ("%s: <%s>\n", Info->Name, Info->Description);
190 1.1 jruoho printf ("%*s%s\n", 6, " ", Info->Action);
191 1.1 jruoho
192 1.1 jruoho AhDisplayPredefinedInfo (Info->Name);
193 1.1 jruoho continue;
194 1.1 jruoho }
195 1.1 jruoho
196 1.1 jruoho Matched = TRUE;
197 1.1 jruoho for (i = 0; i < Length; i++)
198 1.1 jruoho {
199 1.1 jruoho if (Info->Name[i] != Name[i])
200 1.1 jruoho {
201 1.1 jruoho Matched = FALSE;
202 1.1 jruoho break;
203 1.1 jruoho }
204 1.1 jruoho }
205 1.1 jruoho
206 1.1 jruoho if (Matched)
207 1.1 jruoho {
208 1.1 jruoho Found = TRUE;
209 1.1 jruoho printf ("%s: <%s>\n", Info->Name, Info->Description);
210 1.1 jruoho printf ("%*s%s\n", 6, " ", Info->Action);
211 1.1 jruoho
212 1.1 jruoho AhDisplayPredefinedInfo (Info->Name);
213 1.1 jruoho }
214 1.1 jruoho }
215 1.1 jruoho
216 1.1 jruoho return (Found);
217 1.1 jruoho }
218 1.1 jruoho
219 1.1 jruoho
220 1.1 jruoho /*******************************************************************************
221 1.1 jruoho *
222 1.1 jruoho * FUNCTION: AhDisplayPredefinedInfo
223 1.1 jruoho *
224 1.1 jruoho * PARAMETERS: Name - Exact 4-character ACPI name.
225 1.1 jruoho *
226 1.1 jruoho * RETURN: None
227 1.1 jruoho *
228 1.1 jruoho * DESCRIPTION: Find the name in the main ACPICA predefined info table and
229 1.1 jruoho * display the # of arguments and the return value type.
230 1.1 jruoho *
231 1.1 jruoho * Note: Resource Descriptor field names do not appear in this
232 1.1 jruoho * table -- thus, nothing will be displayed for them.
233 1.1 jruoho *
234 1.1 jruoho ******************************************************************************/
235 1.1 jruoho
236 1.1 jruoho static void
237 1.1 jruoho AhDisplayPredefinedInfo (
238 1.1.1.2 christos char *Name)
239 1.1 jruoho {
240 1.1 jruoho const ACPI_PREDEFINED_INFO *ThisName;
241 1.1 jruoho
242 1.1 jruoho
243 1.1.1.2 christos /* NOTE: we check both tables always because there are some dupes */
244 1.1 jruoho
245 1.1.1.2 christos /* Check against the predefine methods first */
246 1.1 jruoho
247 1.1.1.2 christos ThisName = AcpiUtMatchPredefinedMethod (Name);
248 1.1.1.2 christos if (ThisName)
249 1.1.1.2 christos {
250 1.1.1.2 christos AcpiUtDisplayPredefinedMethod (Gbl_Buffer, ThisName, TRUE);
251 1.1.1.2 christos }
252 1.1 jruoho
253 1.1.1.2 christos /* Check against the predefined resource descriptor names */
254 1.1 jruoho
255 1.1.1.2 christos ThisName = AcpiUtMatchResourceName (Name);
256 1.1.1.2 christos if (ThisName)
257 1.1.1.2 christos {
258 1.1.1.2 christos AhDisplayResourceName (ThisName);
259 1.1 jruoho }
260 1.1 jruoho }
261 1.1 jruoho
262 1.1 jruoho
263 1.1 jruoho /*******************************************************************************
264 1.1 jruoho *
265 1.1.1.2 christos * FUNCTION: AhDisplayResourceName
266 1.1 jruoho *
267 1.1.1.2 christos * PARAMETERS: ThisName - Entry in the predefined method/name table
268 1.1 jruoho *
269 1.1.1.2 christos * RETURN: None
270 1.1 jruoho *
271 1.1.1.2 christos * DESCRIPTION: Display information about a resource descriptor name.
272 1.1 jruoho *
273 1.1 jruoho ******************************************************************************/
274 1.1 jruoho
275 1.1 jruoho static void
276 1.1.1.2 christos AhDisplayResourceName (
277 1.1.1.2 christos const ACPI_PREDEFINED_INFO *ThisName)
278 1.1 jruoho {
279 1.1.1.2 christos UINT32 NumTypes;
280 1.1 jruoho
281 1.1 jruoho
282 1.1.1.2 christos NumTypes = AcpiUtGetResourceBitWidth (Gbl_Buffer,
283 1.1.1.2 christos ThisName->Info.ArgumentList);
284 1.1 jruoho
285 1.1.1.2 christos printf (" %4.4s resource descriptor field is %s bits wide%s\n",
286 1.1.1.2 christos ThisName->Info.Name,
287 1.1.1.2 christos Gbl_Buffer,
288 1.1.1.2 christos (NumTypes > 1) ? " (depending on descriptor type)" : "");
289 1.1 jruoho }
290 1.1 jruoho
291 1.1 jruoho
292 1.1 jruoho /*******************************************************************************
293 1.1 jruoho *
294 1.1 jruoho * FUNCTION: AhFindAmlOpcode (entry point for AML opcode name search)
295 1.1 jruoho *
296 1.1 jruoho * PARAMETERS: Name - Name or prefix for an AML opcode.
297 1.1 jruoho * NULL means "find all"
298 1.1 jruoho *
299 1.1 jruoho * RETURN: None
300 1.1 jruoho *
301 1.1 jruoho * DESCRIPTION: Find all AML opcodes that match the input Name or name
302 1.1 jruoho * prefix.
303 1.1 jruoho *
304 1.1 jruoho ******************************************************************************/
305 1.1 jruoho
306 1.1 jruoho void
307 1.1 jruoho AhFindAmlOpcode (
308 1.1 jruoho char *Name)
309 1.1 jruoho {
310 1.1 jruoho const AH_AML_OPCODE *Op;
311 1.1 jruoho BOOLEAN Found = FALSE;
312 1.1 jruoho
313 1.1 jruoho
314 1.1 jruoho AhStrupr (Name);
315 1.1 jruoho
316 1.1 jruoho /* Find/display all opcode names that match the input name prefix */
317 1.1 jruoho
318 1.1 jruoho for (Op = AmlOpcodeInfo; Op->OpcodeString; Op++)
319 1.1 jruoho {
320 1.1 jruoho if (!Op->OpcodeName) /* Unused opcodes */
321 1.1 jruoho {
322 1.1 jruoho continue;
323 1.1 jruoho }
324 1.1 jruoho
325 1.1 jruoho if (!Name)
326 1.1 jruoho {
327 1.1 jruoho AhDisplayAmlOpcode (Op);
328 1.1 jruoho Found = TRUE;
329 1.1 jruoho continue;
330 1.1 jruoho }
331 1.1 jruoho
332 1.1 jruoho /* Upper case the opcode name before substring compare */
333 1.1 jruoho
334 1.1 jruoho strcpy (Gbl_Buffer, Op->OpcodeName);
335 1.1 jruoho AhStrupr (Gbl_Buffer);
336 1.1 jruoho
337 1.1 jruoho if (strstr (Gbl_Buffer, Name) == Gbl_Buffer)
338 1.1 jruoho {
339 1.1 jruoho AhDisplayAmlOpcode (Op);
340 1.1 jruoho Found = TRUE;
341 1.1 jruoho }
342 1.1 jruoho }
343 1.1 jruoho
344 1.1 jruoho if (!Found)
345 1.1 jruoho {
346 1.1 jruoho printf ("%s, no matching AML operators\n", Name);
347 1.1 jruoho }
348 1.1 jruoho }
349 1.1 jruoho
350 1.1 jruoho
351 1.1 jruoho /*******************************************************************************
352 1.1 jruoho *
353 1.1 jruoho * FUNCTION: AhDecodeAmlOpcode (entry point for AML opcode search)
354 1.1 jruoho *
355 1.1 jruoho * PARAMETERS: OpcodeString - String version of AML opcode
356 1.1 jruoho *
357 1.1 jruoho * RETURN: None
358 1.1 jruoho *
359 1.1 jruoho * DESCRIPTION: Display information about the input AML opcode
360 1.1 jruoho *
361 1.1 jruoho ******************************************************************************/
362 1.1 jruoho
363 1.1 jruoho void
364 1.1 jruoho AhDecodeAmlOpcode (
365 1.1 jruoho char *OpcodeString)
366 1.1 jruoho {
367 1.1 jruoho const AH_AML_OPCODE *Op;
368 1.1 jruoho UINT32 Opcode;
369 1.1 jruoho UINT8 Prefix;
370 1.1 jruoho
371 1.1 jruoho
372 1.1 jruoho if (!OpcodeString)
373 1.1 jruoho {
374 1.1 jruoho AhFindAmlOpcode (NULL);
375 1.1 jruoho return;
376 1.1 jruoho }
377 1.1 jruoho
378 1.1 jruoho Opcode = ACPI_STRTOUL (OpcodeString, NULL, 16);
379 1.1 jruoho if (Opcode > ACPI_UINT16_MAX)
380 1.1 jruoho {
381 1.1 jruoho printf ("Invalid opcode (more than 16 bits)\n");
382 1.1 jruoho return;
383 1.1 jruoho }
384 1.1 jruoho
385 1.1 jruoho /* Only valid opcode extension is 0x5B */
386 1.1 jruoho
387 1.1 jruoho Prefix = (Opcode & 0x0000FF00) >> 8;
388 1.1 jruoho if (Prefix && (Prefix != 0x5B))
389 1.1 jruoho {
390 1.1 jruoho printf ("Invalid opcode (invalid extension prefix 0x%X)\n",
391 1.1 jruoho Prefix);
392 1.1 jruoho return;
393 1.1 jruoho }
394 1.1 jruoho
395 1.1 jruoho /* Find/Display the opcode. May fall within an opcode range */
396 1.1 jruoho
397 1.1 jruoho for (Op = AmlOpcodeInfo; Op->OpcodeString; Op++)
398 1.1 jruoho {
399 1.1 jruoho if ((Opcode >= Op->OpcodeRangeStart) &&
400 1.1 jruoho (Opcode <= Op->OpcodeRangeEnd))
401 1.1 jruoho {
402 1.1 jruoho AhDisplayAmlOpcode (Op);
403 1.1 jruoho }
404 1.1 jruoho }
405 1.1 jruoho }
406 1.1 jruoho
407 1.1 jruoho
408 1.1 jruoho /*******************************************************************************
409 1.1 jruoho *
410 1.1 jruoho * FUNCTION: AhDisplayAmlOpcode
411 1.1 jruoho *
412 1.1 jruoho * PARAMETERS: Op - An opcode info struct
413 1.1 jruoho *
414 1.1 jruoho * RETURN: None
415 1.1 jruoho *
416 1.1 jruoho * DESCRIPTION: Display the contents of an AML opcode information struct
417 1.1 jruoho *
418 1.1 jruoho ******************************************************************************/
419 1.1 jruoho
420 1.1 jruoho static void
421 1.1 jruoho AhDisplayAmlOpcode (
422 1.1 jruoho const AH_AML_OPCODE *Op)
423 1.1 jruoho {
424 1.1 jruoho
425 1.1 jruoho if (!Op->OpcodeName)
426 1.1 jruoho {
427 1.1 jruoho printf ("%18s: Opcode=%-9s\n", "Reserved opcode", Op->OpcodeString);
428 1.1 jruoho return;
429 1.1 jruoho }
430 1.1 jruoho
431 1.1 jruoho /* Opcode name and value(s) */
432 1.1 jruoho
433 1.1 jruoho printf ("%18s: Opcode=%-9s Type (%s)",
434 1.1 jruoho Op->OpcodeName, Op->OpcodeString, Op->Type);
435 1.1 jruoho
436 1.1 jruoho /* Optional fixed/static arguments */
437 1.1 jruoho
438 1.1 jruoho if (Op->FixedArguments)
439 1.1 jruoho {
440 1.1 jruoho printf (" FixedArgs (");
441 1.1 jruoho AhPrintOneField (37, 36 + 7 + strlen (Op->Type) + 12,
442 1.1 jruoho AH_MAX_AML_LINE_LENGTH, Op->FixedArguments);
443 1.1 jruoho printf (")");
444 1.1 jruoho }
445 1.1 jruoho
446 1.1 jruoho /* Optional variable-length argument list */
447 1.1 jruoho
448 1.1 jruoho if (Op->VariableArguments)
449 1.1 jruoho {
450 1.1 jruoho if (Op->FixedArguments)
451 1.1 jruoho {
452 1.1 jruoho printf ("\n%*s", 36, " ");
453 1.1 jruoho }
454 1.1 jruoho printf (" VariableArgs (");
455 1.1 jruoho AhPrintOneField (37, 15, AH_MAX_AML_LINE_LENGTH, Op->VariableArguments);
456 1.1 jruoho printf (")");
457 1.1 jruoho }
458 1.1 jruoho printf ("\n");
459 1.1 jruoho
460 1.1 jruoho /* Grammar specification */
461 1.1 jruoho
462 1.1 jruoho if (Op->Grammar)
463 1.1 jruoho {
464 1.1 jruoho AhPrintOneField (37, 0, AH_MAX_AML_LINE_LENGTH, Op->Grammar);
465 1.1 jruoho printf ("\n");
466 1.1 jruoho }
467 1.1 jruoho }
468 1.1 jruoho
469 1.1 jruoho
470 1.1 jruoho /*******************************************************************************
471 1.1 jruoho *
472 1.1 jruoho * FUNCTION: AhFindAslKeywords (entry point for ASL keyword search)
473 1.1 jruoho *
474 1.1 jruoho * PARAMETERS: Name - Name or prefix for an ASL keyword.
475 1.1 jruoho * NULL means "find all"
476 1.1 jruoho *
477 1.1 jruoho * RETURN: None
478 1.1 jruoho *
479 1.1 jruoho * DESCRIPTION: Find all ASL keywords that match the input Name or name
480 1.1 jruoho * prefix.
481 1.1 jruoho *
482 1.1 jruoho ******************************************************************************/
483 1.1 jruoho
484 1.1 jruoho void
485 1.1 jruoho AhFindAslKeywords (
486 1.1 jruoho char *Name)
487 1.1 jruoho {
488 1.1 jruoho const AH_ASL_KEYWORD *Keyword;
489 1.1 jruoho BOOLEAN Found = FALSE;
490 1.1 jruoho
491 1.1 jruoho
492 1.1 jruoho AhStrupr (Name);
493 1.1 jruoho
494 1.1 jruoho for (Keyword = AslKeywordInfo; Keyword->Name; Keyword++)
495 1.1 jruoho {
496 1.1 jruoho if (!Name)
497 1.1 jruoho {
498 1.1 jruoho AhDisplayAslKeyword (Keyword);
499 1.1 jruoho Found = TRUE;
500 1.1 jruoho continue;
501 1.1 jruoho }
502 1.1 jruoho
503 1.1 jruoho /* Upper case the operator name before substring compare */
504 1.1 jruoho
505 1.1 jruoho strcpy (Gbl_Buffer, Keyword->Name);
506 1.1 jruoho AhStrupr (Gbl_Buffer);
507 1.1 jruoho
508 1.1 jruoho if (strstr (Gbl_Buffer, Name) == Gbl_Buffer)
509 1.1 jruoho {
510 1.1 jruoho AhDisplayAslKeyword (Keyword);
511 1.1 jruoho Found = TRUE;
512 1.1 jruoho }
513 1.1 jruoho }
514 1.1 jruoho
515 1.1 jruoho if (!Found)
516 1.1 jruoho {
517 1.1 jruoho printf ("%s, no matching ASL keywords\n", Name);
518 1.1 jruoho }
519 1.1 jruoho }
520 1.1 jruoho
521 1.1 jruoho
522 1.1 jruoho /*******************************************************************************
523 1.1 jruoho *
524 1.1 jruoho * FUNCTION: AhDisplayAslKeyword
525 1.1 jruoho *
526 1.1 jruoho * PARAMETERS: Op - Pointer to ASL keyword with syntax info
527 1.1 jruoho *
528 1.1 jruoho * RETURN: None
529 1.1 jruoho *
530 1.1 jruoho * DESCRIPTION: Format and display syntax info for an ASL keyword. Splits
531 1.1 jruoho * long lines appropriately for reading.
532 1.1 jruoho *
533 1.1 jruoho ******************************************************************************/
534 1.1 jruoho
535 1.1 jruoho static void
536 1.1 jruoho AhDisplayAslKeyword (
537 1.1 jruoho const AH_ASL_KEYWORD *Op)
538 1.1 jruoho {
539 1.1 jruoho
540 1.1 jruoho /* ASL keyword name and description */
541 1.1 jruoho
542 1.1.1.2 christos printf ("%22s: %s\n", Op->Name, Op->Description);
543 1.1 jruoho if (!Op->KeywordList)
544 1.1 jruoho {
545 1.1 jruoho return;
546 1.1 jruoho }
547 1.1 jruoho
548 1.1 jruoho /* List of actual keywords */
549 1.1 jruoho
550 1.1.1.2 christos AhPrintOneField (24, 0, AH_MAX_ASL_LINE_LENGTH, Op->KeywordList);
551 1.1 jruoho printf ("\n");
552 1.1 jruoho }
553 1.1 jruoho
554 1.1 jruoho
555 1.1 jruoho /*******************************************************************************
556 1.1 jruoho *
557 1.1.1.3 christos * FUNCTION: AhFindAslAndAmlOperators
558 1.1 jruoho *
559 1.1 jruoho * PARAMETERS: Name - Name or prefix for an ASL operator.
560 1.1 jruoho * NULL means "find all"
561 1.1 jruoho *
562 1.1 jruoho * RETURN: None
563 1.1 jruoho *
564 1.1 jruoho * DESCRIPTION: Find all ASL operators that match the input Name or name
565 1.1.1.3 christos * prefix. Also displays the AML information if only one entry
566 1.1.1.3 christos * matches.
567 1.1 jruoho *
568 1.1 jruoho ******************************************************************************/
569 1.1 jruoho
570 1.1 jruoho void
571 1.1.1.3 christos AhFindAslAndAmlOperators (
572 1.1.1.3 christos char *Name)
573 1.1.1.3 christos {
574 1.1.1.3 christos UINT32 MatchCount;
575 1.1.1.3 christos
576 1.1.1.3 christos
577 1.1.1.3 christos MatchCount = AhFindAslOperators (Name);
578 1.1.1.3 christos if (MatchCount == 1)
579 1.1.1.3 christos {
580 1.1.1.3 christos AhFindAmlOpcode (Name);
581 1.1.1.3 christos }
582 1.1.1.3 christos }
583 1.1.1.3 christos
584 1.1.1.3 christos
585 1.1.1.3 christos /*******************************************************************************
586 1.1.1.3 christos *
587 1.1.1.3 christos * FUNCTION: AhFindAslOperators (entry point for ASL operator search)
588 1.1.1.3 christos *
589 1.1.1.3 christos * PARAMETERS: Name - Name or prefix for an ASL operator.
590 1.1.1.3 christos * NULL means "find all"
591 1.1.1.3 christos *
592 1.1.1.3 christos * RETURN: Number of operators that matched the name prefix.
593 1.1.1.3 christos *
594 1.1.1.3 christos * DESCRIPTION: Find all ASL operators that match the input Name or name
595 1.1.1.3 christos * prefix.
596 1.1.1.3 christos *
597 1.1.1.3 christos ******************************************************************************/
598 1.1.1.3 christos
599 1.1.1.3 christos UINT32
600 1.1 jruoho AhFindAslOperators (
601 1.1 jruoho char *Name)
602 1.1 jruoho {
603 1.1 jruoho const AH_ASL_OPERATOR *Operator;
604 1.1.1.3 christos BOOLEAN MatchCount = 0;
605 1.1 jruoho
606 1.1 jruoho
607 1.1 jruoho AhStrupr (Name);
608 1.1 jruoho
609 1.1 jruoho /* Find/display all names that match the input name prefix */
610 1.1 jruoho
611 1.1 jruoho for (Operator = AslOperatorInfo; Operator->Name; Operator++)
612 1.1 jruoho {
613 1.1 jruoho if (!Name)
614 1.1 jruoho {
615 1.1 jruoho AhDisplayAslOperator (Operator);
616 1.1.1.3 christos MatchCount++;
617 1.1 jruoho continue;
618 1.1 jruoho }
619 1.1 jruoho
620 1.1 jruoho /* Upper case the operator name before substring compare */
621 1.1 jruoho
622 1.1 jruoho strcpy (Gbl_Buffer, Operator->Name);
623 1.1 jruoho AhStrupr (Gbl_Buffer);
624 1.1 jruoho
625 1.1 jruoho if (strstr (Gbl_Buffer, Name) == Gbl_Buffer)
626 1.1 jruoho {
627 1.1 jruoho AhDisplayAslOperator (Operator);
628 1.1.1.3 christos MatchCount++;
629 1.1 jruoho }
630 1.1 jruoho }
631 1.1 jruoho
632 1.1.1.3 christos if (!MatchCount)
633 1.1 jruoho {
634 1.1 jruoho printf ("%s, no matching ASL operators\n", Name);
635 1.1 jruoho }
636 1.1.1.3 christos
637 1.1.1.3 christos return (MatchCount);
638 1.1 jruoho }
639 1.1 jruoho
640 1.1 jruoho
641 1.1 jruoho /*******************************************************************************
642 1.1 jruoho *
643 1.1 jruoho * FUNCTION: AhDisplayAslOperator
644 1.1 jruoho *
645 1.1 jruoho * PARAMETERS: Op - Pointer to ASL operator with syntax info
646 1.1 jruoho *
647 1.1 jruoho * RETURN: None
648 1.1 jruoho *
649 1.1 jruoho * DESCRIPTION: Format and display syntax info for an ASL operator. Splits
650 1.1 jruoho * long lines appropriately for reading.
651 1.1 jruoho *
652 1.1 jruoho ******************************************************************************/
653 1.1 jruoho
654 1.1 jruoho static void
655 1.1 jruoho AhDisplayAslOperator (
656 1.1 jruoho const AH_ASL_OPERATOR *Op)
657 1.1 jruoho {
658 1.1 jruoho
659 1.1 jruoho /* ASL operator name and description */
660 1.1 jruoho
661 1.1 jruoho printf ("%16s: %s\n", Op->Name, Op->Description);
662 1.1 jruoho if (!Op->Syntax)
663 1.1 jruoho {
664 1.1 jruoho return;
665 1.1 jruoho }
666 1.1 jruoho
667 1.1 jruoho /* Syntax for the operator */
668 1.1 jruoho
669 1.1 jruoho AhPrintOneField (18, 0, AH_MAX_ASL_LINE_LENGTH, Op->Syntax);
670 1.1 jruoho printf ("\n");
671 1.1.1.2 christos
672 1.1.1.2 christos AhDisplayOperatorKeywords (Op);
673 1.1.1.2 christos printf ("\n");
674 1.1.1.2 christos }
675 1.1.1.2 christos
676 1.1.1.2 christos
677 1.1.1.2 christos /*******************************************************************************
678 1.1.1.2 christos *
679 1.1.1.2 christos * FUNCTION: AhDisplayOperatorKeywords
680 1.1.1.2 christos *
681 1.1.1.2 christos * PARAMETERS: Op - Pointer to ASL keyword with syntax info
682 1.1.1.2 christos *
683 1.1.1.2 christos * RETURN: None
684 1.1.1.2 christos *
685 1.1.1.2 christos * DESCRIPTION: Display any/all keywords that are associated with the ASL
686 1.1.1.2 christos * operator.
687 1.1.1.2 christos *
688 1.1.1.2 christos ******************************************************************************/
689 1.1.1.2 christos
690 1.1.1.2 christos static void
691 1.1.1.2 christos AhDisplayOperatorKeywords (
692 1.1.1.2 christos const AH_ASL_OPERATOR *Op)
693 1.1.1.2 christos {
694 1.1.1.2 christos char *Token;
695 1.1.1.2 christos char *Separators = "(){}, ";
696 1.1.1.2 christos BOOLEAN FirstKeyword = TRUE;
697 1.1.1.2 christos
698 1.1.1.2 christos
699 1.1.1.2 christos if (!Op || !Op->Syntax)
700 1.1.1.2 christos {
701 1.1.1.2 christos return;
702 1.1.1.2 christos }
703 1.1.1.2 christos
704 1.1.1.2 christos /*
705 1.1.1.2 christos * Find all parameters that have the word "keyword" within, and then
706 1.1.1.2 christos * display the info about that keyword
707 1.1.1.2 christos */
708 1.1.1.2 christos strcpy (Gbl_LineBuffer, Op->Syntax);
709 1.1.1.2 christos Token = strtok (Gbl_LineBuffer, Separators);
710 1.1.1.2 christos while (Token)
711 1.1.1.2 christos {
712 1.1.1.2 christos if (strstr (Token, "Keyword"))
713 1.1.1.2 christos {
714 1.1.1.2 christos if (FirstKeyword)
715 1.1.1.2 christos {
716 1.1.1.2 christos printf ("\n");
717 1.1.1.2 christos FirstKeyword = FALSE;
718 1.1.1.2 christos }
719 1.1.1.2 christos
720 1.1.1.2 christos /* Found a keyword, display keyword information */
721 1.1.1.2 christos
722 1.1.1.2 christos AhFindAslKeywords (Token);
723 1.1.1.2 christos }
724 1.1.1.2 christos
725 1.1.1.2 christos Token = strtok (NULL, Separators);
726 1.1.1.2 christos }
727 1.1 jruoho }
728 1.1 jruoho
729 1.1 jruoho
730 1.1 jruoho /*******************************************************************************
731 1.1 jruoho *
732 1.1 jruoho * FUNCTION: AhPrintOneField
733 1.1 jruoho *
734 1.1 jruoho * PARAMETERS: Indent - Indent length for new line(s)
735 1.1 jruoho * CurrentPosition - Position on current line
736 1.1 jruoho * MaxPosition - Max allowed line length
737 1.1 jruoho * Field - Data to output
738 1.1 jruoho *
739 1.1 jruoho * RETURN: Line position after field is written
740 1.1 jruoho *
741 1.1 jruoho * DESCRIPTION: Split long lines appropriately for ease of reading.
742 1.1 jruoho *
743 1.1 jruoho ******************************************************************************/
744 1.1 jruoho
745 1.1 jruoho static void
746 1.1 jruoho AhPrintOneField (
747 1.1 jruoho UINT32 Indent,
748 1.1 jruoho UINT32 CurrentPosition,
749 1.1 jruoho UINT32 MaxPosition,
750 1.1 jruoho const char *Field)
751 1.1 jruoho {
752 1.1 jruoho UINT32 Position;
753 1.1 jruoho UINT32 TokenLength;
754 1.1 jruoho const char *This;
755 1.1 jruoho const char *Next;
756 1.1 jruoho const char *Last;
757 1.1 jruoho
758 1.1 jruoho
759 1.1 jruoho This = Field;
760 1.1 jruoho Position = CurrentPosition;
761 1.1 jruoho
762 1.1 jruoho if (Position == 0)
763 1.1 jruoho {
764 1.1 jruoho printf ("%*s", (int) Indent, " ");
765 1.1 jruoho Position = Indent;
766 1.1 jruoho }
767 1.1 jruoho
768 1.1 jruoho Last = This + strlen (This);
769 1.1 jruoho while ((Next = strpbrk (This, " ")))
770 1.1 jruoho {
771 1.1 jruoho TokenLength = Next - This;
772 1.1 jruoho Position += TokenLength;
773 1.1 jruoho
774 1.1 jruoho /* Split long lines */
775 1.1 jruoho
776 1.1 jruoho if (Position > MaxPosition)
777 1.1 jruoho {
778 1.1 jruoho printf ("\n%*s", (int) Indent, " ");
779 1.1 jruoho Position = TokenLength;
780 1.1 jruoho }
781 1.1 jruoho
782 1.1 jruoho printf ("%.*s ", (int) TokenLength, This);
783 1.1 jruoho This = Next + 1;
784 1.1 jruoho }
785 1.1 jruoho
786 1.1 jruoho /* Handle last token on the input line */
787 1.1 jruoho
788 1.1 jruoho TokenLength = Last - This;
789 1.1 jruoho if (TokenLength > 0)
790 1.1 jruoho {
791 1.1 jruoho Position += TokenLength;
792 1.1 jruoho if (Position > MaxPosition)
793 1.1 jruoho {
794 1.1 jruoho printf ("\n%*s", (int) Indent, " ");
795 1.1 jruoho }
796 1.1 jruoho printf ("%s", This);
797 1.1 jruoho }
798 1.1 jruoho }
799 1.1.1.2 christos
800 1.1.1.2 christos
801 1.1.1.2 christos /*******************************************************************************
802 1.1.1.2 christos *
803 1.1.1.2 christos * FUNCTION: AhDisplayDeviceIds
804 1.1.1.2 christos *
805 1.1.1.3 christos * PARAMETERS: Name - Device Hardware ID string.
806 1.1.1.3 christos * NULL means "find all"
807 1.1.1.2 christos *
808 1.1.1.2 christos * RETURN: None
809 1.1.1.2 christos *
810 1.1.1.3 christos * DESCRIPTION: Display PNP* and ACPI* device IDs.
811 1.1.1.2 christos *
812 1.1.1.2 christos ******************************************************************************/
813 1.1.1.2 christos
814 1.1.1.2 christos void
815 1.1.1.2 christos AhDisplayDeviceIds (
816 1.1.1.3 christos char *Name)
817 1.1.1.3 christos {
818 1.1.1.3 christos const AH_DEVICE_ID *Info;
819 1.1.1.3 christos UINT32 Length;
820 1.1.1.3 christos BOOLEAN Matched;
821 1.1.1.3 christos UINT32 i;
822 1.1.1.3 christos BOOLEAN Found = FALSE;
823 1.1.1.3 christos
824 1.1.1.3 christos
825 1.1.1.3 christos /* Null input name indicates "display all" */
826 1.1.1.3 christos
827 1.1.1.3 christos if (!Name)
828 1.1.1.3 christos {
829 1.1.1.3 christos printf ("ACPI and PNP Device/Hardware IDs:\n\n");
830 1.1.1.3 christos for (Info = AslDeviceIds; Info->Name; Info++)
831 1.1.1.3 christos {
832 1.1.1.3 christos printf ("%8s %s\n", Info->Name, Info->Description);
833 1.1.1.3 christos }
834 1.1.1.3 christos
835 1.1.1.3 christos return;
836 1.1.1.3 christos }
837 1.1.1.3 christos
838 1.1.1.3 christos Length = strlen (Name);
839 1.1.1.3 christos if (Length > 8)
840 1.1.1.3 christos {
841 1.1.1.3 christos printf ("%.8s: Hardware ID must be 8 characters maximum\n", Name);
842 1.1.1.3 christos return;
843 1.1.1.3 christos }
844 1.1.1.3 christos
845 1.1.1.3 christos /* Find/display all names that match the input name prefix */
846 1.1.1.3 christos
847 1.1.1.3 christos AhStrupr (Name);
848 1.1.1.3 christos for (Info = AslDeviceIds; Info->Name; Info++)
849 1.1.1.3 christos {
850 1.1.1.3 christos Matched = TRUE;
851 1.1.1.3 christos for (i = 0; i < Length; i++)
852 1.1.1.3 christos {
853 1.1.1.3 christos if (Info->Name[i] != Name[i])
854 1.1.1.3 christos {
855 1.1.1.3 christos Matched = FALSE;
856 1.1.1.3 christos break;
857 1.1.1.3 christos }
858 1.1.1.3 christos }
859 1.1.1.3 christos
860 1.1.1.3 christos if (Matched)
861 1.1.1.3 christos {
862 1.1.1.3 christos Found = TRUE;
863 1.1.1.3 christos printf ("%8s %s\n", Info->Name, Info->Description);
864 1.1.1.3 christos }
865 1.1.1.3 christos }
866 1.1.1.3 christos
867 1.1.1.3 christos if (!Found)
868 1.1.1.3 christos {
869 1.1.1.3 christos printf ("%s, Hardware ID not found\n", Name);
870 1.1.1.3 christos }
871 1.1.1.3 christos }
872 1.1.1.3 christos
873 1.1.1.3 christos
874 1.1.1.3 christos /*******************************************************************************
875 1.1.1.3 christos *
876 1.1.1.3 christos * FUNCTION: AhDisplayUuids
877 1.1.1.3 christos *
878 1.1.1.3 christos * PARAMETERS: None
879 1.1.1.3 christos *
880 1.1.1.3 christos * RETURN: None
881 1.1.1.3 christos *
882 1.1.1.3 christos * DESCRIPTION: Display all known UUIDs.
883 1.1.1.3 christos *
884 1.1.1.3 christos ******************************************************************************/
885 1.1.1.3 christos
886 1.1.1.3 christos void
887 1.1.1.3 christos AhDisplayUuids (
888 1.1.1.2 christos void)
889 1.1.1.2 christos {
890 1.1.1.3 christos const AH_UUID *Info;
891 1.1.1.3 christos
892 1.1.1.2 christos
893 1.1.1.3 christos printf ("ACPI-related UUIDs:\n\n");
894 1.1.1.2 christos
895 1.1.1.3 christos for (Info = AcpiUuids; Info->Description; Info++)
896 1.1.1.2 christos {
897 1.1.1.3 christos printf ("%32s : %s\n", Info->Description, Info->String);
898 1.1.1.2 christos }
899 1.1.1.2 christos }
900 1.1.1.2 christos
901 1.1.1.2 christos
902 1.1.1.2 christos /*******************************************************************************
903 1.1.1.2 christos *
904 1.1.1.2 christos * FUNCTION: AhDecodeException
905 1.1.1.2 christos *
906 1.1.1.2 christos * PARAMETERS: HexString - ACPI status string from command line, in
907 1.1.1.2 christos * hex. If null, display all exceptions.
908 1.1.1.2 christos *
909 1.1.1.2 christos * RETURN: None
910 1.1.1.2 christos *
911 1.1.1.2 christos * DESCRIPTION: Decode and display an ACPI_STATUS exception code.
912 1.1.1.2 christos *
913 1.1.1.2 christos ******************************************************************************/
914 1.1.1.2 christos
915 1.1.1.2 christos void
916 1.1.1.2 christos AhDecodeException (
917 1.1.1.2 christos char *HexString)
918 1.1.1.2 christos {
919 1.1.1.2 christos const ACPI_EXCEPTION_INFO *ExceptionInfo;
920 1.1.1.2 christos UINT32 Status;
921 1.1.1.2 christos UINT32 i;
922 1.1.1.2 christos
923 1.1.1.2 christos
924 1.1.1.2 christos /*
925 1.1.1.2 christos * A null input string means to decode and display all known
926 1.1.1.2 christos * exception codes.
927 1.1.1.2 christos */
928 1.1.1.2 christos if (!HexString)
929 1.1.1.2 christos {
930 1.1.1.2 christos printf ("All defined ACPICA exception codes:\n\n");
931 1.1.1.2 christos AH_DISPLAY_EXCEPTION (0, "AE_OK (No error occurred)");
932 1.1.1.2 christos
933 1.1.1.2 christos /* Display codes in each block of exception types */
934 1.1.1.2 christos
935 1.1.1.2 christos for (i = 1; (i & AE_CODE_MASK) <= AE_CODE_MAX; i += 0x1000)
936 1.1.1.2 christos {
937 1.1.1.2 christos Status = i;
938 1.1.1.2 christos do
939 1.1.1.2 christos {
940 1.1.1.2 christos ExceptionInfo = AcpiUtValidateException ((ACPI_STATUS) Status);
941 1.1.1.2 christos if (ExceptionInfo)
942 1.1.1.2 christos {
943 1.1.1.2 christos AH_DISPLAY_EXCEPTION_TEXT (Status, ExceptionInfo);
944 1.1.1.2 christos }
945 1.1.1.2 christos Status++;
946 1.1.1.2 christos
947 1.1.1.2 christos } while (ExceptionInfo);
948 1.1.1.2 christos }
949 1.1.1.2 christos return;
950 1.1.1.2 christos }
951 1.1.1.2 christos
952 1.1.1.2 christos /* Decode a single user-supplied exception code */
953 1.1.1.2 christos
954 1.1.1.2 christos Status = ACPI_STRTOUL (HexString, NULL, 16);
955 1.1.1.2 christos if (!Status)
956 1.1.1.2 christos {
957 1.1.1.2 christos printf ("%s: Invalid hexadecimal exception code value\n", HexString);
958 1.1.1.2 christos return;
959 1.1.1.2 christos }
960 1.1.1.2 christos
961 1.1.1.2 christos if (Status > ACPI_UINT16_MAX)
962 1.1.1.2 christos {
963 1.1.1.2 christos AH_DISPLAY_EXCEPTION (Status, "Invalid exception code (more than 16 bits)");
964 1.1.1.2 christos return;
965 1.1.1.2 christos }
966 1.1.1.2 christos
967 1.1.1.2 christos ExceptionInfo = AcpiUtValidateException ((ACPI_STATUS) Status);
968 1.1.1.2 christos if (!ExceptionInfo)
969 1.1.1.2 christos {
970 1.1.1.2 christos AH_DISPLAY_EXCEPTION (Status, "Unknown exception code");
971 1.1.1.2 christos return;
972 1.1.1.2 christos }
973 1.1.1.2 christos
974 1.1.1.2 christos AH_DISPLAY_EXCEPTION_TEXT (Status, ExceptionInfo);
975 1.1.1.2 christos }
976