1*a159c266SJung-uk Kim /****************************************************************************** 2*a159c266SJung-uk Kim * 3*a159c266SJung-uk Kim * Module Name: dsinit - Object initialization namespace walk 4*a159c266SJung-uk Kim * 5*a159c266SJung-uk Kim *****************************************************************************/ 6*a159c266SJung-uk Kim 7*a159c266SJung-uk Kim /* 8*a159c266SJung-uk Kim * Copyright (C) 2000 - 2012, Intel Corp. 9*a159c266SJung-uk Kim * All rights reserved. 10*a159c266SJung-uk Kim * 11*a159c266SJung-uk Kim * Redistribution and use in source and binary forms, with or without 12*a159c266SJung-uk Kim * modification, are permitted provided that the following conditions 13*a159c266SJung-uk Kim * are met: 14*a159c266SJung-uk Kim * 1. Redistributions of source code must retain the above copyright 15*a159c266SJung-uk Kim * notice, this list of conditions, and the following disclaimer, 16*a159c266SJung-uk Kim * without modification. 17*a159c266SJung-uk Kim * 2. Redistributions in binary form must reproduce at minimum a disclaimer 18*a159c266SJung-uk Kim * substantially similar to the "NO WARRANTY" disclaimer below 19*a159c266SJung-uk Kim * ("Disclaimer") and any redistribution must be conditioned upon 20*a159c266SJung-uk Kim * including a substantially similar Disclaimer requirement for further 21*a159c266SJung-uk Kim * binary redistribution. 22*a159c266SJung-uk Kim * 3. Neither the names of the above-listed copyright holders nor the names 23*a159c266SJung-uk Kim * of any contributors may be used to endorse or promote products derived 24*a159c266SJung-uk Kim * from this software without specific prior written permission. 25*a159c266SJung-uk Kim * 26*a159c266SJung-uk Kim * Alternatively, this software may be distributed under the terms of the 27*a159c266SJung-uk Kim * GNU General Public License ("GPL") version 2 as published by the Free 28*a159c266SJung-uk Kim * Software Foundation. 29*a159c266SJung-uk Kim * 30*a159c266SJung-uk Kim * NO WARRANTY 31*a159c266SJung-uk Kim * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 32*a159c266SJung-uk Kim * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 33*a159c266SJung-uk Kim * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR 34*a159c266SJung-uk Kim * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 35*a159c266SJung-uk Kim * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 36*a159c266SJung-uk Kim * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 37*a159c266SJung-uk Kim * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 38*a159c266SJung-uk Kim * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, 39*a159c266SJung-uk Kim * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING 40*a159c266SJung-uk Kim * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 41*a159c266SJung-uk Kim * POSSIBILITY OF SUCH DAMAGES. 42*a159c266SJung-uk Kim */ 43*a159c266SJung-uk Kim 44*a159c266SJung-uk Kim #define __DSINIT_C__ 45*a159c266SJung-uk Kim 46*a159c266SJung-uk Kim #include <contrib/dev/acpica/include/acpi.h> 47*a159c266SJung-uk Kim #include <contrib/dev/acpica/include/accommon.h> 48*a159c266SJung-uk Kim #include <contrib/dev/acpica/include/acdispat.h> 49*a159c266SJung-uk Kim #include <contrib/dev/acpica/include/acnamesp.h> 50*a159c266SJung-uk Kim #include <contrib/dev/acpica/include/actables.h> 51*a159c266SJung-uk Kim 52*a159c266SJung-uk Kim #define _COMPONENT ACPI_DISPATCHER 53*a159c266SJung-uk Kim ACPI_MODULE_NAME ("dsinit") 54*a159c266SJung-uk Kim 55*a159c266SJung-uk Kim /* Local prototypes */ 56*a159c266SJung-uk Kim 57*a159c266SJung-uk Kim static ACPI_STATUS 58*a159c266SJung-uk Kim AcpiDsInitOneObject ( 59*a159c266SJung-uk Kim ACPI_HANDLE ObjHandle, 60*a159c266SJung-uk Kim UINT32 Level, 61*a159c266SJung-uk Kim void *Context, 62*a159c266SJung-uk Kim void **ReturnValue); 63*a159c266SJung-uk Kim 64*a159c266SJung-uk Kim 65*a159c266SJung-uk Kim /******************************************************************************* 66*a159c266SJung-uk Kim * 67*a159c266SJung-uk Kim * FUNCTION: AcpiDsInitOneObject 68*a159c266SJung-uk Kim * 69*a159c266SJung-uk Kim * PARAMETERS: ObjHandle - Node for the object 70*a159c266SJung-uk Kim * Level - Current nesting level 71*a159c266SJung-uk Kim * Context - Points to a init info struct 72*a159c266SJung-uk Kim * ReturnValue - Not used 73*a159c266SJung-uk Kim * 74*a159c266SJung-uk Kim * RETURN: Status 75*a159c266SJung-uk Kim * 76*a159c266SJung-uk Kim * DESCRIPTION: Callback from AcpiWalkNamespace. Invoked for every object 77*a159c266SJung-uk Kim * within the namespace. 78*a159c266SJung-uk Kim * 79*a159c266SJung-uk Kim * Currently, the only objects that require initialization are: 80*a159c266SJung-uk Kim * 1) Methods 81*a159c266SJung-uk Kim * 2) Operation Regions 82*a159c266SJung-uk Kim * 83*a159c266SJung-uk Kim ******************************************************************************/ 84*a159c266SJung-uk Kim 85*a159c266SJung-uk Kim static ACPI_STATUS 86*a159c266SJung-uk Kim AcpiDsInitOneObject ( 87*a159c266SJung-uk Kim ACPI_HANDLE ObjHandle, 88*a159c266SJung-uk Kim UINT32 Level, 89*a159c266SJung-uk Kim void *Context, 90*a159c266SJung-uk Kim void **ReturnValue) 91*a159c266SJung-uk Kim { 92*a159c266SJung-uk Kim ACPI_INIT_WALK_INFO *Info = (ACPI_INIT_WALK_INFO *) Context; 93*a159c266SJung-uk Kim ACPI_NAMESPACE_NODE *Node = (ACPI_NAMESPACE_NODE *) ObjHandle; 94*a159c266SJung-uk Kim ACPI_OBJECT_TYPE Type; 95*a159c266SJung-uk Kim ACPI_STATUS Status; 96*a159c266SJung-uk Kim 97*a159c266SJung-uk Kim 98*a159c266SJung-uk Kim ACPI_FUNCTION_ENTRY (); 99*a159c266SJung-uk Kim 100*a159c266SJung-uk Kim 101*a159c266SJung-uk Kim /* 102*a159c266SJung-uk Kim * We are only interested in NS nodes owned by the table that 103*a159c266SJung-uk Kim * was just loaded 104*a159c266SJung-uk Kim */ 105*a159c266SJung-uk Kim if (Node->OwnerId != Info->OwnerId) 106*a159c266SJung-uk Kim { 107*a159c266SJung-uk Kim return (AE_OK); 108*a159c266SJung-uk Kim } 109*a159c266SJung-uk Kim 110*a159c266SJung-uk Kim Info->ObjectCount++; 111*a159c266SJung-uk Kim 112*a159c266SJung-uk Kim /* And even then, we are only interested in a few object types */ 113*a159c266SJung-uk Kim 114*a159c266SJung-uk Kim Type = AcpiNsGetType (ObjHandle); 115*a159c266SJung-uk Kim 116*a159c266SJung-uk Kim switch (Type) 117*a159c266SJung-uk Kim { 118*a159c266SJung-uk Kim case ACPI_TYPE_REGION: 119*a159c266SJung-uk Kim 120*a159c266SJung-uk Kim Status = AcpiDsInitializeRegion (ObjHandle); 121*a159c266SJung-uk Kim if (ACPI_FAILURE (Status)) 122*a159c266SJung-uk Kim { 123*a159c266SJung-uk Kim ACPI_EXCEPTION ((AE_INFO, Status, 124*a159c266SJung-uk Kim "During Region initialization %p [%4.4s]", 125*a159c266SJung-uk Kim ObjHandle, AcpiUtGetNodeName (ObjHandle))); 126*a159c266SJung-uk Kim } 127*a159c266SJung-uk Kim 128*a159c266SJung-uk Kim Info->OpRegionCount++; 129*a159c266SJung-uk Kim break; 130*a159c266SJung-uk Kim 131*a159c266SJung-uk Kim 132*a159c266SJung-uk Kim case ACPI_TYPE_METHOD: 133*a159c266SJung-uk Kim 134*a159c266SJung-uk Kim Info->MethodCount++; 135*a159c266SJung-uk Kim break; 136*a159c266SJung-uk Kim 137*a159c266SJung-uk Kim 138*a159c266SJung-uk Kim case ACPI_TYPE_DEVICE: 139*a159c266SJung-uk Kim 140*a159c266SJung-uk Kim Info->DeviceCount++; 141*a159c266SJung-uk Kim break; 142*a159c266SJung-uk Kim 143*a159c266SJung-uk Kim 144*a159c266SJung-uk Kim default: 145*a159c266SJung-uk Kim break; 146*a159c266SJung-uk Kim } 147*a159c266SJung-uk Kim 148*a159c266SJung-uk Kim /* 149*a159c266SJung-uk Kim * We ignore errors from above, and always return OK, since 150*a159c266SJung-uk Kim * we don't want to abort the walk on a single error. 151*a159c266SJung-uk Kim */ 152*a159c266SJung-uk Kim return (AE_OK); 153*a159c266SJung-uk Kim } 154*a159c266SJung-uk Kim 155*a159c266SJung-uk Kim 156*a159c266SJung-uk Kim /******************************************************************************* 157*a159c266SJung-uk Kim * 158*a159c266SJung-uk Kim * FUNCTION: AcpiDsInitializeObjects 159*a159c266SJung-uk Kim * 160*a159c266SJung-uk Kim * PARAMETERS: TableDesc - Descriptor for parent ACPI table 161*a159c266SJung-uk Kim * StartNode - Root of subtree to be initialized. 162*a159c266SJung-uk Kim * 163*a159c266SJung-uk Kim * RETURN: Status 164*a159c266SJung-uk Kim * 165*a159c266SJung-uk Kim * DESCRIPTION: Walk the namespace starting at "StartNode" and perform any 166*a159c266SJung-uk Kim * necessary initialization on the objects found therein 167*a159c266SJung-uk Kim * 168*a159c266SJung-uk Kim ******************************************************************************/ 169*a159c266SJung-uk Kim 170*a159c266SJung-uk Kim ACPI_STATUS 171*a159c266SJung-uk Kim AcpiDsInitializeObjects ( 172*a159c266SJung-uk Kim UINT32 TableIndex, 173*a159c266SJung-uk Kim ACPI_NAMESPACE_NODE *StartNode) 174*a159c266SJung-uk Kim { 175*a159c266SJung-uk Kim ACPI_STATUS Status; 176*a159c266SJung-uk Kim ACPI_INIT_WALK_INFO Info; 177*a159c266SJung-uk Kim ACPI_TABLE_HEADER *Table; 178*a159c266SJung-uk Kim ACPI_OWNER_ID OwnerId; 179*a159c266SJung-uk Kim 180*a159c266SJung-uk Kim 181*a159c266SJung-uk Kim ACPI_FUNCTION_TRACE (DsInitializeObjects); 182*a159c266SJung-uk Kim 183*a159c266SJung-uk Kim 184*a159c266SJung-uk Kim Status = AcpiTbGetOwnerId (TableIndex, &OwnerId); 185*a159c266SJung-uk Kim if (ACPI_FAILURE (Status)) 186*a159c266SJung-uk Kim { 187*a159c266SJung-uk Kim return_ACPI_STATUS (Status); 188*a159c266SJung-uk Kim } 189*a159c266SJung-uk Kim 190*a159c266SJung-uk Kim ACPI_DEBUG_PRINT ((ACPI_DB_DISPATCH, 191*a159c266SJung-uk Kim "**** Starting initialization of namespace objects ****\n")); 192*a159c266SJung-uk Kim ACPI_DEBUG_PRINT_RAW ((ACPI_DB_INIT, "Parsing all Control Methods:")); 193*a159c266SJung-uk Kim 194*a159c266SJung-uk Kim /* Set all init info to zero */ 195*a159c266SJung-uk Kim 196*a159c266SJung-uk Kim ACPI_MEMSET (&Info, 0, sizeof (ACPI_INIT_WALK_INFO)); 197*a159c266SJung-uk Kim 198*a159c266SJung-uk Kim Info.OwnerId = OwnerId; 199*a159c266SJung-uk Kim Info.TableIndex = TableIndex; 200*a159c266SJung-uk Kim 201*a159c266SJung-uk Kim /* Walk entire namespace from the supplied root */ 202*a159c266SJung-uk Kim 203*a159c266SJung-uk Kim Status = AcpiUtAcquireMutex (ACPI_MTX_NAMESPACE); 204*a159c266SJung-uk Kim if (ACPI_FAILURE (Status)) 205*a159c266SJung-uk Kim { 206*a159c266SJung-uk Kim return_ACPI_STATUS (Status); 207*a159c266SJung-uk Kim } 208*a159c266SJung-uk Kim 209*a159c266SJung-uk Kim /* 210*a159c266SJung-uk Kim * We don't use AcpiWalkNamespace since we do not want to acquire 211*a159c266SJung-uk Kim * the namespace reader lock. 212*a159c266SJung-uk Kim */ 213*a159c266SJung-uk Kim Status = AcpiNsWalkNamespace (ACPI_TYPE_ANY, StartNode, ACPI_UINT32_MAX, 214*a159c266SJung-uk Kim ACPI_NS_WALK_UNLOCK, AcpiDsInitOneObject, NULL, &Info, NULL); 215*a159c266SJung-uk Kim if (ACPI_FAILURE (Status)) 216*a159c266SJung-uk Kim { 217*a159c266SJung-uk Kim ACPI_EXCEPTION ((AE_INFO, Status, "During WalkNamespace")); 218*a159c266SJung-uk Kim } 219*a159c266SJung-uk Kim (void) AcpiUtReleaseMutex (ACPI_MTX_NAMESPACE); 220*a159c266SJung-uk Kim 221*a159c266SJung-uk Kim Status = AcpiGetTableByIndex (TableIndex, &Table); 222*a159c266SJung-uk Kim if (ACPI_FAILURE (Status)) 223*a159c266SJung-uk Kim { 224*a159c266SJung-uk Kim return_ACPI_STATUS (Status); 225*a159c266SJung-uk Kim } 226*a159c266SJung-uk Kim 227*a159c266SJung-uk Kim ACPI_DEBUG_PRINT_RAW ((ACPI_DB_INIT, 228*a159c266SJung-uk Kim "\nTable [%4.4s](id %4.4X) - %u Objects with %u Devices %u Methods %u Regions\n", 229*a159c266SJung-uk Kim Table->Signature, OwnerId, Info.ObjectCount, 230*a159c266SJung-uk Kim Info.DeviceCount, Info.MethodCount, Info.OpRegionCount)); 231*a159c266SJung-uk Kim 232*a159c266SJung-uk Kim ACPI_DEBUG_PRINT ((ACPI_DB_DISPATCH, 233*a159c266SJung-uk Kim "%u Methods, %u Regions\n", Info.MethodCount, Info.OpRegionCount)); 234*a159c266SJung-uk Kim 235*a159c266SJung-uk Kim return_ACPI_STATUS (AE_OK); 236*a159c266SJung-uk Kim } 237*a159c266SJung-uk Kim 238*a159c266SJung-uk Kim 239