xref: /freebsd/sys/contrib/dev/acpica/components/utilities/utpredef.c (revision 7e00348e7605b9906601438008341ffc37c00e2c)
1 /******************************************************************************
2  *
3  * Module Name: utpredef - support functions for predefined names
4  *
5  *****************************************************************************/
6 
7 /*
8  * Copyright (C) 2000 - 2014, Intel Corp.
9  * All rights reserved.
10  *
11  * Redistribution and use in source and binary forms, with or without
12  * modification, are permitted provided that the following conditions
13  * are met:
14  * 1. Redistributions of source code must retain the above copyright
15  *    notice, this list of conditions, and the following disclaimer,
16  *    without modification.
17  * 2. Redistributions in binary form must reproduce at minimum a disclaimer
18  *    substantially similar to the "NO WARRANTY" disclaimer below
19  *    ("Disclaimer") and any redistribution must be conditioned upon
20  *    including a substantially similar Disclaimer requirement for further
21  *    binary redistribution.
22  * 3. Neither the names of the above-listed copyright holders nor the names
23  *    of any contributors may be used to endorse or promote products derived
24  *    from this software without specific prior written permission.
25  *
26  * Alternatively, this software may be distributed under the terms of the
27  * GNU General Public License ("GPL") version 2 as published by the Free
28  * Software Foundation.
29  *
30  * NO WARRANTY
31  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
32  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
33  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
34  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
35  * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
36  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
37  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
38  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
39  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
40  * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
41  * POSSIBILITY OF SUCH DAMAGES.
42  */
43 
44 #define __UTPREDEF_C__
45 
46 #include <contrib/dev/acpica/include/acpi.h>
47 #include <contrib/dev/acpica/include/accommon.h>
48 #include <contrib/dev/acpica/include/acpredef.h>
49 
50 
51 #define _COMPONENT          ACPI_UTILITIES
52         ACPI_MODULE_NAME    ("utpredef")
53 
54 
55 /*
56  * Names for the types that can be returned by the predefined objects.
57  * Used for warning messages. Must be in the same order as the ACPI_RTYPEs
58  */
59 static const char   *UtRtypeNames[] =
60 {
61     "/Integer",
62     "/String",
63     "/Buffer",
64     "/Package",
65     "/Reference",
66 };
67 
68 
69 /*******************************************************************************
70  *
71  * FUNCTION:    AcpiUtGetNextPredefinedMethod
72  *
73  * PARAMETERS:  ThisName            - Entry in the predefined method/name table
74  *
75  * RETURN:      Pointer to next entry in predefined table.
76  *
77  * DESCRIPTION: Get the next entry in the predefine method table. Handles the
78  *              cases where a package info entry follows a method name that
79  *              returns a package.
80  *
81  ******************************************************************************/
82 
83 const ACPI_PREDEFINED_INFO *
84 AcpiUtGetNextPredefinedMethod (
85     const ACPI_PREDEFINED_INFO  *ThisName)
86 {
87 
88     /*
89      * Skip next entry in the table if this name returns a Package
90      * (next entry contains the package info)
91      */
92     if ((ThisName->Info.ExpectedBtypes & ACPI_RTYPE_PACKAGE) &&
93         (ThisName->Info.ExpectedBtypes != ACPI_RTYPE_ALL))
94     {
95         ThisName++;
96     }
97 
98     ThisName++;
99     return (ThisName);
100 }
101 
102 
103 /*******************************************************************************
104  *
105  * FUNCTION:    AcpiUtMatchPredefinedMethod
106  *
107  * PARAMETERS:  Name                - Name to find
108  *
109  * RETURN:      Pointer to entry in predefined table. NULL indicates not found.
110  *
111  * DESCRIPTION: Check an object name against the predefined object list.
112  *
113  ******************************************************************************/
114 
115 const ACPI_PREDEFINED_INFO *
116 AcpiUtMatchPredefinedMethod (
117     char                        *Name)
118 {
119     const ACPI_PREDEFINED_INFO  *ThisName;
120 
121 
122     /* Quick check for a predefined name, first character must be underscore */
123 
124     if (Name[0] != '_')
125     {
126         return (NULL);
127     }
128 
129     /* Search info table for a predefined method/object name */
130 
131     ThisName = AcpiGbl_PredefinedMethods;
132     while (ThisName->Info.Name[0])
133     {
134         if (ACPI_COMPARE_NAME (Name, ThisName->Info.Name))
135         {
136             return (ThisName);
137         }
138 
139         ThisName = AcpiUtGetNextPredefinedMethod (ThisName);
140     }
141 
142     return (NULL); /* Not found */
143 }
144 
145 
146 /*******************************************************************************
147  *
148  * FUNCTION:    AcpiUtGetExpectedReturnTypes
149  *
150  * PARAMETERS:  Buffer              - Where the formatted string is returned
151  *              ExpectedBTypes      - Bitfield of expected data types
152  *
153  * RETURN:      Formatted string in Buffer.
154  *
155  * DESCRIPTION: Format the expected object types into a printable string.
156  *
157  ******************************************************************************/
158 
159 void
160 AcpiUtGetExpectedReturnTypes (
161     char                    *Buffer,
162     UINT32                  ExpectedBtypes)
163 {
164     UINT32                  ThisRtype;
165     UINT32                  i;
166     UINT32                  j;
167 
168 
169     if (!ExpectedBtypes)
170     {
171         ACPI_STRCPY (Buffer, "NONE");
172         return;
173     }
174 
175     j = 1;
176     Buffer[0] = 0;
177     ThisRtype = ACPI_RTYPE_INTEGER;
178 
179     for (i = 0; i < ACPI_NUM_RTYPES; i++)
180     {
181         /* If one of the expected types, concatenate the name of this type */
182 
183         if (ExpectedBtypes & ThisRtype)
184         {
185             ACPI_STRCAT (Buffer, &UtRtypeNames[i][j]);
186             j = 0;              /* Use name separator from now on */
187         }
188 
189         ThisRtype <<= 1;    /* Next Rtype */
190     }
191 }
192 
193 
194 /*******************************************************************************
195  *
196  * The remaining functions are used by iASL and AcpiHelp only
197  *
198  ******************************************************************************/
199 
200 #if (defined ACPI_ASL_COMPILER || defined ACPI_HELP_APP)
201 #include <stdio.h>
202 #include <string.h>
203 
204 /* Local prototypes */
205 
206 static UINT32
207 AcpiUtGetArgumentTypes (
208     char                    *Buffer,
209     UINT16                  ArgumentTypes);
210 
211 
212 /* Types that can be returned externally by a predefined name */
213 
214 static const char   *UtExternalTypeNames[] = /* Indexed by ACPI_TYPE_* */
215 {
216     ", UNSUPPORTED-TYPE",
217     ", Integer",
218     ", String",
219     ", Buffer",
220     ", Package"
221 };
222 
223 /* Bit widths for resource descriptor predefined names */
224 
225 static const char   *UtResourceTypeNames[] =
226 {
227     "/1",
228     "/2",
229     "/3",
230     "/8",
231     "/16",
232     "/32",
233     "/64",
234     "/variable",
235 };
236 
237 
238 /*******************************************************************************
239  *
240  * FUNCTION:    AcpiUtMatchResourceName
241  *
242  * PARAMETERS:  Name                - Name to find
243  *
244  * RETURN:      Pointer to entry in the resource table. NULL indicates not
245  *              found.
246  *
247  * DESCRIPTION: Check an object name against the predefined resource
248  *              descriptor object list.
249  *
250  ******************************************************************************/
251 
252 const ACPI_PREDEFINED_INFO *
253 AcpiUtMatchResourceName (
254     char                        *Name)
255 {
256     const ACPI_PREDEFINED_INFO  *ThisName;
257 
258 
259     /* Quick check for a predefined name, first character must be underscore */
260 
261     if (Name[0] != '_')
262     {
263         return (NULL);
264     }
265 
266     /* Search info table for a predefined method/object name */
267 
268     ThisName = AcpiGbl_ResourceNames;
269     while (ThisName->Info.Name[0])
270     {
271         if (ACPI_COMPARE_NAME (Name, ThisName->Info.Name))
272         {
273             return (ThisName);
274         }
275 
276         ThisName++;
277     }
278 
279     return (NULL); /* Not found */
280 }
281 
282 
283 /*******************************************************************************
284  *
285  * FUNCTION:    AcpiUtDisplayPredefinedMethod
286  *
287  * PARAMETERS:  Buffer              - Scratch buffer for this function
288  *              ThisName            - Entry in the predefined method/name table
289  *              MultiLine           - TRUE if output should be on >1 line
290  *
291  * RETURN:      None
292  *
293  * DESCRIPTION: Display information about a predefined method. Number and
294  *              type of the input arguments, and expected type(s) for the
295  *              return value, if any.
296  *
297  ******************************************************************************/
298 
299 void
300 AcpiUtDisplayPredefinedMethod (
301     char                        *Buffer,
302     const ACPI_PREDEFINED_INFO  *ThisName,
303     BOOLEAN                     MultiLine)
304 {
305     UINT32                      ArgCount;
306 
307     /*
308      * Get the argument count and the string buffer
309      * containing all argument types
310      */
311     ArgCount = AcpiUtGetArgumentTypes (Buffer,
312         ThisName->Info.ArgumentList);
313 
314     if (MultiLine)
315     {
316         printf ("      ");
317     }
318 
319     printf ("%4.4s    Requires %s%u argument%s",
320         ThisName->Info.Name,
321         (ThisName->Info.ArgumentList & ARG_COUNT_IS_MINIMUM) ?
322             "(at least) " : "",
323         ArgCount, ArgCount != 1 ? "s" : "");
324 
325     /* Display the types for any arguments */
326 
327     if (ArgCount > 0)
328     {
329         printf (" (%s)", Buffer);
330     }
331 
332     if (MultiLine)
333     {
334         printf ("\n    ");
335     }
336 
337     /* Get the return value type(s) allowed */
338 
339     if (ThisName->Info.ExpectedBtypes)
340     {
341         AcpiUtGetExpectedReturnTypes (Buffer, ThisName->Info.ExpectedBtypes);
342         printf ("  Return value types: %s\n", Buffer);
343     }
344     else
345     {
346         printf ("  No return value\n");
347     }
348 }
349 
350 
351 /*******************************************************************************
352  *
353  * FUNCTION:    AcpiUtGetArgumentTypes
354  *
355  * PARAMETERS:  Buffer              - Where to return the formatted types
356  *              ArgumentTypes       - Types field for this method
357  *
358  * RETURN:      Count - the number of arguments required for this method
359  *
360  * DESCRIPTION: Format the required data types for this method (Integer,
361  *              String, Buffer, or Package) and return the required argument
362  *              count.
363  *
364  ******************************************************************************/
365 
366 static UINT32
367 AcpiUtGetArgumentTypes (
368     char                    *Buffer,
369     UINT16                  ArgumentTypes)
370 {
371     UINT16                  ThisArgumentType;
372     UINT16                  SubIndex;
373     UINT16                  ArgCount;
374     UINT32                  i;
375 
376 
377     *Buffer = 0;
378     SubIndex = 2;
379 
380     /* First field in the types list is the count of args to follow */
381 
382     ArgCount = METHOD_GET_ARG_COUNT (ArgumentTypes);
383     if (ArgCount > METHOD_PREDEF_ARGS_MAX)
384     {
385         printf ("**** Invalid argument count (%u) "
386             "in predefined info structure\n", ArgCount);
387         return (ArgCount);
388     }
389 
390     /* Get each argument from the list, convert to ascii, store to buffer */
391 
392     for (i = 0; i < ArgCount; i++)
393     {
394         ThisArgumentType = METHOD_GET_NEXT_TYPE (ArgumentTypes);
395 
396         if (!ThisArgumentType || (ThisArgumentType > METHOD_MAX_ARG_TYPE))
397         {
398             printf ("**** Invalid argument type (%u) "
399                 "in predefined info structure\n", ThisArgumentType);
400             return (ArgCount);
401         }
402 
403         strcat (Buffer, UtExternalTypeNames[ThisArgumentType] + SubIndex);
404         SubIndex = 0;
405     }
406 
407     return (ArgCount);
408 }
409 
410 
411 /*******************************************************************************
412  *
413  * FUNCTION:    AcpiUtGetResourceBitWidth
414  *
415  * PARAMETERS:  Buffer              - Where the formatted string is returned
416  *              Types               - Bitfield of expected data types
417  *
418  * RETURN:      Count of return types. Formatted string in Buffer.
419  *
420  * DESCRIPTION: Format the resource bit widths into a printable string.
421  *
422  ******************************************************************************/
423 
424 UINT32
425 AcpiUtGetResourceBitWidth (
426     char                    *Buffer,
427     UINT16                  Types)
428 {
429     UINT32                  i;
430     UINT16                  SubIndex;
431     UINT32                  Found;
432 
433 
434     *Buffer = 0;
435     SubIndex = 1;
436     Found = 0;
437 
438     for (i = 0; i < NUM_RESOURCE_WIDTHS; i++)
439     {
440         if (Types & 1)
441         {
442             strcat (Buffer, &(UtResourceTypeNames[i][SubIndex]));
443             SubIndex = 0;
444             Found++;
445         }
446 
447         Types >>= 1;
448     }
449 
450     return (Found);
451 }
452 #endif
453