1100966Siwasaki/****************************************************************************** 2100966Siwasaki * 3100966Siwasaki * Module Name: nsdump - table dumping routines for debug 4100966Siwasaki * 5100966Siwasaki *****************************************************************************/ 6100966Siwasaki 7217365Sjkim/* 8306536Sjkim * Copyright (C) 2000 - 2016, Intel Corp. 9100966Siwasaki * All rights reserved. 10100966Siwasaki * 11217365Sjkim * Redistribution and use in source and binary forms, with or without 12217365Sjkim * modification, are permitted provided that the following conditions 13217365Sjkim * are met: 14217365Sjkim * 1. Redistributions of source code must retain the above copyright 15217365Sjkim * notice, this list of conditions, and the following disclaimer, 16217365Sjkim * without modification. 17217365Sjkim * 2. Redistributions in binary form must reproduce at minimum a disclaimer 18217365Sjkim * substantially similar to the "NO WARRANTY" disclaimer below 19217365Sjkim * ("Disclaimer") and any redistribution must be conditioned upon 20217365Sjkim * including a substantially similar Disclaimer requirement for further 21217365Sjkim * binary redistribution. 22217365Sjkim * 3. Neither the names of the above-listed copyright holders nor the names 23217365Sjkim * of any contributors may be used to endorse or promote products derived 24217365Sjkim * from this software without specific prior written permission. 25100966Siwasaki * 26217365Sjkim * Alternatively, this software may be distributed under the terms of the 27217365Sjkim * GNU General Public License ("GPL") version 2 as published by the Free 28217365Sjkim * Software Foundation. 29100966Siwasaki * 30217365Sjkim * NO WARRANTY 31217365Sjkim * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 32217365Sjkim * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 33217365Sjkim * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR 34217365Sjkim * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 35217365Sjkim * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 36217365Sjkim * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 37217365Sjkim * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 38217365Sjkim * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, 39217365Sjkim * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING 40217365Sjkim * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 41217365Sjkim * POSSIBILITY OF SUCH DAMAGES. 42217365Sjkim */ 43100966Siwasaki 44193341Sjkim#include <contrib/dev/acpica/include/acpi.h> 45100966Siwasaki 46100966Siwasaki 47151937Sjkim/* TBD: This entire module is apparently obsolete and should be removed */ 48151937Sjkim 49100966Siwasaki#define _COMPONENT ACPI_NAMESPACE 50100966Siwasaki ACPI_MODULE_NAME ("nsdumpdv") 51100966Siwasaki 52151937Sjkim#ifdef ACPI_OBSOLETE_FUNCTIONS 53102550Siwasaki#if defined(ACPI_DEBUG_OUTPUT) || defined(ACPI_DEBUGGER) 54100966Siwasaki 55193341Sjkim#include <contrib/dev/acpica/include/acnamesp.h> 56151937Sjkim 57100966Siwasaki/******************************************************************************* 58100966Siwasaki * 59100966Siwasaki * FUNCTION: AcpiNsDumpOneDevice 60100966Siwasaki * 61100966Siwasaki * PARAMETERS: Handle - Node to be dumped 62100966Siwasaki * Level - Nesting level of the handle 63100966Siwasaki * Context - Passed into WalkNamespace 64151937Sjkim * ReturnValue - Not used 65100966Siwasaki * 66151937Sjkim * RETURN: Status 67151937Sjkim * 68100966Siwasaki * DESCRIPTION: Dump a single Node that represents a device 69100966Siwasaki * This procedure is a UserFunction called by AcpiNsWalkNamespace. 70100966Siwasaki * 71100966Siwasaki ******************************************************************************/ 72100966Siwasaki 73151937Sjkimstatic ACPI_STATUS 74100966SiwasakiAcpiNsDumpOneDevice ( 75100966Siwasaki ACPI_HANDLE ObjHandle, 76100966Siwasaki UINT32 Level, 77100966Siwasaki void *Context, 78100966Siwasaki void **ReturnValue) 79100966Siwasaki{ 80117521Snjl ACPI_BUFFER Buffer; 81117521Snjl ACPI_DEVICE_INFO *Info; 82100966Siwasaki ACPI_STATUS Status; 83100966Siwasaki UINT32 i; 84100966Siwasaki 85100966Siwasaki 86167802Sjkim ACPI_FUNCTION_NAME (NsDumpOneDevice); 87100966Siwasaki 88100966Siwasaki 89100966Siwasaki Status = AcpiNsDumpOneObject (ObjHandle, Level, Context, ReturnValue); 90100966Siwasaki 91117521Snjl Buffer.Length = ACPI_ALLOCATE_LOCAL_BUFFER; 92117521Snjl Status = AcpiGetObjectInfo (ObjHandle, &Buffer); 93100966Siwasaki if (ACPI_SUCCESS (Status)) 94100966Siwasaki { 95117521Snjl Info = Buffer.Pointer; 96100966Siwasaki for (i = 0; i < Level; i++) 97100966Siwasaki { 98100966Siwasaki ACPI_DEBUG_PRINT_RAW ((ACPI_DB_TABLES, " ")); 99100966Siwasaki } 100100966Siwasaki 101138287Smarks ACPI_DEBUG_PRINT_RAW ((ACPI_DB_TABLES, 102138287Smarks " HID: %s, ADR: %8.8X%8.8X, Status: %X\n", 103138287Smarks Info->HardwareId.Value, ACPI_FORMAT_UINT64 (Info->Address), 104138287Smarks Info->CurrentStatus)); 105167802Sjkim ACPI_FREE (Info); 106100966Siwasaki } 107100966Siwasaki 108100966Siwasaki return (Status); 109100966Siwasaki} 110100966Siwasaki 111100966Siwasaki 112100966Siwasaki/******************************************************************************* 113100966Siwasaki * 114100966Siwasaki * FUNCTION: AcpiNsDumpRootDevices 115100966Siwasaki * 116100966Siwasaki * PARAMETERS: None 117100966Siwasaki * 118151937Sjkim * RETURN: None 119151937Sjkim * 120100966Siwasaki * DESCRIPTION: Dump all objects of type "device" 121100966Siwasaki * 122100966Siwasaki ******************************************************************************/ 123100966Siwasaki 124100966Siwasakivoid 125151937SjkimAcpiNsDumpRootDevices ( 126151937Sjkim void) 127100966Siwasaki{ 128100966Siwasaki ACPI_HANDLE SysBusHandle; 129100966Siwasaki ACPI_STATUS Status; 130100966Siwasaki 131100966Siwasaki 132167802Sjkim ACPI_FUNCTION_NAME (NsDumpRootDevices); 133100966Siwasaki 134100966Siwasaki 135100966Siwasaki /* Only dump the table if tracing is enabled */ 136100966Siwasaki 137100966Siwasaki if (!(ACPI_LV_TABLES & AcpiDbgLevel)) 138100966Siwasaki { 139100966Siwasaki return; 140100966Siwasaki } 141100966Siwasaki 142233250Sjkim Status = AcpiGetHandle (NULL, METHOD_NAME__SB_, &SysBusHandle); 143100966Siwasaki if (ACPI_FAILURE (Status)) 144100966Siwasaki { 145100966Siwasaki return; 146100966Siwasaki } 147100966Siwasaki 148138287Smarks ACPI_DEBUG_PRINT ((ACPI_DB_TABLES, 149138287Smarks "Display of all devices in the namespace:\n")); 150100966Siwasaki 151102550Siwasaki Status = AcpiNsWalkNamespace (ACPI_TYPE_DEVICE, SysBusHandle, 152306536Sjkim ACPI_UINT32_MAX, ACPI_NS_WALK_NO_UNLOCK, 153306536Sjkim AcpiNsDumpOneDevice, NULL, NULL, NULL); 154100966Siwasaki} 155100966Siwasaki 156100966Siwasaki#endif 157151937Sjkim#endif 158