1100966Siwasaki/****************************************************************************** 2100966Siwasaki * 3100966Siwasaki * Module Name: nsdump - table dumping routines for debug 4100966Siwasaki * 5100966Siwasaki *****************************************************************************/ 6100966Siwasaki 7217365Sjkim/* 8245582Sjkim * Copyright (C) 2000 - 2013, 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 44100966Siwasaki#define __NSDUMPDV_C__ 45100966Siwasaki 46193341Sjkim#include <contrib/dev/acpica/include/acpi.h> 47100966Siwasaki 48100966Siwasaki 49151937Sjkim/* TBD: This entire module is apparently obsolete and should be removed */ 50151937Sjkim 51100966Siwasaki#define _COMPONENT ACPI_NAMESPACE 52100966Siwasaki ACPI_MODULE_NAME ("nsdumpdv") 53100966Siwasaki 54151937Sjkim#ifdef ACPI_OBSOLETE_FUNCTIONS 55102550Siwasaki#if defined(ACPI_DEBUG_OUTPUT) || defined(ACPI_DEBUGGER) 56100966Siwasaki 57193341Sjkim#include <contrib/dev/acpica/include/acnamesp.h> 58151937Sjkim 59100966Siwasaki/******************************************************************************* 60100966Siwasaki * 61100966Siwasaki * FUNCTION: AcpiNsDumpOneDevice 62100966Siwasaki * 63100966Siwasaki * PARAMETERS: Handle - Node to be dumped 64100966Siwasaki * Level - Nesting level of the handle 65100966Siwasaki * Context - Passed into WalkNamespace 66151937Sjkim * ReturnValue - Not used 67100966Siwasaki * 68151937Sjkim * RETURN: Status 69151937Sjkim * 70100966Siwasaki * DESCRIPTION: Dump a single Node that represents a device 71100966Siwasaki * This procedure is a UserFunction called by AcpiNsWalkNamespace. 72100966Siwasaki * 73100966Siwasaki ******************************************************************************/ 74100966Siwasaki 75151937Sjkimstatic ACPI_STATUS 76100966SiwasakiAcpiNsDumpOneDevice ( 77100966Siwasaki ACPI_HANDLE ObjHandle, 78100966Siwasaki UINT32 Level, 79100966Siwasaki void *Context, 80100966Siwasaki void **ReturnValue) 81100966Siwasaki{ 82117521Snjl ACPI_BUFFER Buffer; 83117521Snjl ACPI_DEVICE_INFO *Info; 84100966Siwasaki ACPI_STATUS Status; 85100966Siwasaki UINT32 i; 86100966Siwasaki 87100966Siwasaki 88167802Sjkim ACPI_FUNCTION_NAME (NsDumpOneDevice); 89100966Siwasaki 90100966Siwasaki 91100966Siwasaki Status = AcpiNsDumpOneObject (ObjHandle, Level, Context, ReturnValue); 92100966Siwasaki 93117521Snjl Buffer.Length = ACPI_ALLOCATE_LOCAL_BUFFER; 94117521Snjl Status = AcpiGetObjectInfo (ObjHandle, &Buffer); 95100966Siwasaki if (ACPI_SUCCESS (Status)) 96100966Siwasaki { 97117521Snjl Info = Buffer.Pointer; 98100966Siwasaki for (i = 0; i < Level; i++) 99100966Siwasaki { 100100966Siwasaki ACPI_DEBUG_PRINT_RAW ((ACPI_DB_TABLES, " ")); 101100966Siwasaki } 102100966Siwasaki 103138287Smarks ACPI_DEBUG_PRINT_RAW ((ACPI_DB_TABLES, 104138287Smarks " HID: %s, ADR: %8.8X%8.8X, Status: %X\n", 105138287Smarks Info->HardwareId.Value, ACPI_FORMAT_UINT64 (Info->Address), 106138287Smarks Info->CurrentStatus)); 107167802Sjkim ACPI_FREE (Info); 108100966Siwasaki } 109100966Siwasaki 110100966Siwasaki return (Status); 111100966Siwasaki} 112100966Siwasaki 113100966Siwasaki 114100966Siwasaki/******************************************************************************* 115100966Siwasaki * 116100966Siwasaki * FUNCTION: AcpiNsDumpRootDevices 117100966Siwasaki * 118100966Siwasaki * PARAMETERS: None 119100966Siwasaki * 120151937Sjkim * RETURN: None 121151937Sjkim * 122100966Siwasaki * DESCRIPTION: Dump all objects of type "device" 123100966Siwasaki * 124100966Siwasaki ******************************************************************************/ 125100966Siwasaki 126100966Siwasakivoid 127151937SjkimAcpiNsDumpRootDevices ( 128151937Sjkim void) 129100966Siwasaki{ 130100966Siwasaki ACPI_HANDLE SysBusHandle; 131100966Siwasaki ACPI_STATUS Status; 132100966Siwasaki 133100966Siwasaki 134167802Sjkim ACPI_FUNCTION_NAME (NsDumpRootDevices); 135100966Siwasaki 136100966Siwasaki 137100966Siwasaki /* Only dump the table if tracing is enabled */ 138100966Siwasaki 139100966Siwasaki if (!(ACPI_LV_TABLES & AcpiDbgLevel)) 140100966Siwasaki { 141100966Siwasaki return; 142100966Siwasaki } 143100966Siwasaki 144233250Sjkim Status = AcpiGetHandle (NULL, METHOD_NAME__SB_, &SysBusHandle); 145100966Siwasaki if (ACPI_FAILURE (Status)) 146100966Siwasaki { 147100966Siwasaki return; 148100966Siwasaki } 149100966Siwasaki 150138287Smarks ACPI_DEBUG_PRINT ((ACPI_DB_TABLES, 151138287Smarks "Display of all devices in the namespace:\n")); 152100966Siwasaki 153102550Siwasaki Status = AcpiNsWalkNamespace (ACPI_TYPE_DEVICE, SysBusHandle, 154100966Siwasaki ACPI_UINT32_MAX, ACPI_NS_WALK_NO_UNLOCK, 155199337Sjkim AcpiNsDumpOneDevice, NULL, NULL, NULL); 156100966Siwasaki} 157100966Siwasaki 158100966Siwasaki#endif 159151937Sjkim#endif 160