xref: /netbsd-src/sys/external/bsd/acpica/dist/compiler/aslmapoutput.c (revision 046a29855e04359424fd074e8313af6b6be8cfb6)
1460301d4Schristos /******************************************************************************
2460301d4Schristos  *
3460301d4Schristos  * Module Name: aslmapoutput - Output/emit the resource descriptor/device maps
4460301d4Schristos  *
5460301d4Schristos  *****************************************************************************/
6460301d4Schristos 
7460301d4Schristos /*
8*046a2985Schristos  * Copyright (C) 2000 - 2023, Intel Corp.
9460301d4Schristos  * All rights reserved.
10460301d4Schristos  *
11460301d4Schristos  * Redistribution and use in source and binary forms, with or without
12460301d4Schristos  * modification, are permitted provided that the following conditions
13460301d4Schristos  * are met:
14460301d4Schristos  * 1. Redistributions of source code must retain the above copyright
15460301d4Schristos  *    notice, this list of conditions, and the following disclaimer,
16460301d4Schristos  *    without modification.
17460301d4Schristos  * 2. Redistributions in binary form must reproduce at minimum a disclaimer
18460301d4Schristos  *    substantially similar to the "NO WARRANTY" disclaimer below
19460301d4Schristos  *    ("Disclaimer") and any redistribution must be conditioned upon
20460301d4Schristos  *    including a substantially similar Disclaimer requirement for further
21460301d4Schristos  *    binary redistribution.
22460301d4Schristos  * 3. Neither the names of the above-listed copyright holders nor the names
23460301d4Schristos  *    of any contributors may be used to endorse or promote products derived
24460301d4Schristos  *    from this software without specific prior written permission.
25460301d4Schristos  *
26460301d4Schristos  * Alternatively, this software may be distributed under the terms of the
27460301d4Schristos  * GNU General Public License ("GPL") version 2 as published by the Free
28460301d4Schristos  * Software Foundation.
29460301d4Schristos  *
30460301d4Schristos  * NO WARRANTY
31460301d4Schristos  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
32460301d4Schristos  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
3346a330b4Schristos  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
34460301d4Schristos  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
35460301d4Schristos  * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
36460301d4Schristos  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
37460301d4Schristos  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
38460301d4Schristos  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
39460301d4Schristos  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
40460301d4Schristos  * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
41460301d4Schristos  * POSSIBILITY OF SUCH DAMAGES.
42460301d4Schristos  */
43460301d4Schristos 
44460301d4Schristos #include "acpi.h"
45460301d4Schristos #include "accommon.h"
46460301d4Schristos #include "acapps.h"
47460301d4Schristos #include "aslcompiler.h"
48460301d4Schristos #include "aslcompiler.y.h"
49460301d4Schristos #include "acinterp.h"
50460301d4Schristos #include "acparser.h"
51460301d4Schristos #include "acnamesp.h"
52460301d4Schristos #include "amlcode.h"
53460301d4Schristos 
54460301d4Schristos /* This module used for application-level code only */
55460301d4Schristos 
56460301d4Schristos #define _COMPONENT          ACPI_COMPILER
57460301d4Schristos         ACPI_MODULE_NAME    ("aslmapoutput")
58460301d4Schristos 
59460301d4Schristos /* Local prototypes */
60460301d4Schristos 
61460301d4Schristos static void
62460301d4Schristos MpEmitGpioInfo (
63460301d4Schristos     void);
64460301d4Schristos 
65460301d4Schristos static void
66460301d4Schristos MpEmitSerialInfo (
67460301d4Schristos     void);
68460301d4Schristos 
69460301d4Schristos static void
70460301d4Schristos MpEmitDeviceTree (
71460301d4Schristos     void);
72460301d4Schristos 
73460301d4Schristos static ACPI_STATUS
74460301d4Schristos MpEmitOneDevice (
75460301d4Schristos     ACPI_HANDLE             ObjHandle,
76460301d4Schristos     UINT32                  NestingLevel,
77460301d4Schristos     void                    *Context,
78460301d4Schristos     void                    **ReturnValue);
79460301d4Schristos 
80460301d4Schristos static void
81460301d4Schristos MpXrefDevices (
82460301d4Schristos     ACPI_GPIO_INFO          *Info);
83460301d4Schristos 
84460301d4Schristos static ACPI_STATUS
85460301d4Schristos MpNamespaceXrefBegin (
86460301d4Schristos     ACPI_PARSE_OBJECT       *Op,
87460301d4Schristos     UINT32                  Level,
88460301d4Schristos     void                    *Context);
89460301d4Schristos 
90460301d4Schristos 
91460301d4Schristos /* Strings used to decode flag bits */
92460301d4Schristos 
93460301d4Schristos const char                  *DirectionDecode[] =
94460301d4Schristos {
95460301d4Schristos     "Both I/O   ",
96460301d4Schristos     "InputOnly  ",
97460301d4Schristos     "OutputOnly ",
98460301d4Schristos     "Preserve   "
99460301d4Schristos };
100460301d4Schristos 
101460301d4Schristos const char                  *PolarityDecode[] =
102460301d4Schristos {
103460301d4Schristos     "ActiveHigh",
104460301d4Schristos     "ActiveLow ",
105460301d4Schristos     "ActiveBoth",
106460301d4Schristos     "Reserved  "
107460301d4Schristos };
108460301d4Schristos 
109460301d4Schristos 
110460301d4Schristos /*******************************************************************************
111460301d4Schristos  *
112460301d4Schristos  * FUNCTION:    MpEmitMappingInfo
113460301d4Schristos  *
114460301d4Schristos  * PARAMETERS:  None
115460301d4Schristos  *
116460301d4Schristos  * RETURN:      None
117460301d4Schristos  *
118460301d4Schristos  * DESCRIPTION: External interface.
119679c17fdSchristos  *              Map file has already been opened. Emit all of the collected
120460301d4Schristos  *              hardware mapping information. Includes: GPIO information,
121460301d4Schristos  *              Serial information, and a dump of the entire ACPI device tree.
122460301d4Schristos  *
123460301d4Schristos  ******************************************************************************/
124460301d4Schristos 
125460301d4Schristos void
MpEmitMappingInfo(void)126460301d4Schristos MpEmitMappingInfo (
127460301d4Schristos     void)
128460301d4Schristos {
129460301d4Schristos 
130460301d4Schristos     /* Mapfile option enabled? */
131460301d4Schristos 
1324c4e8184Schristos     if (!AslGbl_MapfileFlag)
133460301d4Schristos     {
134460301d4Schristos         return;
135460301d4Schristos     }
136460301d4Schristos 
1374c4e8184Schristos     if (!AslGbl_GpioList)
138460301d4Schristos     {
139460301d4Schristos         FlPrintFile (ASL_FILE_MAP_OUTPUT,
140460301d4Schristos             "\nNo GPIO devices found\n");
141460301d4Schristos     }
142460301d4Schristos 
1434c4e8184Schristos     if (!AslGbl_SerialList)
144460301d4Schristos     {
145460301d4Schristos         FlPrintFile (ASL_FILE_MAP_OUTPUT,
146460301d4Schristos             "\nNo Serial devices found (I2C/SPI/UART)\n");
147460301d4Schristos     }
148460301d4Schristos 
1494c4e8184Schristos     if (!AslGbl_GpioList && !AslGbl_SerialList)
150460301d4Schristos     {
151460301d4Schristos         return;
152460301d4Schristos     }
153460301d4Schristos 
154460301d4Schristos     /* Headers */
155460301d4Schristos 
156460301d4Schristos     FlPrintFile (ASL_FILE_MAP_OUTPUT, "\nResource Descriptor Connectivity Map\n");
157460301d4Schristos     FlPrintFile (ASL_FILE_MAP_OUTPUT,   "------------------------------------\n");
158460301d4Schristos 
159460301d4Schristos     /* Emit GPIO and Serial descriptors, then entire ACPI device tree */
160460301d4Schristos 
161460301d4Schristos     MpEmitGpioInfo ();
162460301d4Schristos     MpEmitSerialInfo ();
163460301d4Schristos     MpEmitDeviceTree ();
164460301d4Schristos 
165460301d4Schristos     /* Clear the lists - no need to free memory here */
166460301d4Schristos 
1674c4e8184Schristos     AslGbl_SerialList = NULL;
1684c4e8184Schristos     AslGbl_GpioList = NULL;
169460301d4Schristos }
170460301d4Schristos 
171460301d4Schristos 
172460301d4Schristos /*******************************************************************************
173460301d4Schristos  *
174460301d4Schristos  * FUNCTION:    MpEmitGpioInfo
175460301d4Schristos  *
176460301d4Schristos  * PARAMETERS:  None
177460301d4Schristos  *
178460301d4Schristos  * RETURN:      None
179460301d4Schristos  *
180460301d4Schristos  * DESCRIPTION: Emit the info about all GPIO devices found during the
181460301d4Schristos  *              compile or disassembly.
182460301d4Schristos  *
183460301d4Schristos  ******************************************************************************/
184460301d4Schristos 
185460301d4Schristos static void
MpEmitGpioInfo(void)186460301d4Schristos MpEmitGpioInfo (
187460301d4Schristos     void)
188460301d4Schristos {
189460301d4Schristos     ACPI_GPIO_INFO          *Info;
190460301d4Schristos     char                    *Type;
191460301d4Schristos     char                    *PrevDeviceName = NULL;
192460301d4Schristos     const char              *Direction;
193460301d4Schristos     const char              *Polarity;
194460301d4Schristos     char                    *ParentPathname;
195460301d4Schristos     const char              *Description;
196460301d4Schristos     char                    *HidString;
197460301d4Schristos     const AH_DEVICE_ID      *HidInfo;
198460301d4Schristos 
199460301d4Schristos 
200460301d4Schristos     /* Walk the GPIO descriptor list */
201460301d4Schristos 
2024c4e8184Schristos     Info = AslGbl_GpioList;
203460301d4Schristos     while (Info)
204460301d4Schristos     {
205460301d4Schristos         HidString = MpGetHidViaNamestring (Info->DeviceName);
206460301d4Schristos 
207460301d4Schristos         /* Print header info for the controller itself */
208460301d4Schristos 
209460301d4Schristos         if (!PrevDeviceName ||
210c72da027Schristos             strcmp (PrevDeviceName, Info->DeviceName))
211460301d4Schristos         {
212460301d4Schristos             FlPrintFile (ASL_FILE_MAP_OUTPUT,
213460301d4Schristos                 "\n\nGPIO Controller:  %-8s  %-28s",
214460301d4Schristos                 HidString, Info->DeviceName);
215460301d4Schristos 
216460301d4Schristos             HidInfo = AcpiAhMatchHardwareId (HidString);
217460301d4Schristos             if (HidInfo)
218460301d4Schristos             {
219460301d4Schristos                 FlPrintFile (ASL_FILE_MAP_OUTPUT, "  // %s",
220460301d4Schristos                     HidInfo->Description);
221460301d4Schristos             }
222460301d4Schristos 
223460301d4Schristos             FlPrintFile (ASL_FILE_MAP_OUTPUT,
224460301d4Schristos                 "\n\nPin   Type     Direction    Polarity"
225460301d4Schristos                 "    Dest _HID  Destination\n");
226460301d4Schristos         }
227460301d4Schristos 
228460301d4Schristos         PrevDeviceName = Info->DeviceName;
229460301d4Schristos 
230460301d4Schristos         /* Setup various strings based upon the type (GpioInt or GpioIo) */
231460301d4Schristos 
232460301d4Schristos         switch (Info->Type)
233460301d4Schristos         {
234460301d4Schristos         case AML_RESOURCE_GPIO_TYPE_INT:
235460301d4Schristos 
236460301d4Schristos             Type = "GpioInt";
237460301d4Schristos             Direction = "-Interrupt-";
238460301d4Schristos             Polarity = PolarityDecode[Info->Polarity];
239460301d4Schristos             break;
240460301d4Schristos 
241460301d4Schristos         case AML_RESOURCE_GPIO_TYPE_IO:
242460301d4Schristos 
243460301d4Schristos             Type = "GpioIo ";
244460301d4Schristos             Direction = DirectionDecode[Info->Direction];
245460301d4Schristos             Polarity = "          ";
246460301d4Schristos             break;
247460301d4Schristos 
248460301d4Schristos         default:
249460301d4Schristos             continue;
250460301d4Schristos         }
251460301d4Schristos 
252460301d4Schristos         /* Emit the GPIO info */
253460301d4Schristos 
254460301d4Schristos         FlPrintFile (ASL_FILE_MAP_OUTPUT, "%4.4X  %s  %s  %s  ",
255460301d4Schristos             Info->PinNumber, Type, Direction, Polarity);
256460301d4Schristos 
257460301d4Schristos         ParentPathname = NULL;
258460301d4Schristos         HidString = MpGetConnectionInfo (Info->Op, Info->PinIndex,
259460301d4Schristos             &Info->TargetNode, &ParentPathname);
260460301d4Schristos         if (HidString)
261460301d4Schristos         {
262460301d4Schristos             /*
263460301d4Schristos              * This is a Connection() field
264460301d4Schristos              * Attempt to find all references to the field.
265460301d4Schristos              */
266460301d4Schristos             FlPrintFile (ASL_FILE_MAP_OUTPUT, "%8s   %-28s",
267460301d4Schristos                 HidString, ParentPathname);
268460301d4Schristos 
269460301d4Schristos             MpXrefDevices (Info);
270460301d4Schristos         }
271460301d4Schristos         else
272460301d4Schristos         {
273460301d4Schristos             /*
274460301d4Schristos              * For Devices, attempt to get the _HID description string.
275460301d4Schristos              * Failing that (many _HIDs are not recognized), attempt to
276460301d4Schristos              * get the _DDN description string.
277460301d4Schristos              */
278460301d4Schristos             HidString = MpGetParentDeviceHid (Info->Op, &Info->TargetNode,
279460301d4Schristos                 &ParentPathname);
280460301d4Schristos 
281460301d4Schristos             FlPrintFile (ASL_FILE_MAP_OUTPUT, "%8s   %-28s",
282460301d4Schristos                 HidString, ParentPathname);
283460301d4Schristos 
284460301d4Schristos             /* Get the _HID description or _DDN string */
285460301d4Schristos 
286460301d4Schristos             HidInfo = AcpiAhMatchHardwareId (HidString);
287460301d4Schristos             if (HidInfo)
288460301d4Schristos             {
289460301d4Schristos                 FlPrintFile (ASL_FILE_MAP_OUTPUT, "  // %s",
290460301d4Schristos                     HidInfo->Description);
291460301d4Schristos             }
292460301d4Schristos             else if ((Description = MpGetDdnValue (ParentPathname)))
293460301d4Schristos             {
294460301d4Schristos                 FlPrintFile (ASL_FILE_MAP_OUTPUT, "  // %s (_DDN)",
295460301d4Schristos                     Description);
296460301d4Schristos             }
297460301d4Schristos         }
298460301d4Schristos 
299460301d4Schristos         FlPrintFile (ASL_FILE_MAP_OUTPUT, "\n");
300460301d4Schristos         ACPI_FREE (ParentPathname);
301460301d4Schristos         Info = Info->Next;
302460301d4Schristos     }
303460301d4Schristos }
304460301d4Schristos 
305460301d4Schristos 
306460301d4Schristos /*******************************************************************************
307460301d4Schristos  *
308460301d4Schristos  * FUNCTION:    MpEmitSerialInfo
309460301d4Schristos  *
310460301d4Schristos  * PARAMETERS:  None
311460301d4Schristos  *
312460301d4Schristos  * RETURN:      None
313460301d4Schristos  *
314460301d4Schristos  * DESCRIPTION: Emit the info about all Serial devices found during the
315460301d4Schristos  *              compile or disassembly.
316460301d4Schristos  *
317460301d4Schristos  ******************************************************************************/
318460301d4Schristos 
319460301d4Schristos static void
MpEmitSerialInfo(void)320460301d4Schristos MpEmitSerialInfo (
321460301d4Schristos     void)
322460301d4Schristos {
323460301d4Schristos     ACPI_SERIAL_INFO        *Info;
324460301d4Schristos     char                    *Type;
325460301d4Schristos     char                    *ParentPathname;
326460301d4Schristos     char                    *PrevDeviceName = NULL;
327460301d4Schristos     char                    *HidString;
328460301d4Schristos     const AH_DEVICE_ID      *HidInfo;
329460301d4Schristos     const char              *Description;
330460301d4Schristos     AML_RESOURCE            *Resource;
331460301d4Schristos 
332460301d4Schristos 
333460301d4Schristos     /* Walk the constructed serial descriptor list */
334460301d4Schristos 
3354c4e8184Schristos     Info = AslGbl_SerialList;
336460301d4Schristos     while (Info)
337460301d4Schristos     {
338460301d4Schristos         Resource = Info->Resource;
339460301d4Schristos         switch (Resource->CommonSerialBus.Type)
340460301d4Schristos         {
341460301d4Schristos         case AML_RESOURCE_I2C_SERIALBUSTYPE:
342460301d4Schristos             Type = "I2C ";
343460301d4Schristos             break;
344460301d4Schristos 
345460301d4Schristos         case AML_RESOURCE_SPI_SERIALBUSTYPE:
346460301d4Schristos             Type = "SPI ";
347460301d4Schristos             break;
348460301d4Schristos 
349460301d4Schristos         case AML_RESOURCE_UART_SERIALBUSTYPE:
350460301d4Schristos             Type = "UART";
351460301d4Schristos             break;
352460301d4Schristos 
353460301d4Schristos         default:
354460301d4Schristos             Type = "UNKN";
355460301d4Schristos             break;
356460301d4Schristos         }
357460301d4Schristos 
358460301d4Schristos         HidString = MpGetHidViaNamestring (Info->DeviceName);
359460301d4Schristos 
360460301d4Schristos         /* Print header info for the controller itself */
361460301d4Schristos 
362460301d4Schristos         if (!PrevDeviceName ||
363c72da027Schristos             strcmp (PrevDeviceName, Info->DeviceName))
364460301d4Schristos         {
365460301d4Schristos             FlPrintFile (ASL_FILE_MAP_OUTPUT, "\n\n%s Controller:  ",
366460301d4Schristos                 Type);
367460301d4Schristos             FlPrintFile (ASL_FILE_MAP_OUTPUT, "%-8s  %-28s",
368460301d4Schristos                 HidString, Info->DeviceName);
369460301d4Schristos 
370460301d4Schristos             HidInfo = AcpiAhMatchHardwareId (HidString);
371460301d4Schristos             if (HidInfo)
372460301d4Schristos             {
373460301d4Schristos                 FlPrintFile (ASL_FILE_MAP_OUTPUT, "  // %s",
374460301d4Schristos                     HidInfo->Description);
375460301d4Schristos             }
376460301d4Schristos 
377460301d4Schristos             FlPrintFile (ASL_FILE_MAP_OUTPUT, "\n\n");
378460301d4Schristos             FlPrintFile (ASL_FILE_MAP_OUTPUT,
379460301d4Schristos                 "Type  Address   Speed      Dest _HID  Destination\n");
380460301d4Schristos         }
381460301d4Schristos 
382460301d4Schristos         PrevDeviceName = Info->DeviceName;
383460301d4Schristos 
384460301d4Schristos         FlPrintFile (ASL_FILE_MAP_OUTPUT, "%s   %4.4X    %8.8X    ",
385460301d4Schristos             Type, Info->Address, Info->Speed);
386460301d4Schristos 
387460301d4Schristos         ParentPathname = NULL;
388460301d4Schristos         HidString = MpGetConnectionInfo (Info->Op, 0, &Info->TargetNode,
389460301d4Schristos             &ParentPathname);
390460301d4Schristos         if (HidString)
391460301d4Schristos         {
392460301d4Schristos             /*
393460301d4Schristos              * This is a Connection() field
394460301d4Schristos              * Attempt to find all references to the field.
395460301d4Schristos              */
396460301d4Schristos             FlPrintFile (ASL_FILE_MAP_OUTPUT, "%8s   %-28s",
397460301d4Schristos                 HidString, ParentPathname);
398460301d4Schristos         }
399460301d4Schristos         else
400460301d4Schristos         {
401460301d4Schristos             /* Normal resource template */
402460301d4Schristos 
403460301d4Schristos             HidString = MpGetParentDeviceHid (Info->Op, &Info->TargetNode,
404460301d4Schristos                 &ParentPathname);
405460301d4Schristos             FlPrintFile (ASL_FILE_MAP_OUTPUT, "%8s   %-28s",
406460301d4Schristos                 HidString, ParentPathname);
407460301d4Schristos 
408460301d4Schristos             /* Get the _HID description or _DDN string */
409460301d4Schristos 
410460301d4Schristos             HidInfo = AcpiAhMatchHardwareId (HidString);
411460301d4Schristos             if (HidInfo)
412460301d4Schristos             {
413460301d4Schristos                 FlPrintFile (ASL_FILE_MAP_OUTPUT, "  // %s",
414460301d4Schristos                     HidInfo->Description);
415460301d4Schristos             }
416460301d4Schristos             else if ((Description = MpGetDdnValue (ParentPathname)))
417460301d4Schristos             {
418460301d4Schristos                 FlPrintFile (ASL_FILE_MAP_OUTPUT, "  // %s (_DDN)",
419460301d4Schristos                     Description);
420460301d4Schristos             }
421460301d4Schristos         }
422460301d4Schristos 
423460301d4Schristos         FlPrintFile (ASL_FILE_MAP_OUTPUT, "\n");
424460301d4Schristos         ACPI_FREE (ParentPathname);
425460301d4Schristos         Info = Info->Next;
426460301d4Schristos     }
427460301d4Schristos }
428460301d4Schristos 
429460301d4Schristos 
430460301d4Schristos /*******************************************************************************
431460301d4Schristos  *
432460301d4Schristos  * FUNCTION:    MpEmitDeviceTree
433460301d4Schristos  *
434460301d4Schristos  * PARAMETERS:  None
435460301d4Schristos  *
436460301d4Schristos  * RETURN:      None
437460301d4Schristos  *
438460301d4Schristos  * DESCRIPTION: Emit information about all devices within the ACPI namespace.
439460301d4Schristos  *
440460301d4Schristos  ******************************************************************************/
441460301d4Schristos 
442460301d4Schristos static void
MpEmitDeviceTree(void)443460301d4Schristos MpEmitDeviceTree (
444460301d4Schristos     void)
445460301d4Schristos {
446460301d4Schristos 
447460301d4Schristos     FlPrintFile (ASL_FILE_MAP_OUTPUT, "\n\nACPI Device Tree\n");
448460301d4Schristos     FlPrintFile (ASL_FILE_MAP_OUTPUT,     "----------------\n\n");
449460301d4Schristos 
450460301d4Schristos     FlPrintFile (ASL_FILE_MAP_OUTPUT, "Device Pathname                   "
451460301d4Schristos         "_HID      Description\n\n");
452460301d4Schristos 
453460301d4Schristos     /* Walk the namespace from the root */
454460301d4Schristos 
455460301d4Schristos     (void) AcpiNsWalkNamespace (ACPI_TYPE_DEVICE, ACPI_ROOT_OBJECT,
456460301d4Schristos         ACPI_UINT32_MAX, FALSE, MpEmitOneDevice, NULL, NULL, NULL);
457460301d4Schristos }
458460301d4Schristos 
459460301d4Schristos 
460460301d4Schristos /*******************************************************************************
461460301d4Schristos  *
462460301d4Schristos  * FUNCTION:    MpEmitOneDevice
463460301d4Schristos  *
464460301d4Schristos  * PARAMETERS:  ACPI_NAMESPACE_WALK callback
465460301d4Schristos  *
466460301d4Schristos  * RETURN:      Status
467460301d4Schristos  *
468460301d4Schristos  * DESCRIPTION: Emit information about one ACPI device in the namespace. Used
469460301d4Schristos  *              during dump of all device objects within the namespace.
470460301d4Schristos  *
471460301d4Schristos  ******************************************************************************/
472460301d4Schristos 
473460301d4Schristos static ACPI_STATUS
MpEmitOneDevice(ACPI_HANDLE ObjHandle,UINT32 NestingLevel,void * Context,void ** ReturnValue)474460301d4Schristos MpEmitOneDevice (
475460301d4Schristos     ACPI_HANDLE             ObjHandle,
476460301d4Schristos     UINT32                  NestingLevel,
477460301d4Schristos     void                    *Context,
478460301d4Schristos     void                    **ReturnValue)
479460301d4Schristos {
480460301d4Schristos     char                    *DevicePathname;
481460301d4Schristos     char                    *DdnString;
482460301d4Schristos     char                    *HidString;
483460301d4Schristos     const AH_DEVICE_ID      *HidInfo;
484460301d4Schristos 
485460301d4Schristos 
486460301d4Schristos     /* Device pathname */
487460301d4Schristos 
488460301d4Schristos     DevicePathname = AcpiNsGetExternalPathname (
489460301d4Schristos         ACPI_CAST_PTR (ACPI_NAMESPACE_NODE, ObjHandle));
490460301d4Schristos 
491460301d4Schristos     FlPrintFile (ASL_FILE_MAP_OUTPUT, "%-32s", DevicePathname);
492460301d4Schristos 
493460301d4Schristos     /* _HID or _DDN */
494460301d4Schristos 
495460301d4Schristos     HidString = MpGetHidValue (
496460301d4Schristos         ACPI_CAST_PTR (ACPI_NAMESPACE_NODE, ObjHandle));
497460301d4Schristos     FlPrintFile (ASL_FILE_MAP_OUTPUT, "%8s", HidString);
498460301d4Schristos 
499460301d4Schristos     HidInfo = AcpiAhMatchHardwareId (HidString);
500460301d4Schristos     if (HidInfo)
501460301d4Schristos     {
502460301d4Schristos         FlPrintFile (ASL_FILE_MAP_OUTPUT, "    // %s",
503460301d4Schristos             HidInfo->Description);
504460301d4Schristos     }
505460301d4Schristos     else if ((DdnString = MpGetDdnValue (DevicePathname)))
506460301d4Schristos     {
507460301d4Schristos         FlPrintFile (ASL_FILE_MAP_OUTPUT, "    // %s (_DDN)", DdnString);
508460301d4Schristos     }
509460301d4Schristos 
510460301d4Schristos     FlPrintFile (ASL_FILE_MAP_OUTPUT, "\n");
511460301d4Schristos     ACPI_FREE (DevicePathname);
512460301d4Schristos     return (AE_OK);
513460301d4Schristos }
514460301d4Schristos 
515460301d4Schristos 
516460301d4Schristos /*******************************************************************************
517460301d4Schristos  *
518460301d4Schristos  * FUNCTION:    MpXrefDevices
519460301d4Schristos  *
520460301d4Schristos  * PARAMETERS:  Info                    - A GPIO Info block
521460301d4Schristos  *
522460301d4Schristos  * RETURN:      None
523460301d4Schristos  *
524460301d4Schristos  * DESCRIPTION: Cross-reference the parse tree and find all references to the
525460301d4Schristos  *              specified GPIO device.
526460301d4Schristos  *
527460301d4Schristos  ******************************************************************************/
528460301d4Schristos 
529460301d4Schristos static void
MpXrefDevices(ACPI_GPIO_INFO * Info)530460301d4Schristos MpXrefDevices (
531460301d4Schristos     ACPI_GPIO_INFO          *Info)
532460301d4Schristos {
533460301d4Schristos 
534460301d4Schristos     /* Walk the entire parse tree */
535460301d4Schristos 
5364c4e8184Schristos     TrWalkParseTree (AslGbl_ParseTreeRoot, ASL_WALK_VISIT_DOWNWARD,
537460301d4Schristos         MpNamespaceXrefBegin, NULL, Info);
538460301d4Schristos 
539460301d4Schristos     if (!Info->References)
540460301d4Schristos     {
541460301d4Schristos         FlPrintFile (ASL_FILE_MAP_OUTPUT, "  // **** No references in table");
542460301d4Schristos     }
543460301d4Schristos }
544460301d4Schristos 
545460301d4Schristos 
546460301d4Schristos /*******************************************************************************
547460301d4Schristos  *
548460301d4Schristos  * FUNCTION:    MpNamespaceXrefBegin
549460301d4Schristos  *
550460301d4Schristos  * PARAMETERS:  WALK_PARSE_TREE callback
551460301d4Schristos  *
552460301d4Schristos  * RETURN:      Status
553460301d4Schristos  *
554460301d4Schristos  * DESCRIPTION: Walk parse tree callback used to cross-reference GPIO pins.
555460301d4Schristos  *
556460301d4Schristos  ******************************************************************************/
557460301d4Schristos 
558460301d4Schristos static ACPI_STATUS
MpNamespaceXrefBegin(ACPI_PARSE_OBJECT * Op,UINT32 Level,void * Context)559460301d4Schristos MpNamespaceXrefBegin (
560460301d4Schristos     ACPI_PARSE_OBJECT       *Op,
561460301d4Schristos     UINT32                  Level,
562460301d4Schristos     void                    *Context)
563460301d4Schristos {
564460301d4Schristos     ACPI_GPIO_INFO          *Info = ACPI_CAST_PTR (ACPI_GPIO_INFO, Context);
565460301d4Schristos     const ACPI_OPCODE_INFO  *OpInfo;
566460301d4Schristos     char                    *DevicePathname;
567460301d4Schristos     ACPI_PARSE_OBJECT       *ParentOp;
568460301d4Schristos     char                    *HidString;
569460301d4Schristos 
570460301d4Schristos 
571460301d4Schristos     ACPI_FUNCTION_TRACE_PTR (MpNamespaceXrefBegin, Op);
572460301d4Schristos 
573460301d4Schristos     /*
574460301d4Schristos      * If this node is the actual declaration of a name
575460301d4Schristos      * [such as the XXXX name in "Method (XXXX)"],
576460301d4Schristos      * we are not interested in it here. We only care about names that
577460301d4Schristos      * are references to other objects within the namespace and the
578460301d4Schristos      * parent objects of name declarations
579460301d4Schristos      */
58089b8eb6cSchristos     if (Op->Asl.CompileFlags & OP_IS_NAME_DECLARATION)
581460301d4Schristos     {
582460301d4Schristos         return (AE_OK);
583460301d4Schristos     }
584460301d4Schristos 
585460301d4Schristos     /* We are only interested in opcodes that have an associated name */
586460301d4Schristos 
587460301d4Schristos     OpInfo = AcpiPsGetOpcodeInfo (Op->Asl.AmlOpcode);
588460301d4Schristos 
589460301d4Schristos     if ((OpInfo->Flags & AML_NAMED) ||
590460301d4Schristos         (OpInfo->Flags & AML_CREATE))
591460301d4Schristos     {
592460301d4Schristos         return (AE_OK);
593460301d4Schristos     }
594460301d4Schristos 
595460301d4Schristos     if ((Op->Asl.ParseOpcode != PARSEOP_NAMESTRING) &&
596460301d4Schristos         (Op->Asl.ParseOpcode != PARSEOP_NAMESEG)    &&
597460301d4Schristos         (Op->Asl.ParseOpcode != PARSEOP_METHODCALL))
598460301d4Schristos     {
599460301d4Schristos         return (AE_OK);
600460301d4Schristos     }
601460301d4Schristos 
602460301d4Schristos     if (!Op->Asl.Node)
603460301d4Schristos     {
604460301d4Schristos         return (AE_OK);
605460301d4Schristos     }
606460301d4Schristos 
607460301d4Schristos     ParentOp = Op->Asl.Parent;
608460301d4Schristos     if (ParentOp->Asl.ParseOpcode == PARSEOP_FIELD)
609460301d4Schristos     {
610460301d4Schristos         return (AE_OK);
611460301d4Schristos     }
612460301d4Schristos 
613460301d4Schristos     if (Op->Asl.Node == Info->TargetNode)
614460301d4Schristos     {
615460301d4Schristos         while (ParentOp && (!ParentOp->Asl.Node))
616460301d4Schristos         {
617460301d4Schristos             ParentOp = ParentOp->Asl.Parent;
618460301d4Schristos         }
619460301d4Schristos 
620460301d4Schristos         if (ParentOp)
621460301d4Schristos         {
622460301d4Schristos             DevicePathname = AcpiNsGetExternalPathname (
623460301d4Schristos                 ParentOp->Asl.Node);
624460301d4Schristos 
625460301d4Schristos             if (!Info->References)
626460301d4Schristos             {
627460301d4Schristos                 FlPrintFile (ASL_FILE_MAP_OUTPUT, "  // References:");
628460301d4Schristos             }
629460301d4Schristos 
630460301d4Schristos             HidString = MpGetHidViaNamestring (DevicePathname);
631460301d4Schristos 
632460301d4Schristos             FlPrintFile (ASL_FILE_MAP_OUTPUT, " %s [%s]",
633460301d4Schristos                 DevicePathname, HidString);
634460301d4Schristos 
635460301d4Schristos             Info->References++;
636679c17fdSchristos 
637679c17fdSchristos             ACPI_FREE (DevicePathname);
638460301d4Schristos         }
639460301d4Schristos     }
640460301d4Schristos 
641460301d4Schristos     return (AE_OK);
642460301d4Schristos }
643