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