1*ffef6827SLin Ming /******************************************************************************* 2*ffef6827SLin Ming * 3*ffef6827SLin Ming * Module Name: utxfmutex - external AML mutex access functions 4*ffef6827SLin Ming * 5*ffef6827SLin Ming ******************************************************************************/ 6*ffef6827SLin Ming 7*ffef6827SLin Ming /* 8*ffef6827SLin Ming * Copyright (C) 2000 - 2011, Intel Corp. 9*ffef6827SLin Ming * All rights reserved. 10*ffef6827SLin Ming * 11*ffef6827SLin Ming * Redistribution and use in source and binary forms, with or without 12*ffef6827SLin Ming * modification, are permitted provided that the following conditions 13*ffef6827SLin Ming * are met: 14*ffef6827SLin Ming * 1. Redistributions of source code must retain the above copyright 15*ffef6827SLin Ming * notice, this list of conditions, and the following disclaimer, 16*ffef6827SLin Ming * without modification. 17*ffef6827SLin Ming * 2. Redistributions in binary form must reproduce at minimum a disclaimer 18*ffef6827SLin Ming * substantially similar to the "NO WARRANTY" disclaimer below 19*ffef6827SLin Ming * ("Disclaimer") and any redistribution must be conditioned upon 20*ffef6827SLin Ming * including a substantially similar Disclaimer requirement for further 21*ffef6827SLin Ming * binary redistribution. 22*ffef6827SLin Ming * 3. Neither the names of the above-listed copyright holders nor the names 23*ffef6827SLin Ming * of any contributors may be used to endorse or promote products derived 24*ffef6827SLin Ming * from this software without specific prior written permission. 25*ffef6827SLin Ming * 26*ffef6827SLin Ming * Alternatively, this software may be distributed under the terms of the 27*ffef6827SLin Ming * GNU General Public License ("GPL") version 2 as published by the Free 28*ffef6827SLin Ming * Software Foundation. 29*ffef6827SLin Ming * 30*ffef6827SLin Ming * NO WARRANTY 31*ffef6827SLin Ming * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 32*ffef6827SLin Ming * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 33*ffef6827SLin Ming * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR 34*ffef6827SLin Ming * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 35*ffef6827SLin Ming * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 36*ffef6827SLin Ming * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 37*ffef6827SLin Ming * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 38*ffef6827SLin Ming * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, 39*ffef6827SLin Ming * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING 40*ffef6827SLin Ming * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 41*ffef6827SLin Ming * POSSIBILITY OF SUCH DAMAGES. 42*ffef6827SLin Ming */ 43*ffef6827SLin Ming 44*ffef6827SLin Ming #include <acpi/acpi.h> 45*ffef6827SLin Ming #include "accommon.h" 46*ffef6827SLin Ming #include "acnamesp.h" 47*ffef6827SLin Ming 48*ffef6827SLin Ming #define _COMPONENT ACPI_UTILITIES 49*ffef6827SLin Ming ACPI_MODULE_NAME("utxfmutex") 50*ffef6827SLin Ming 51*ffef6827SLin Ming /* Local prototypes */ 52*ffef6827SLin Ming static acpi_status 53*ffef6827SLin Ming acpi_ut_get_mutex_object(acpi_handle handle, 54*ffef6827SLin Ming acpi_string pathname, 55*ffef6827SLin Ming union acpi_operand_object **ret_obj); 56*ffef6827SLin Ming 57*ffef6827SLin Ming /******************************************************************************* 58*ffef6827SLin Ming * 59*ffef6827SLin Ming * FUNCTION: acpi_ut_get_mutex_object 60*ffef6827SLin Ming * 61*ffef6827SLin Ming * PARAMETERS: Handle - Mutex or prefix handle (optional) 62*ffef6827SLin Ming * Pathname - Mutex pathname (optional) 63*ffef6827SLin Ming * ret_obj - Where the mutex object is returned 64*ffef6827SLin Ming * 65*ffef6827SLin Ming * RETURN: Status 66*ffef6827SLin Ming * 67*ffef6827SLin Ming * DESCRIPTION: Get an AML mutex object. The mutex node is pointed to by 68*ffef6827SLin Ming * Handle:Pathname. Either Handle or Pathname can be NULL, but 69*ffef6827SLin Ming * not both. 70*ffef6827SLin Ming * 71*ffef6827SLin Ming ******************************************************************************/ 72*ffef6827SLin Ming 73*ffef6827SLin Ming static acpi_status 74*ffef6827SLin Ming acpi_ut_get_mutex_object(acpi_handle handle, 75*ffef6827SLin Ming acpi_string pathname, 76*ffef6827SLin Ming union acpi_operand_object **ret_obj) 77*ffef6827SLin Ming { 78*ffef6827SLin Ming struct acpi_namespace_node *mutex_node; 79*ffef6827SLin Ming union acpi_operand_object *mutex_obj; 80*ffef6827SLin Ming acpi_status status; 81*ffef6827SLin Ming 82*ffef6827SLin Ming /* Parameter validation */ 83*ffef6827SLin Ming 84*ffef6827SLin Ming if (!ret_obj || (!handle && !pathname)) { 85*ffef6827SLin Ming return (AE_BAD_PARAMETER); 86*ffef6827SLin Ming } 87*ffef6827SLin Ming 88*ffef6827SLin Ming /* Get a the namespace node for the mutex */ 89*ffef6827SLin Ming 90*ffef6827SLin Ming mutex_node = handle; 91*ffef6827SLin Ming if (pathname != NULL) { 92*ffef6827SLin Ming status = acpi_get_handle(handle, pathname, 93*ffef6827SLin Ming ACPI_CAST_PTR(acpi_handle, 94*ffef6827SLin Ming &mutex_node)); 95*ffef6827SLin Ming if (ACPI_FAILURE(status)) { 96*ffef6827SLin Ming return (status); 97*ffef6827SLin Ming } 98*ffef6827SLin Ming } 99*ffef6827SLin Ming 100*ffef6827SLin Ming /* Ensure that we actually have a Mutex object */ 101*ffef6827SLin Ming 102*ffef6827SLin Ming if (!mutex_node || (mutex_node->type != ACPI_TYPE_MUTEX)) { 103*ffef6827SLin Ming return (AE_TYPE); 104*ffef6827SLin Ming } 105*ffef6827SLin Ming 106*ffef6827SLin Ming /* Get the low-level mutex object */ 107*ffef6827SLin Ming 108*ffef6827SLin Ming mutex_obj = acpi_ns_get_attached_object(mutex_node); 109*ffef6827SLin Ming if (!mutex_obj) { 110*ffef6827SLin Ming return (AE_NULL_OBJECT); 111*ffef6827SLin Ming } 112*ffef6827SLin Ming 113*ffef6827SLin Ming *ret_obj = mutex_obj; 114*ffef6827SLin Ming return (AE_OK); 115*ffef6827SLin Ming } 116*ffef6827SLin Ming 117*ffef6827SLin Ming /******************************************************************************* 118*ffef6827SLin Ming * 119*ffef6827SLin Ming * FUNCTION: acpi_acquire_mutex 120*ffef6827SLin Ming * 121*ffef6827SLin Ming * PARAMETERS: Handle - Mutex or prefix handle (optional) 122*ffef6827SLin Ming * Pathname - Mutex pathname (optional) 123*ffef6827SLin Ming * Timeout - Max time to wait for the lock (millisec) 124*ffef6827SLin Ming * 125*ffef6827SLin Ming * RETURN: Status 126*ffef6827SLin Ming * 127*ffef6827SLin Ming * DESCRIPTION: Acquire an AML mutex. This is a device driver interface to 128*ffef6827SLin Ming * AML mutex objects, and allows for transaction locking between 129*ffef6827SLin Ming * drivers and AML code. The mutex node is pointed to by 130*ffef6827SLin Ming * Handle:Pathname. Either Handle or Pathname can be NULL, but 131*ffef6827SLin Ming * not both. 132*ffef6827SLin Ming * 133*ffef6827SLin Ming ******************************************************************************/ 134*ffef6827SLin Ming 135*ffef6827SLin Ming acpi_status 136*ffef6827SLin Ming acpi_acquire_mutex(acpi_handle handle, acpi_string pathname, u16 timeout) 137*ffef6827SLin Ming { 138*ffef6827SLin Ming acpi_status status; 139*ffef6827SLin Ming union acpi_operand_object *mutex_obj; 140*ffef6827SLin Ming 141*ffef6827SLin Ming /* Get the low-level mutex associated with Handle:Pathname */ 142*ffef6827SLin Ming 143*ffef6827SLin Ming status = acpi_ut_get_mutex_object(handle, pathname, &mutex_obj); 144*ffef6827SLin Ming if (ACPI_FAILURE(status)) { 145*ffef6827SLin Ming return (status); 146*ffef6827SLin Ming } 147*ffef6827SLin Ming 148*ffef6827SLin Ming /* Acquire the OS mutex */ 149*ffef6827SLin Ming 150*ffef6827SLin Ming status = acpi_os_acquire_mutex(mutex_obj->mutex.os_mutex, timeout); 151*ffef6827SLin Ming return (status); 152*ffef6827SLin Ming } 153*ffef6827SLin Ming 154*ffef6827SLin Ming /******************************************************************************* 155*ffef6827SLin Ming * 156*ffef6827SLin Ming * FUNCTION: acpi_release_mutex 157*ffef6827SLin Ming * 158*ffef6827SLin Ming * PARAMETERS: Handle - Mutex or prefix handle (optional) 159*ffef6827SLin Ming * Pathname - Mutex pathname (optional) 160*ffef6827SLin Ming * 161*ffef6827SLin Ming * RETURN: Status 162*ffef6827SLin Ming * 163*ffef6827SLin Ming * DESCRIPTION: Release an AML mutex. This is a device driver interface to 164*ffef6827SLin Ming * AML mutex objects, and allows for transaction locking between 165*ffef6827SLin Ming * drivers and AML code. The mutex node is pointed to by 166*ffef6827SLin Ming * Handle:Pathname. Either Handle or Pathname can be NULL, but 167*ffef6827SLin Ming * not both. 168*ffef6827SLin Ming * 169*ffef6827SLin Ming ******************************************************************************/ 170*ffef6827SLin Ming 171*ffef6827SLin Ming acpi_status acpi_release_mutex(acpi_handle handle, acpi_string pathname) 172*ffef6827SLin Ming { 173*ffef6827SLin Ming acpi_status status; 174*ffef6827SLin Ming union acpi_operand_object *mutex_obj; 175*ffef6827SLin Ming 176*ffef6827SLin Ming /* Get the low-level mutex associated with Handle:Pathname */ 177*ffef6827SLin Ming 178*ffef6827SLin Ming status = acpi_ut_get_mutex_object(handle, pathname, &mutex_obj); 179*ffef6827SLin Ming if (ACPI_FAILURE(status)) { 180*ffef6827SLin Ming return (status); 181*ffef6827SLin Ming } 182*ffef6827SLin Ming 183*ffef6827SLin Ming /* Release the OS mutex */ 184*ffef6827SLin Ming 185*ffef6827SLin Ming acpi_os_release_mutex(mutex_obj->mutex.os_mutex); 186*ffef6827SLin Ming return (AE_OK); 187*ffef6827SLin Ming } 188