xref: /freebsd-src/sys/contrib/dev/acpica/compiler/aslnamesp.c (revision 804fe2660352e090f4481f2c1d646b508859e79a)
1efcc2a30SJung-uk Kim /******************************************************************************
2efcc2a30SJung-uk Kim  *
3efcc2a30SJung-uk Kim  * Module Name: aslnamesp - Namespace output file generation
4efcc2a30SJung-uk Kim  *
5efcc2a30SJung-uk Kim  *****************************************************************************/
6efcc2a30SJung-uk Kim 
70d84335fSJung-uk Kim /******************************************************************************
80d84335fSJung-uk Kim  *
90d84335fSJung-uk Kim  * 1. Copyright Notice
100d84335fSJung-uk Kim  *
11*804fe266SJung-uk Kim  * Some or all of this work - Copyright (c) 1999 - 2024, Intel Corp.
12efcc2a30SJung-uk Kim  * All rights reserved.
13efcc2a30SJung-uk Kim  *
140d84335fSJung-uk Kim  * 2. License
150d84335fSJung-uk Kim  *
160d84335fSJung-uk Kim  * 2.1. This is your license from Intel Corp. under its intellectual property
170d84335fSJung-uk Kim  * rights. You may have additional license terms from the party that provided
180d84335fSJung-uk Kim  * you this software, covering your right to use that party's intellectual
190d84335fSJung-uk Kim  * property rights.
200d84335fSJung-uk Kim  *
210d84335fSJung-uk Kim  * 2.2. Intel grants, free of charge, to any person ("Licensee") obtaining a
220d84335fSJung-uk Kim  * copy of the source code appearing in this file ("Covered Code") an
230d84335fSJung-uk Kim  * irrevocable, perpetual, worldwide license under Intel's copyrights in the
240d84335fSJung-uk Kim  * base code distributed originally by Intel ("Original Intel Code") to copy,
250d84335fSJung-uk Kim  * make derivatives, distribute, use and display any portion of the Covered
260d84335fSJung-uk Kim  * Code in any form, with the right to sublicense such rights; and
270d84335fSJung-uk Kim  *
280d84335fSJung-uk Kim  * 2.3. Intel grants Licensee a non-exclusive and non-transferable patent
290d84335fSJung-uk Kim  * license (with the right to sublicense), under only those claims of Intel
300d84335fSJung-uk Kim  * patents that are infringed by the Original Intel Code, to make, use, sell,
310d84335fSJung-uk Kim  * offer to sell, and import the Covered Code and derivative works thereof
320d84335fSJung-uk Kim  * solely to the minimum extent necessary to exercise the above copyright
330d84335fSJung-uk Kim  * license, and in no event shall the patent license extend to any additions
340d84335fSJung-uk Kim  * to or modifications of the Original Intel Code. No other license or right
350d84335fSJung-uk Kim  * is granted directly or by implication, estoppel or otherwise;
360d84335fSJung-uk Kim  *
370d84335fSJung-uk Kim  * The above copyright and patent license is granted only if the following
380d84335fSJung-uk Kim  * conditions are met:
390d84335fSJung-uk Kim  *
400d84335fSJung-uk Kim  * 3. Conditions
410d84335fSJung-uk Kim  *
420d84335fSJung-uk Kim  * 3.1. Redistribution of Source with Rights to Further Distribute Source.
430d84335fSJung-uk Kim  * Redistribution of source code of any substantial portion of the Covered
440d84335fSJung-uk Kim  * Code or modification with rights to further distribute source must include
450d84335fSJung-uk Kim  * the above Copyright Notice, the above License, this list of Conditions,
460d84335fSJung-uk Kim  * and the following Disclaimer and Export Compliance provision. In addition,
470d84335fSJung-uk Kim  * Licensee must cause all Covered Code to which Licensee contributes to
480d84335fSJung-uk Kim  * contain a file documenting the changes Licensee made to create that Covered
490d84335fSJung-uk Kim  * Code and the date of any change. Licensee must include in that file the
500d84335fSJung-uk Kim  * documentation of any changes made by any predecessor Licensee. Licensee
510d84335fSJung-uk Kim  * must include a prominent statement that the modification is derived,
520d84335fSJung-uk Kim  * directly or indirectly, from Original Intel Code.
530d84335fSJung-uk Kim  *
540d84335fSJung-uk Kim  * 3.2. Redistribution of Source with no Rights to Further Distribute Source.
550d84335fSJung-uk Kim  * Redistribution of source code of any substantial portion of the Covered
560d84335fSJung-uk Kim  * Code or modification without rights to further distribute source must
570d84335fSJung-uk Kim  * include the following Disclaimer and Export Compliance provision in the
580d84335fSJung-uk Kim  * documentation and/or other materials provided with distribution. In
590d84335fSJung-uk Kim  * addition, Licensee may not authorize further sublicense of source of any
600d84335fSJung-uk Kim  * portion of the Covered Code, and must include terms to the effect that the
610d84335fSJung-uk Kim  * license from Licensee to its licensee is limited to the intellectual
620d84335fSJung-uk Kim  * property embodied in the software Licensee provides to its licensee, and
630d84335fSJung-uk Kim  * not to intellectual property embodied in modifications its licensee may
640d84335fSJung-uk Kim  * make.
650d84335fSJung-uk Kim  *
660d84335fSJung-uk Kim  * 3.3. Redistribution of Executable. Redistribution in executable form of any
670d84335fSJung-uk Kim  * substantial portion of the Covered Code or modification must reproduce the
680d84335fSJung-uk Kim  * above Copyright Notice, and the following Disclaimer and Export Compliance
690d84335fSJung-uk Kim  * provision in the documentation and/or other materials provided with the
700d84335fSJung-uk Kim  * distribution.
710d84335fSJung-uk Kim  *
720d84335fSJung-uk Kim  * 3.4. Intel retains all right, title, and interest in and to the Original
730d84335fSJung-uk Kim  * Intel Code.
740d84335fSJung-uk Kim  *
750d84335fSJung-uk Kim  * 3.5. Neither the name Intel nor any other trademark owned or controlled by
760d84335fSJung-uk Kim  * Intel shall be used in advertising or otherwise to promote the sale, use or
770d84335fSJung-uk Kim  * other dealings in products derived from or relating to the Covered Code
780d84335fSJung-uk Kim  * without prior written authorization from Intel.
790d84335fSJung-uk Kim  *
800d84335fSJung-uk Kim  * 4. Disclaimer and Export Compliance
810d84335fSJung-uk Kim  *
820d84335fSJung-uk Kim  * 4.1. INTEL MAKES NO WARRANTY OF ANY KIND REGARDING ANY SOFTWARE PROVIDED
830d84335fSJung-uk Kim  * HERE. ANY SOFTWARE ORIGINATING FROM INTEL OR DERIVED FROM INTEL SOFTWARE
840d84335fSJung-uk Kim  * IS PROVIDED "AS IS," AND INTEL WILL NOT PROVIDE ANY SUPPORT, ASSISTANCE,
850d84335fSJung-uk Kim  * INSTALLATION, TRAINING OR OTHER SERVICES. INTEL WILL NOT PROVIDE ANY
860d84335fSJung-uk Kim  * UPDATES, ENHANCEMENTS OR EXTENSIONS. INTEL SPECIFICALLY DISCLAIMS ANY
870d84335fSJung-uk Kim  * IMPLIED WARRANTIES OF MERCHANTABILITY, NONINFRINGEMENT AND FITNESS FOR A
880d84335fSJung-uk Kim  * PARTICULAR PURPOSE.
890d84335fSJung-uk Kim  *
900d84335fSJung-uk Kim  * 4.2. IN NO EVENT SHALL INTEL HAVE ANY LIABILITY TO LICENSEE, ITS LICENSEES
910d84335fSJung-uk Kim  * OR ANY OTHER THIRD PARTY, FOR ANY LOST PROFITS, LOST DATA, LOSS OF USE OR
920d84335fSJung-uk Kim  * COSTS OF PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES, OR FOR ANY INDIRECT,
930d84335fSJung-uk Kim  * SPECIAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THIS AGREEMENT, UNDER ANY
940d84335fSJung-uk Kim  * CAUSE OF ACTION OR THEORY OF LIABILITY, AND IRRESPECTIVE OF WHETHER INTEL
950d84335fSJung-uk Kim  * HAS ADVANCE NOTICE OF THE POSSIBILITY OF SUCH DAMAGES. THESE LIMITATIONS
960d84335fSJung-uk Kim  * SHALL APPLY NOTWITHSTANDING THE FAILURE OF THE ESSENTIAL PURPOSE OF ANY
970d84335fSJung-uk Kim  * LIMITED REMEDY.
980d84335fSJung-uk Kim  *
990d84335fSJung-uk Kim  * 4.3. Licensee shall not export, either directly or indirectly, any of this
1000d84335fSJung-uk Kim  * software or system incorporating such software without first obtaining any
1010d84335fSJung-uk Kim  * required license or other approval from the U. S. Department of Commerce or
1020d84335fSJung-uk Kim  * any other agency or department of the United States Government. In the
1030d84335fSJung-uk Kim  * event Licensee exports any such software from the United States or
1040d84335fSJung-uk Kim  * re-exports any such software from a foreign destination, Licensee shall
1050d84335fSJung-uk Kim  * ensure that the distribution and export/re-export of the software is in
1060d84335fSJung-uk Kim  * compliance with all laws, regulations, orders, or other restrictions of the
1070d84335fSJung-uk Kim  * U.S. Export Administration Regulations. Licensee agrees that neither it nor
1080d84335fSJung-uk Kim  * any of its subsidiaries will export/re-export any technical data, process,
1090d84335fSJung-uk Kim  * software, or service, directly or indirectly, to any country for which the
1100d84335fSJung-uk Kim  * United States government or any agency thereof requires an export license,
1110d84335fSJung-uk Kim  * other governmental approval, or letter of assurance, without first obtaining
1120d84335fSJung-uk Kim  * such license, approval or letter.
1130d84335fSJung-uk Kim  *
1140d84335fSJung-uk Kim  *****************************************************************************
1150d84335fSJung-uk Kim  *
1160d84335fSJung-uk Kim  * Alternatively, you may choose to be licensed under the terms of the
1170d84335fSJung-uk Kim  * following license:
1180d84335fSJung-uk Kim  *
119efcc2a30SJung-uk Kim  * Redistribution and use in source and binary forms, with or without
120efcc2a30SJung-uk Kim  * modification, are permitted provided that the following conditions
121efcc2a30SJung-uk Kim  * are met:
122efcc2a30SJung-uk Kim  * 1. Redistributions of source code must retain the above copyright
123efcc2a30SJung-uk Kim  *    notice, this list of conditions, and the following disclaimer,
124efcc2a30SJung-uk Kim  *    without modification.
125efcc2a30SJung-uk Kim  * 2. Redistributions in binary form must reproduce at minimum a disclaimer
126efcc2a30SJung-uk Kim  *    substantially similar to the "NO WARRANTY" disclaimer below
127efcc2a30SJung-uk Kim  *    ("Disclaimer") and any redistribution must be conditioned upon
128efcc2a30SJung-uk Kim  *    including a substantially similar Disclaimer requirement for further
129efcc2a30SJung-uk Kim  *    binary redistribution.
130efcc2a30SJung-uk Kim  * 3. Neither the names of the above-listed copyright holders nor the names
131efcc2a30SJung-uk Kim  *    of any contributors may be used to endorse or promote products derived
132efcc2a30SJung-uk Kim  *    from this software without specific prior written permission.
133efcc2a30SJung-uk Kim  *
1340d84335fSJung-uk Kim  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
1350d84335fSJung-uk Kim  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
1360d84335fSJung-uk Kim  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
1370d84335fSJung-uk Kim  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
1380d84335fSJung-uk Kim  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
1390d84335fSJung-uk Kim  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
1400d84335fSJung-uk Kim  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
1410d84335fSJung-uk Kim  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
1420d84335fSJung-uk Kim  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
1430d84335fSJung-uk Kim  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
1440d84335fSJung-uk Kim  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
1450d84335fSJung-uk Kim  *
1460d84335fSJung-uk Kim  * Alternatively, you may choose to be licensed under the terms of the
147efcc2a30SJung-uk Kim  * GNU General Public License ("GPL") version 2 as published by the Free
148efcc2a30SJung-uk Kim  * Software Foundation.
149efcc2a30SJung-uk Kim  *
1500d84335fSJung-uk Kim  *****************************************************************************/
151efcc2a30SJung-uk Kim 
152efcc2a30SJung-uk Kim #include <contrib/dev/acpica/compiler/aslcompiler.h>
153efcc2a30SJung-uk Kim #include "aslcompiler.y.h"
154efcc2a30SJung-uk Kim #include <contrib/dev/acpica/include/acnamesp.h>
155efcc2a30SJung-uk Kim 
156efcc2a30SJung-uk Kim 
157efcc2a30SJung-uk Kim #define _COMPONENT          ACPI_COMPILER
158efcc2a30SJung-uk Kim         ACPI_MODULE_NAME    ("aslnamesp")
159efcc2a30SJung-uk Kim 
160efcc2a30SJung-uk Kim /* Local prototypes */
161efcc2a30SJung-uk Kim 
162efcc2a30SJung-uk Kim static ACPI_STATUS
163efcc2a30SJung-uk Kim NsDoOneNamespaceObject (
164efcc2a30SJung-uk Kim     ACPI_HANDLE             ObjHandle,
165efcc2a30SJung-uk Kim     UINT32                  Level,
166efcc2a30SJung-uk Kim     void                    *Context,
167efcc2a30SJung-uk Kim     void                    **ReturnValue);
168efcc2a30SJung-uk Kim 
169efcc2a30SJung-uk Kim static ACPI_STATUS
170efcc2a30SJung-uk Kim NsDoOnePathname (
171efcc2a30SJung-uk Kim     ACPI_HANDLE             ObjHandle,
172efcc2a30SJung-uk Kim     UINT32                  Level,
173efcc2a30SJung-uk Kim     void                    *Context,
174efcc2a30SJung-uk Kim     void                    **ReturnValue);
175efcc2a30SJung-uk Kim 
176efcc2a30SJung-uk Kim 
177efcc2a30SJung-uk Kim /*******************************************************************************
178efcc2a30SJung-uk Kim  *
179efcc2a30SJung-uk Kim  * FUNCTION:    NsSetupNamespaceListing
180efcc2a30SJung-uk Kim  *
181efcc2a30SJung-uk Kim  * PARAMETERS:  Handle          - local file handle
182efcc2a30SJung-uk Kim  *
183efcc2a30SJung-uk Kim  * RETURN:      None
184efcc2a30SJung-uk Kim  *
185efcc2a30SJung-uk Kim  * DESCRIPTION: Set the namespace output file to the input handle
186efcc2a30SJung-uk Kim  *
187efcc2a30SJung-uk Kim  ******************************************************************************/
188efcc2a30SJung-uk Kim 
189efcc2a30SJung-uk Kim void
190efcc2a30SJung-uk Kim NsSetupNamespaceListing (
191efcc2a30SJung-uk Kim     void                    *Handle)
192efcc2a30SJung-uk Kim {
193efcc2a30SJung-uk Kim 
1946f1f1a63SJung-uk Kim     AslGbl_NsOutputFlag = TRUE;
1956f1f1a63SJung-uk Kim     AslGbl_Files[ASL_FILE_NAMESPACE_OUTPUT].Handle = Handle;
196efcc2a30SJung-uk Kim }
197efcc2a30SJung-uk Kim 
198efcc2a30SJung-uk Kim 
199efcc2a30SJung-uk Kim /*******************************************************************************
200efcc2a30SJung-uk Kim  *
201efcc2a30SJung-uk Kim  * FUNCTION:    NsDisplayNamespace
202efcc2a30SJung-uk Kim  *
203efcc2a30SJung-uk Kim  * PARAMETERS:  None
204efcc2a30SJung-uk Kim  *
205efcc2a30SJung-uk Kim  * RETURN:      Status
206efcc2a30SJung-uk Kim  *
207efcc2a30SJung-uk Kim  * DESCRIPTION: Walk the namespace an display information about each node
208efcc2a30SJung-uk Kim  *              in the tree. Information is written to the optional
209efcc2a30SJung-uk Kim  *              namespace output file.
210efcc2a30SJung-uk Kim  *
211efcc2a30SJung-uk Kim  ******************************************************************************/
212efcc2a30SJung-uk Kim 
213efcc2a30SJung-uk Kim ACPI_STATUS
214efcc2a30SJung-uk Kim NsDisplayNamespace (
215efcc2a30SJung-uk Kim     void)
216efcc2a30SJung-uk Kim {
217efcc2a30SJung-uk Kim     ACPI_STATUS             Status;
218efcc2a30SJung-uk Kim 
219efcc2a30SJung-uk Kim 
2206f1f1a63SJung-uk Kim     if (!AslGbl_NsOutputFlag)
221efcc2a30SJung-uk Kim     {
222efcc2a30SJung-uk Kim         return (AE_OK);
223efcc2a30SJung-uk Kim     }
224efcc2a30SJung-uk Kim 
2256f1f1a63SJung-uk Kim     AslGbl_NumNamespaceObjects = 0;
226efcc2a30SJung-uk Kim 
227efcc2a30SJung-uk Kim     /* File header */
228efcc2a30SJung-uk Kim 
229fbde3477SJung-uk Kim     FlPrintFile (ASL_FILE_NAMESPACE_OUTPUT, "Contents of ACPI Namespace\n\n"
230fbde3477SJung-uk Kim         "Count  Depth    Name - Type\n\n");
231efcc2a30SJung-uk Kim 
232efcc2a30SJung-uk Kim     /* Walk entire namespace from the root */
233efcc2a30SJung-uk Kim 
234efcc2a30SJung-uk Kim     Status = AcpiNsWalkNamespace (ACPI_TYPE_ANY, ACPI_ROOT_OBJECT,
235efcc2a30SJung-uk Kim         ACPI_UINT32_MAX, FALSE, NsDoOneNamespaceObject, NULL,
236efcc2a30SJung-uk Kim         NULL, NULL);
237a009b7dcSJung-uk Kim     if (ACPI_FAILURE (Status))
238a009b7dcSJung-uk Kim     {
239a009b7dcSJung-uk Kim         return (Status);
240a009b7dcSJung-uk Kim     }
241efcc2a30SJung-uk Kim 
242fbde3477SJung-uk Kim     /* Print the full pathname for each namespace node in the common namespace */
243efcc2a30SJung-uk Kim 
244fbde3477SJung-uk Kim     FlPrintFile (ASL_FILE_NAMESPACE_OUTPUT,
245fbde3477SJung-uk Kim         "\nNamespace pathnames and where declared:\n"
246fbde3477SJung-uk Kim         "<NamePath, Object type, Containing file, Line number within file>\n\n");
247efcc2a30SJung-uk Kim 
248efcc2a30SJung-uk Kim     Status = AcpiNsWalkNamespace (ACPI_TYPE_ANY, ACPI_ROOT_OBJECT,
249efcc2a30SJung-uk Kim         ACPI_UINT32_MAX, FALSE, NsDoOnePathname, NULL,
250efcc2a30SJung-uk Kim         NULL, NULL);
251efcc2a30SJung-uk Kim 
252fbde3477SJung-uk Kim     /*
253fbde3477SJung-uk Kim      * We just dumped the entire common namespace, we don't want to do it
254fbde3477SJung-uk Kim      * again for other input files.
255fbde3477SJung-uk Kim      */
256fbde3477SJung-uk Kim     AslGbl_NsOutputFlag = FALSE;
257efcc2a30SJung-uk Kim     return (Status);
258efcc2a30SJung-uk Kim }
259efcc2a30SJung-uk Kim 
260efcc2a30SJung-uk Kim 
261efcc2a30SJung-uk Kim /*******************************************************************************
262efcc2a30SJung-uk Kim  *
263efcc2a30SJung-uk Kim  * FUNCTION:    NsDoOneNamespaceObject
264efcc2a30SJung-uk Kim  *
265efcc2a30SJung-uk Kim  * PARAMETERS:  ACPI_WALK_CALLBACK
266efcc2a30SJung-uk Kim  *
267efcc2a30SJung-uk Kim  * RETURN:      Status
268efcc2a30SJung-uk Kim  *
269efcc2a30SJung-uk Kim  * DESCRIPTION: Dump a namespace object to the namespace output file.
270efcc2a30SJung-uk Kim  *              Called during the walk of the namespace to dump all objects.
271efcc2a30SJung-uk Kim  *
272efcc2a30SJung-uk Kim  ******************************************************************************/
273efcc2a30SJung-uk Kim 
274efcc2a30SJung-uk Kim static ACPI_STATUS
275efcc2a30SJung-uk Kim NsDoOneNamespaceObject (
276efcc2a30SJung-uk Kim     ACPI_HANDLE             ObjHandle,
277efcc2a30SJung-uk Kim     UINT32                  Level,
278efcc2a30SJung-uk Kim     void                    *Context,
279efcc2a30SJung-uk Kim     void                    **ReturnValue)
280efcc2a30SJung-uk Kim {
281efcc2a30SJung-uk Kim     ACPI_NAMESPACE_NODE     *Node = (ACPI_NAMESPACE_NODE *) ObjHandle;
282efcc2a30SJung-uk Kim     ACPI_OPERAND_OBJECT     *ObjDesc;
283efcc2a30SJung-uk Kim     ACPI_PARSE_OBJECT       *Op;
284efcc2a30SJung-uk Kim 
285efcc2a30SJung-uk Kim 
2866f1f1a63SJung-uk Kim     AslGbl_NumNamespaceObjects++;
287efcc2a30SJung-uk Kim 
288efcc2a30SJung-uk Kim     FlPrintFile (ASL_FILE_NAMESPACE_OUTPUT, "%5u  [%u]  %*s %4.4s - %s",
2896f1f1a63SJung-uk Kim         AslGbl_NumNamespaceObjects, Level, (Level * 3), " ",
290a009b7dcSJung-uk Kim         &Node->Name.Ascii[0], AcpiUtGetTypeName (Node->Type));
291efcc2a30SJung-uk Kim 
292efcc2a30SJung-uk Kim     Op = Node->Op;
293efcc2a30SJung-uk Kim     ObjDesc = ACPI_CAST_PTR (ACPI_OPERAND_OBJECT, Node->Object);
294efcc2a30SJung-uk Kim 
295efcc2a30SJung-uk Kim     if (!Op)
296efcc2a30SJung-uk Kim     {
297efcc2a30SJung-uk Kim         FlPrintFile (ASL_FILE_NAMESPACE_OUTPUT, "\n");
298efcc2a30SJung-uk Kim         return (AE_OK);
299efcc2a30SJung-uk Kim     }
300efcc2a30SJung-uk Kim 
301efcc2a30SJung-uk Kim 
302efcc2a30SJung-uk Kim     if ((ObjDesc) &&
303efcc2a30SJung-uk Kim         (ACPI_GET_DESCRIPTOR_TYPE (ObjDesc) == ACPI_DESC_TYPE_OPERAND))
304efcc2a30SJung-uk Kim     {
305efcc2a30SJung-uk Kim         switch (Node->Type)
306efcc2a30SJung-uk Kim         {
307efcc2a30SJung-uk Kim         case ACPI_TYPE_INTEGER:
308efcc2a30SJung-uk Kim 
309efcc2a30SJung-uk Kim             FlPrintFile (ASL_FILE_NAMESPACE_OUTPUT,
310efcc2a30SJung-uk Kim                 "       [Initial Value   0x%8.8X%8.8X]",
311efcc2a30SJung-uk Kim                 ACPI_FORMAT_UINT64 (ObjDesc->Integer.Value));
312efcc2a30SJung-uk Kim             break;
313efcc2a30SJung-uk Kim 
314efcc2a30SJung-uk Kim         case ACPI_TYPE_STRING:
315efcc2a30SJung-uk Kim 
316efcc2a30SJung-uk Kim             FlPrintFile (ASL_FILE_NAMESPACE_OUTPUT,
317efcc2a30SJung-uk Kim                 "        [Initial Value   \"%s\"]",
318efcc2a30SJung-uk Kim                 ObjDesc->String.Pointer);
319efcc2a30SJung-uk Kim             break;
320efcc2a30SJung-uk Kim 
321efcc2a30SJung-uk Kim         default:
322a9d8d09cSJung-uk Kim 
323efcc2a30SJung-uk Kim             /* Nothing to do for other types */
324a9d8d09cSJung-uk Kim 
325efcc2a30SJung-uk Kim             break;
326efcc2a30SJung-uk Kim         }
327efcc2a30SJung-uk Kim 
328efcc2a30SJung-uk Kim     }
329efcc2a30SJung-uk Kim     else
330efcc2a30SJung-uk Kim     {
331efcc2a30SJung-uk Kim         switch (Node->Type)
332efcc2a30SJung-uk Kim         {
333efcc2a30SJung-uk Kim         case ACPI_TYPE_INTEGER:
334efcc2a30SJung-uk Kim 
335efcc2a30SJung-uk Kim             if (Op->Asl.ParseOpcode == PARSEOP_NAME)
336efcc2a30SJung-uk Kim             {
337efcc2a30SJung-uk Kim                 Op = Op->Asl.Child;
338efcc2a30SJung-uk Kim             }
339f8146b88SJung-uk Kim 
340efcc2a30SJung-uk Kim             if ((Op->Asl.ParseOpcode == PARSEOP_NAMESEG)  ||
341efcc2a30SJung-uk Kim                 (Op->Asl.ParseOpcode == PARSEOP_NAMESTRING))
342efcc2a30SJung-uk Kim             {
343efcc2a30SJung-uk Kim                 Op = Op->Asl.Next;
344efcc2a30SJung-uk Kim             }
345f8146b88SJung-uk Kim 
346efcc2a30SJung-uk Kim             FlPrintFile (ASL_FILE_NAMESPACE_OUTPUT,
347efcc2a30SJung-uk Kim                 "       [Initial Value   0x%8.8X%8.8X]",
348efcc2a30SJung-uk Kim                 ACPI_FORMAT_UINT64 (Op->Asl.Value.Integer));
349efcc2a30SJung-uk Kim             break;
350efcc2a30SJung-uk Kim 
351efcc2a30SJung-uk Kim         case ACPI_TYPE_STRING:
352efcc2a30SJung-uk Kim 
353efcc2a30SJung-uk Kim             if (Op->Asl.ParseOpcode == PARSEOP_NAME)
354efcc2a30SJung-uk Kim             {
355efcc2a30SJung-uk Kim                 Op = Op->Asl.Child;
356efcc2a30SJung-uk Kim             }
357f8146b88SJung-uk Kim 
358efcc2a30SJung-uk Kim             if ((Op->Asl.ParseOpcode == PARSEOP_NAMESEG)  ||
359efcc2a30SJung-uk Kim                 (Op->Asl.ParseOpcode == PARSEOP_NAMESTRING))
360efcc2a30SJung-uk Kim             {
361efcc2a30SJung-uk Kim                 Op = Op->Asl.Next;
362efcc2a30SJung-uk Kim             }
363f8146b88SJung-uk Kim 
364efcc2a30SJung-uk Kim             FlPrintFile (ASL_FILE_NAMESPACE_OUTPUT,
365efcc2a30SJung-uk Kim                 "        [Initial Value   \"%s\"]",
366efcc2a30SJung-uk Kim                 Op->Asl.Value.String);
367efcc2a30SJung-uk Kim             break;
368efcc2a30SJung-uk Kim 
369efcc2a30SJung-uk Kim         case ACPI_TYPE_LOCAL_REGION_FIELD:
370efcc2a30SJung-uk Kim 
371efcc2a30SJung-uk Kim             if ((Op->Asl.ParseOpcode == PARSEOP_NAMESEG)  ||
372efcc2a30SJung-uk Kim                 (Op->Asl.ParseOpcode == PARSEOP_NAMESTRING))
373efcc2a30SJung-uk Kim             {
374efcc2a30SJung-uk Kim                 Op = Op->Asl.Child;
375efcc2a30SJung-uk Kim             }
376f8146b88SJung-uk Kim 
377efcc2a30SJung-uk Kim             FlPrintFile (ASL_FILE_NAMESPACE_OUTPUT,
378efcc2a30SJung-uk Kim                 "   [Offset 0x%04X   Length 0x%04X bits]",
379efcc2a30SJung-uk Kim                 Op->Asl.Parent->Asl.ExtraValue, (UINT32) Op->Asl.Value.Integer);
380efcc2a30SJung-uk Kim             break;
381efcc2a30SJung-uk Kim 
382efcc2a30SJung-uk Kim         case ACPI_TYPE_BUFFER_FIELD:
383efcc2a30SJung-uk Kim 
384efcc2a30SJung-uk Kim             switch (Op->Asl.ParseOpcode)
385efcc2a30SJung-uk Kim             {
386efcc2a30SJung-uk Kim             case PARSEOP_CREATEBYTEFIELD:
387a9d8d09cSJung-uk Kim 
388efcc2a30SJung-uk Kim                 FlPrintFile (ASL_FILE_NAMESPACE_OUTPUT, "   [BYTE  ( 8 bit)]");
389efcc2a30SJung-uk Kim                 break;
390efcc2a30SJung-uk Kim 
391efcc2a30SJung-uk Kim             case PARSEOP_CREATEDWORDFIELD:
392a9d8d09cSJung-uk Kim 
393efcc2a30SJung-uk Kim                 FlPrintFile (ASL_FILE_NAMESPACE_OUTPUT, "   [DWORD (32 bit)]");
394efcc2a30SJung-uk Kim                 break;
395efcc2a30SJung-uk Kim 
396efcc2a30SJung-uk Kim             case PARSEOP_CREATEQWORDFIELD:
397a9d8d09cSJung-uk Kim 
398efcc2a30SJung-uk Kim                 FlPrintFile (ASL_FILE_NAMESPACE_OUTPUT, "   [QWORD (64 bit)]");
399efcc2a30SJung-uk Kim                 break;
400efcc2a30SJung-uk Kim 
401efcc2a30SJung-uk Kim             case PARSEOP_CREATEWORDFIELD:
402a9d8d09cSJung-uk Kim 
403efcc2a30SJung-uk Kim                 FlPrintFile (ASL_FILE_NAMESPACE_OUTPUT, "   [WORD  (16 bit)]");
404efcc2a30SJung-uk Kim                 break;
405efcc2a30SJung-uk Kim 
406efcc2a30SJung-uk Kim             case PARSEOP_CREATEBITFIELD:
407a9d8d09cSJung-uk Kim 
408efcc2a30SJung-uk Kim                 FlPrintFile (ASL_FILE_NAMESPACE_OUTPUT, "   [BIT   ( 1 bit)]");
409efcc2a30SJung-uk Kim                 break;
410efcc2a30SJung-uk Kim 
411efcc2a30SJung-uk Kim             case PARSEOP_CREATEFIELD:
412a9d8d09cSJung-uk Kim 
413efcc2a30SJung-uk Kim                 FlPrintFile (ASL_FILE_NAMESPACE_OUTPUT, "   [Arbitrary Bit Field]");
414efcc2a30SJung-uk Kim                 break;
415efcc2a30SJung-uk Kim 
416efcc2a30SJung-uk Kim             default:
417a9d8d09cSJung-uk Kim 
418efcc2a30SJung-uk Kim                 break;
419efcc2a30SJung-uk Kim 
420efcc2a30SJung-uk Kim             }
421efcc2a30SJung-uk Kim             break;
422efcc2a30SJung-uk Kim 
423efcc2a30SJung-uk Kim         case ACPI_TYPE_PACKAGE:
424efcc2a30SJung-uk Kim 
425efcc2a30SJung-uk Kim             if (Op->Asl.ParseOpcode == PARSEOP_NAME)
426efcc2a30SJung-uk Kim             {
427efcc2a30SJung-uk Kim                 Op = Op->Asl.Child;
428efcc2a30SJung-uk Kim             }
429f8146b88SJung-uk Kim 
430efcc2a30SJung-uk Kim             if ((Op->Asl.ParseOpcode == PARSEOP_NAMESEG)  ||
431efcc2a30SJung-uk Kim                 (Op->Asl.ParseOpcode == PARSEOP_NAMESTRING))
432efcc2a30SJung-uk Kim             {
433efcc2a30SJung-uk Kim                 Op = Op->Asl.Next;
434efcc2a30SJung-uk Kim             }
435f8146b88SJung-uk Kim 
436efcc2a30SJung-uk Kim             Op = Op->Asl.Child;
437efcc2a30SJung-uk Kim 
438efcc2a30SJung-uk Kim             if ((Op->Asl.ParseOpcode == PARSEOP_BYTECONST) ||
439efcc2a30SJung-uk Kim                 (Op->Asl.ParseOpcode == PARSEOP_RAW_DATA))
440efcc2a30SJung-uk Kim             {
441efcc2a30SJung-uk Kim                 FlPrintFile (ASL_FILE_NAMESPACE_OUTPUT,
442efcc2a30SJung-uk Kim                     "       [Initial Length  0x%.2X elements]",
443a009b7dcSJung-uk Kim                     (UINT32) Op->Asl.Value.Integer);
444efcc2a30SJung-uk Kim             }
445efcc2a30SJung-uk Kim             break;
446efcc2a30SJung-uk Kim 
447efcc2a30SJung-uk Kim         case ACPI_TYPE_BUFFER:
448efcc2a30SJung-uk Kim 
449efcc2a30SJung-uk Kim             if (Op->Asl.ParseOpcode == PARSEOP_NAME)
450efcc2a30SJung-uk Kim             {
451efcc2a30SJung-uk Kim                 Op = Op->Asl.Child;
452efcc2a30SJung-uk Kim             }
453f8146b88SJung-uk Kim 
454efcc2a30SJung-uk Kim             if ((Op->Asl.ParseOpcode == PARSEOP_NAMESEG)  ||
455efcc2a30SJung-uk Kim                 (Op->Asl.ParseOpcode == PARSEOP_NAMESTRING))
456efcc2a30SJung-uk Kim             {
457efcc2a30SJung-uk Kim                 Op = Op->Asl.Next;
458efcc2a30SJung-uk Kim             }
459f8146b88SJung-uk Kim 
460efcc2a30SJung-uk Kim             Op = Op->Asl.Child;
461efcc2a30SJung-uk Kim 
462efcc2a30SJung-uk Kim             if (Op && (Op->Asl.ParseOpcode == PARSEOP_INTEGER))
463efcc2a30SJung-uk Kim             {
464efcc2a30SJung-uk Kim                 FlPrintFile (ASL_FILE_NAMESPACE_OUTPUT,
465efcc2a30SJung-uk Kim                     "        [Initial Length  0x%.2X bytes]",
466a009b7dcSJung-uk Kim                     (UINT32) Op->Asl.Value.Integer);
467efcc2a30SJung-uk Kim             }
468efcc2a30SJung-uk Kim             break;
469efcc2a30SJung-uk Kim 
470efcc2a30SJung-uk Kim         case ACPI_TYPE_METHOD:
471efcc2a30SJung-uk Kim 
472efcc2a30SJung-uk Kim             FlPrintFile (ASL_FILE_NAMESPACE_OUTPUT,
473efcc2a30SJung-uk Kim                 "        [Code Length     0x%.4X bytes]",
474efcc2a30SJung-uk Kim                 Op->Asl.AmlSubtreeLength);
475efcc2a30SJung-uk Kim             break;
476efcc2a30SJung-uk Kim 
477efcc2a30SJung-uk Kim         case ACPI_TYPE_LOCAL_RESOURCE:
478efcc2a30SJung-uk Kim 
479efcc2a30SJung-uk Kim             FlPrintFile (ASL_FILE_NAMESPACE_OUTPUT,
480efcc2a30SJung-uk Kim                 "  [Desc Offset     0x%.4X Bytes]", Node->Value);
481efcc2a30SJung-uk Kim             break;
482efcc2a30SJung-uk Kim 
483efcc2a30SJung-uk Kim         case ACPI_TYPE_LOCAL_RESOURCE_FIELD:
484efcc2a30SJung-uk Kim 
485efcc2a30SJung-uk Kim             FlPrintFile (ASL_FILE_NAMESPACE_OUTPUT,
486efcc2a30SJung-uk Kim                 "   [Field Offset    0x%.4X Bits 0x%.4X Bytes] ",
487efcc2a30SJung-uk Kim                 Node->Value, Node->Value / 8);
488efcc2a30SJung-uk Kim 
489efcc2a30SJung-uk Kim             if (Node->Flags & ANOBJ_IS_REFERENCED)
490efcc2a30SJung-uk Kim             {
491efcc2a30SJung-uk Kim                 FlPrintFile (ASL_FILE_NAMESPACE_OUTPUT,
492efcc2a30SJung-uk Kim                     "Referenced");
493efcc2a30SJung-uk Kim             }
494efcc2a30SJung-uk Kim             else
495efcc2a30SJung-uk Kim             {
496efcc2a30SJung-uk Kim                 FlPrintFile (ASL_FILE_NAMESPACE_OUTPUT,
497efcc2a30SJung-uk Kim                     "Name not referenced");
498efcc2a30SJung-uk Kim             }
499efcc2a30SJung-uk Kim             break;
500efcc2a30SJung-uk Kim 
501efcc2a30SJung-uk Kim         default:
502a9d8d09cSJung-uk Kim 
503efcc2a30SJung-uk Kim             /* Nothing to do for other types */
504a9d8d09cSJung-uk Kim 
505efcc2a30SJung-uk Kim             break;
506efcc2a30SJung-uk Kim         }
507efcc2a30SJung-uk Kim     }
508efcc2a30SJung-uk Kim 
509efcc2a30SJung-uk Kim     FlPrintFile (ASL_FILE_NAMESPACE_OUTPUT, "\n");
510efcc2a30SJung-uk Kim     return (AE_OK);
511efcc2a30SJung-uk Kim }
512efcc2a30SJung-uk Kim 
513efcc2a30SJung-uk Kim 
514efcc2a30SJung-uk Kim /*******************************************************************************
515efcc2a30SJung-uk Kim  *
516efcc2a30SJung-uk Kim  * FUNCTION:    NsDoOnePathname
517efcc2a30SJung-uk Kim  *
518efcc2a30SJung-uk Kim  * PARAMETERS:  ACPI_WALK_CALLBACK
519efcc2a30SJung-uk Kim  *
520efcc2a30SJung-uk Kim  * RETURN:      Status
521efcc2a30SJung-uk Kim  *
522cfd1ed46SJung-uk Kim  * DESCRIPTION: Print the full pathname and additional info for a namespace
523cfd1ed46SJung-uk Kim  * node.
524efcc2a30SJung-uk Kim  *
525efcc2a30SJung-uk Kim  ******************************************************************************/
526efcc2a30SJung-uk Kim 
527efcc2a30SJung-uk Kim static ACPI_STATUS
528efcc2a30SJung-uk Kim NsDoOnePathname (
529efcc2a30SJung-uk Kim     ACPI_HANDLE             ObjHandle,
530efcc2a30SJung-uk Kim     UINT32                  Level,
531efcc2a30SJung-uk Kim     void                    *Context,
532efcc2a30SJung-uk Kim     void                    **ReturnValue)
533efcc2a30SJung-uk Kim {
534efcc2a30SJung-uk Kim     ACPI_NAMESPACE_NODE     *Node = (ACPI_NAMESPACE_NODE *) ObjHandle;
535efcc2a30SJung-uk Kim     ACPI_STATUS             Status;
536efcc2a30SJung-uk Kim     ACPI_BUFFER             TargetPath;
537efcc2a30SJung-uk Kim 
538efcc2a30SJung-uk Kim 
539fbde3477SJung-uk Kim     /* Ignore predefined namespace nodes and External declarations */
540fbde3477SJung-uk Kim 
541fbde3477SJung-uk Kim     if (!Node->Op || (Node->Flags & ANOBJ_IS_EXTERNAL))
542fbde3477SJung-uk Kim     {
543fbde3477SJung-uk Kim         return (AE_OK);
544fbde3477SJung-uk Kim     }
545fbde3477SJung-uk Kim 
546efcc2a30SJung-uk Kim     TargetPath.Length = ACPI_ALLOCATE_LOCAL_BUFFER;
547fe0f0bbbSJung-uk Kim     Status = AcpiNsHandleToPathname (Node, &TargetPath, FALSE);
548efcc2a30SJung-uk Kim     if (ACPI_FAILURE (Status))
549efcc2a30SJung-uk Kim     {
550efcc2a30SJung-uk Kim         return (Status);
551efcc2a30SJung-uk Kim     }
552efcc2a30SJung-uk Kim 
553fbde3477SJung-uk Kim     /*
554fbde3477SJung-uk Kim      * Print the full pathname (and other information)
555fbde3477SJung-uk Kim      * for each namespace node in the common namespace
556fbde3477SJung-uk Kim      */
557fbde3477SJung-uk Kim     FlPrintFile (ASL_FILE_NAMESPACE_OUTPUT, "%-41s %-12s  %s, %u\n",
558fbde3477SJung-uk Kim         ACPI_CAST_PTR (char, TargetPath.Pointer),
559fbde3477SJung-uk Kim         AcpiUtGetTypeName (Node->Type),
560fbde3477SJung-uk Kim         Node->Op->Asl.Filename, Node->Op->Asl.LogicalLineNumber);
561fbde3477SJung-uk Kim 
562efcc2a30SJung-uk Kim     ACPI_FREE (TargetPath.Pointer);
563efcc2a30SJung-uk Kim     return (AE_OK);
564efcc2a30SJung-uk Kim }
565