10d02842fSSascha Wildner /****************************************************************************** 20d02842fSSascha Wildner * 30d02842fSSascha Wildner * Name: acpiosxf.h - All interfaces to the OS Services Layer (OSL). These 40d02842fSSascha Wildner * interfaces must be implemented by OSL to interface the 50d02842fSSascha Wildner * ACPI components to the host operating system. 60d02842fSSascha Wildner * 70d02842fSSascha Wildner *****************************************************************************/ 80d02842fSSascha Wildner 9b4315fc7SSascha Wildner /****************************************************************************** 10b4315fc7SSascha Wildner * 11b4315fc7SSascha Wildner * 1. Copyright Notice 12b4315fc7SSascha Wildner * 13*383048acSSascha Wildner * Some or all of this work - Copyright (c) 1999 - 2021, Intel Corp. 140d02842fSSascha Wildner * All rights reserved. 150d02842fSSascha Wildner * 16b4315fc7SSascha Wildner * 2. License 17b4315fc7SSascha Wildner * 18b4315fc7SSascha Wildner * 2.1. This is your license from Intel Corp. under its intellectual property 19b4315fc7SSascha Wildner * rights. You may have additional license terms from the party that provided 20b4315fc7SSascha Wildner * you this software, covering your right to use that party's intellectual 21b4315fc7SSascha Wildner * property rights. 22b4315fc7SSascha Wildner * 23b4315fc7SSascha Wildner * 2.2. Intel grants, free of charge, to any person ("Licensee") obtaining a 24b4315fc7SSascha Wildner * copy of the source code appearing in this file ("Covered Code") an 25b4315fc7SSascha Wildner * irrevocable, perpetual, worldwide license under Intel's copyrights in the 26b4315fc7SSascha Wildner * base code distributed originally by Intel ("Original Intel Code") to copy, 27b4315fc7SSascha Wildner * make derivatives, distribute, use and display any portion of the Covered 28b4315fc7SSascha Wildner * Code in any form, with the right to sublicense such rights; and 29b4315fc7SSascha Wildner * 30b4315fc7SSascha Wildner * 2.3. Intel grants Licensee a non-exclusive and non-transferable patent 31b4315fc7SSascha Wildner * license (with the right to sublicense), under only those claims of Intel 32b4315fc7SSascha Wildner * patents that are infringed by the Original Intel Code, to make, use, sell, 33b4315fc7SSascha Wildner * offer to sell, and import the Covered Code and derivative works thereof 34b4315fc7SSascha Wildner * solely to the minimum extent necessary to exercise the above copyright 35b4315fc7SSascha Wildner * license, and in no event shall the patent license extend to any additions 36b4315fc7SSascha Wildner * to or modifications of the Original Intel Code. No other license or right 37b4315fc7SSascha Wildner * is granted directly or by implication, estoppel or otherwise; 38b4315fc7SSascha Wildner * 39b4315fc7SSascha Wildner * The above copyright and patent license is granted only if the following 40b4315fc7SSascha Wildner * conditions are met: 41b4315fc7SSascha Wildner * 42b4315fc7SSascha Wildner * 3. Conditions 43b4315fc7SSascha Wildner * 44b4315fc7SSascha Wildner * 3.1. Redistribution of Source with Rights to Further Distribute Source. 45b4315fc7SSascha Wildner * Redistribution of source code of any substantial portion of the Covered 46b4315fc7SSascha Wildner * Code or modification with rights to further distribute source must include 47b4315fc7SSascha Wildner * the above Copyright Notice, the above License, this list of Conditions, 48b4315fc7SSascha Wildner * and the following Disclaimer and Export Compliance provision. In addition, 49b4315fc7SSascha Wildner * Licensee must cause all Covered Code to which Licensee contributes to 50b4315fc7SSascha Wildner * contain a file documenting the changes Licensee made to create that Covered 51b4315fc7SSascha Wildner * Code and the date of any change. Licensee must include in that file the 52b4315fc7SSascha Wildner * documentation of any changes made by any predecessor Licensee. Licensee 53b4315fc7SSascha Wildner * must include a prominent statement that the modification is derived, 54b4315fc7SSascha Wildner * directly or indirectly, from Original Intel Code. 55b4315fc7SSascha Wildner * 56b4315fc7SSascha Wildner * 3.2. Redistribution of Source with no Rights to Further Distribute Source. 57b4315fc7SSascha Wildner * Redistribution of source code of any substantial portion of the Covered 58b4315fc7SSascha Wildner * Code or modification without rights to further distribute source must 59b4315fc7SSascha Wildner * include the following Disclaimer and Export Compliance provision in the 60b4315fc7SSascha Wildner * documentation and/or other materials provided with distribution. In 61b4315fc7SSascha Wildner * addition, Licensee may not authorize further sublicense of source of any 62b4315fc7SSascha Wildner * portion of the Covered Code, and must include terms to the effect that the 63b4315fc7SSascha Wildner * license from Licensee to its licensee is limited to the intellectual 64b4315fc7SSascha Wildner * property embodied in the software Licensee provides to its licensee, and 65b4315fc7SSascha Wildner * not to intellectual property embodied in modifications its licensee may 66b4315fc7SSascha Wildner * make. 67b4315fc7SSascha Wildner * 68b4315fc7SSascha Wildner * 3.3. Redistribution of Executable. Redistribution in executable form of any 69b4315fc7SSascha Wildner * substantial portion of the Covered Code or modification must reproduce the 70b4315fc7SSascha Wildner * above Copyright Notice, and the following Disclaimer and Export Compliance 71b4315fc7SSascha Wildner * provision in the documentation and/or other materials provided with the 72b4315fc7SSascha Wildner * distribution. 73b4315fc7SSascha Wildner * 74b4315fc7SSascha Wildner * 3.4. Intel retains all right, title, and interest in and to the Original 75b4315fc7SSascha Wildner * Intel Code. 76b4315fc7SSascha Wildner * 77b4315fc7SSascha Wildner * 3.5. Neither the name Intel nor any other trademark owned or controlled by 78b4315fc7SSascha Wildner * Intel shall be used in advertising or otherwise to promote the sale, use or 79b4315fc7SSascha Wildner * other dealings in products derived from or relating to the Covered Code 80b4315fc7SSascha Wildner * without prior written authorization from Intel. 81b4315fc7SSascha Wildner * 82b4315fc7SSascha Wildner * 4. Disclaimer and Export Compliance 83b4315fc7SSascha Wildner * 84b4315fc7SSascha Wildner * 4.1. INTEL MAKES NO WARRANTY OF ANY KIND REGARDING ANY SOFTWARE PROVIDED 85b4315fc7SSascha Wildner * HERE. ANY SOFTWARE ORIGINATING FROM INTEL OR DERIVED FROM INTEL SOFTWARE 86b4315fc7SSascha Wildner * IS PROVIDED "AS IS," AND INTEL WILL NOT PROVIDE ANY SUPPORT, ASSISTANCE, 87b4315fc7SSascha Wildner * INSTALLATION, TRAINING OR OTHER SERVICES. INTEL WILL NOT PROVIDE ANY 88b4315fc7SSascha Wildner * UPDATES, ENHANCEMENTS OR EXTENSIONS. INTEL SPECIFICALLY DISCLAIMS ANY 89b4315fc7SSascha Wildner * IMPLIED WARRANTIES OF MERCHANTABILITY, NONINFRINGEMENT AND FITNESS FOR A 90b4315fc7SSascha Wildner * PARTICULAR PURPOSE. 91b4315fc7SSascha Wildner * 92b4315fc7SSascha Wildner * 4.2. IN NO EVENT SHALL INTEL HAVE ANY LIABILITY TO LICENSEE, ITS LICENSEES 93b4315fc7SSascha Wildner * OR ANY OTHER THIRD PARTY, FOR ANY LOST PROFITS, LOST DATA, LOSS OF USE OR 94b4315fc7SSascha Wildner * COSTS OF PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES, OR FOR ANY INDIRECT, 95b4315fc7SSascha Wildner * SPECIAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THIS AGREEMENT, UNDER ANY 96b4315fc7SSascha Wildner * CAUSE OF ACTION OR THEORY OF LIABILITY, AND IRRESPECTIVE OF WHETHER INTEL 97b4315fc7SSascha Wildner * HAS ADVANCE NOTICE OF THE POSSIBILITY OF SUCH DAMAGES. THESE LIMITATIONS 98b4315fc7SSascha Wildner * SHALL APPLY NOTWITHSTANDING THE FAILURE OF THE ESSENTIAL PURPOSE OF ANY 99b4315fc7SSascha Wildner * LIMITED REMEDY. 100b4315fc7SSascha Wildner * 101b4315fc7SSascha Wildner * 4.3. Licensee shall not export, either directly or indirectly, any of this 102b4315fc7SSascha Wildner * software or system incorporating such software without first obtaining any 103b4315fc7SSascha Wildner * required license or other approval from the U. S. Department of Commerce or 104b4315fc7SSascha Wildner * any other agency or department of the United States Government. In the 105b4315fc7SSascha Wildner * event Licensee exports any such software from the United States or 106b4315fc7SSascha Wildner * re-exports any such software from a foreign destination, Licensee shall 107b4315fc7SSascha Wildner * ensure that the distribution and export/re-export of the software is in 108b4315fc7SSascha Wildner * compliance with all laws, regulations, orders, or other restrictions of the 109b4315fc7SSascha Wildner * U.S. Export Administration Regulations. Licensee agrees that neither it nor 110b4315fc7SSascha Wildner * any of its subsidiaries will export/re-export any technical data, process, 111b4315fc7SSascha Wildner * software, or service, directly or indirectly, to any country for which the 112b4315fc7SSascha Wildner * United States government or any agency thereof requires an export license, 113b4315fc7SSascha Wildner * other governmental approval, or letter of assurance, without first obtaining 114b4315fc7SSascha Wildner * such license, approval or letter. 115b4315fc7SSascha Wildner * 116b4315fc7SSascha Wildner ***************************************************************************** 117b4315fc7SSascha Wildner * 118b4315fc7SSascha Wildner * Alternatively, you may choose to be licensed under the terms of the 119b4315fc7SSascha Wildner * following license: 120b4315fc7SSascha Wildner * 1210d02842fSSascha Wildner * Redistribution and use in source and binary forms, with or without 1220d02842fSSascha Wildner * modification, are permitted provided that the following conditions 1230d02842fSSascha Wildner * are met: 1240d02842fSSascha Wildner * 1. Redistributions of source code must retain the above copyright 1250d02842fSSascha Wildner * notice, this list of conditions, and the following disclaimer, 1260d02842fSSascha Wildner * without modification. 1270d02842fSSascha Wildner * 2. Redistributions in binary form must reproduce at minimum a disclaimer 1280d02842fSSascha Wildner * substantially similar to the "NO WARRANTY" disclaimer below 1290d02842fSSascha Wildner * ("Disclaimer") and any redistribution must be conditioned upon 1300d02842fSSascha Wildner * including a substantially similar Disclaimer requirement for further 1310d02842fSSascha Wildner * binary redistribution. 1320d02842fSSascha Wildner * 3. Neither the names of the above-listed copyright holders nor the names 1330d02842fSSascha Wildner * of any contributors may be used to endorse or promote products derived 1340d02842fSSascha Wildner * from this software without specific prior written permission. 1350d02842fSSascha Wildner * 136b4315fc7SSascha Wildner * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 137b4315fc7SSascha Wildner * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 138b4315fc7SSascha Wildner * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 139b4315fc7SSascha Wildner * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 140b4315fc7SSascha Wildner * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 141b4315fc7SSascha Wildner * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 142b4315fc7SSascha Wildner * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 143b4315fc7SSascha Wildner * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 144b4315fc7SSascha Wildner * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 145b4315fc7SSascha Wildner * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 146b4315fc7SSascha Wildner * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 147b4315fc7SSascha Wildner * 148b4315fc7SSascha Wildner * Alternatively, you may choose to be licensed under the terms of the 1490d02842fSSascha Wildner * GNU General Public License ("GPL") version 2 as published by the Free 1500d02842fSSascha Wildner * Software Foundation. 1510d02842fSSascha Wildner * 152b4315fc7SSascha Wildner *****************************************************************************/ 1530d02842fSSascha Wildner 1540d02842fSSascha Wildner #ifndef __ACPIOSXF_H__ 1550d02842fSSascha Wildner #define __ACPIOSXF_H__ 1560d02842fSSascha Wildner 1570d02842fSSascha Wildner #include "platform/acenv.h" 1580d02842fSSascha Wildner #include "actypes.h" 1590d02842fSSascha Wildner 1600d02842fSSascha Wildner 1610d02842fSSascha Wildner /* Types for AcpiOsExecute */ 1620d02842fSSascha Wildner 1630d02842fSSascha Wildner typedef enum 1640d02842fSSascha Wildner { 1650d02842fSSascha Wildner OSL_GLOBAL_LOCK_HANDLER, 1660d02842fSSascha Wildner OSL_NOTIFY_HANDLER, 1670d02842fSSascha Wildner OSL_GPE_HANDLER, 168820c5b08SSascha Wildner OSL_DEBUGGER_MAIN_THREAD, 169820c5b08SSascha Wildner OSL_DEBUGGER_EXEC_THREAD, 1700d02842fSSascha Wildner OSL_EC_POLL_HANDLER, 1710d02842fSSascha Wildner OSL_EC_BURST_HANDLER 1720d02842fSSascha Wildner 1730d02842fSSascha Wildner } ACPI_EXECUTE_TYPE; 1740d02842fSSascha Wildner 1750d02842fSSascha Wildner #define ACPI_NO_UNIT_LIMIT ((UINT32) -1) 1760d02842fSSascha Wildner #define ACPI_MUTEX_SEM 1 1770d02842fSSascha Wildner 1780d02842fSSascha Wildner 1790d02842fSSascha Wildner /* Functions for AcpiOsSignal */ 1800d02842fSSascha Wildner 1810d02842fSSascha Wildner #define ACPI_SIGNAL_FATAL 0 1820d02842fSSascha Wildner #define ACPI_SIGNAL_BREAKPOINT 1 1830d02842fSSascha Wildner 1840d02842fSSascha Wildner typedef struct acpi_signal_fatal_info 1850d02842fSSascha Wildner { 1860d02842fSSascha Wildner UINT32 Type; 1870d02842fSSascha Wildner UINT32 Code; 1880d02842fSSascha Wildner UINT32 Argument; 1890d02842fSSascha Wildner 1900d02842fSSascha Wildner } ACPI_SIGNAL_FATAL_INFO; 1910d02842fSSascha Wildner 1920d02842fSSascha Wildner 1930d02842fSSascha Wildner /* 1940d02842fSSascha Wildner * OSL Initialization and shutdown primitives 1950d02842fSSascha Wildner */ 1960d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsInitialize 1970d02842fSSascha Wildner ACPI_STATUS 1980d02842fSSascha Wildner AcpiOsInitialize ( 1990d02842fSSascha Wildner void); 2000d02842fSSascha Wildner #endif 2010d02842fSSascha Wildner 2020d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsTerminate 2030d02842fSSascha Wildner ACPI_STATUS 2040d02842fSSascha Wildner AcpiOsTerminate ( 2050d02842fSSascha Wildner void); 2060d02842fSSascha Wildner #endif 2070d02842fSSascha Wildner 2080d02842fSSascha Wildner 2090d02842fSSascha Wildner /* 2100d02842fSSascha Wildner * ACPI Table interfaces 2110d02842fSSascha Wildner */ 2120d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetRootPointer 2130d02842fSSascha Wildner ACPI_PHYSICAL_ADDRESS 2140d02842fSSascha Wildner AcpiOsGetRootPointer ( 2150d02842fSSascha Wildner void); 2160d02842fSSascha Wildner #endif 2170d02842fSSascha Wildner 2180d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsPredefinedOverride 2190d02842fSSascha Wildner ACPI_STATUS 2200d02842fSSascha Wildner AcpiOsPredefinedOverride ( 2210d02842fSSascha Wildner const ACPI_PREDEFINED_NAMES *InitVal, 2220d02842fSSascha Wildner ACPI_STRING *NewVal); 2230d02842fSSascha Wildner #endif 2240d02842fSSascha Wildner 2250d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsTableOverride 2260d02842fSSascha Wildner ACPI_STATUS 2270d02842fSSascha Wildner AcpiOsTableOverride ( 2280d02842fSSascha Wildner ACPI_TABLE_HEADER *ExistingTable, 2290d02842fSSascha Wildner ACPI_TABLE_HEADER **NewTable); 2300d02842fSSascha Wildner #endif 2310d02842fSSascha Wildner 2320d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsPhysicalTableOverride 2330d02842fSSascha Wildner ACPI_STATUS 2340d02842fSSascha Wildner AcpiOsPhysicalTableOverride ( 2350d02842fSSascha Wildner ACPI_TABLE_HEADER *ExistingTable, 2360d02842fSSascha Wildner ACPI_PHYSICAL_ADDRESS *NewAddress, 2370d02842fSSascha Wildner UINT32 *NewTableLength); 2380d02842fSSascha Wildner #endif 2390d02842fSSascha Wildner 2400d02842fSSascha Wildner 2410d02842fSSascha Wildner /* 2420d02842fSSascha Wildner * Spinlock primitives 2430d02842fSSascha Wildner */ 2440d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsCreateLock 2450d02842fSSascha Wildner ACPI_STATUS 2460d02842fSSascha Wildner AcpiOsCreateLock ( 2470d02842fSSascha Wildner ACPI_SPINLOCK *OutHandle); 2480d02842fSSascha Wildner #endif 2490d02842fSSascha Wildner 2500d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsDeleteLock 2510d02842fSSascha Wildner void 2520d02842fSSascha Wildner AcpiOsDeleteLock ( 2530d02842fSSascha Wildner ACPI_SPINLOCK Handle); 2540d02842fSSascha Wildner #endif 2550d02842fSSascha Wildner 2560d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsAcquireLock 2570d02842fSSascha Wildner ACPI_CPU_FLAGS 2580d02842fSSascha Wildner AcpiOsAcquireLock ( 2590d02842fSSascha Wildner ACPI_SPINLOCK Handle); 2600d02842fSSascha Wildner #endif 2610d02842fSSascha Wildner 2620d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsReleaseLock 2630d02842fSSascha Wildner void 2640d02842fSSascha Wildner AcpiOsReleaseLock ( 2650d02842fSSascha Wildner ACPI_SPINLOCK Handle, 2660d02842fSSascha Wildner ACPI_CPU_FLAGS Flags); 2670d02842fSSascha Wildner #endif 2680d02842fSSascha Wildner 2690d02842fSSascha Wildner 2700d02842fSSascha Wildner /* 2710d02842fSSascha Wildner * Semaphore primitives 2720d02842fSSascha Wildner */ 2730d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsCreateSemaphore 2740d02842fSSascha Wildner ACPI_STATUS 2750d02842fSSascha Wildner AcpiOsCreateSemaphore ( 2760d02842fSSascha Wildner UINT32 MaxUnits, 2770d02842fSSascha Wildner UINT32 InitialUnits, 2780d02842fSSascha Wildner ACPI_SEMAPHORE *OutHandle); 2790d02842fSSascha Wildner #endif 2800d02842fSSascha Wildner 2810d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsDeleteSemaphore 2820d02842fSSascha Wildner ACPI_STATUS 2830d02842fSSascha Wildner AcpiOsDeleteSemaphore ( 2840d02842fSSascha Wildner ACPI_SEMAPHORE Handle); 2850d02842fSSascha Wildner #endif 2860d02842fSSascha Wildner 2870d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsWaitSemaphore 2880d02842fSSascha Wildner ACPI_STATUS 2890d02842fSSascha Wildner AcpiOsWaitSemaphore ( 2900d02842fSSascha Wildner ACPI_SEMAPHORE Handle, 2910d02842fSSascha Wildner UINT32 Units, 2920d02842fSSascha Wildner UINT16 Timeout); 2930d02842fSSascha Wildner #endif 2940d02842fSSascha Wildner 2950d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsSignalSemaphore 2960d02842fSSascha Wildner ACPI_STATUS 2970d02842fSSascha Wildner AcpiOsSignalSemaphore ( 2980d02842fSSascha Wildner ACPI_SEMAPHORE Handle, 2990d02842fSSascha Wildner UINT32 Units); 3000d02842fSSascha Wildner #endif 3010d02842fSSascha Wildner 3020d02842fSSascha Wildner 3030d02842fSSascha Wildner /* 3040d02842fSSascha Wildner * Mutex primitives. May be configured to use semaphores instead via 3050d02842fSSascha Wildner * ACPI_MUTEX_TYPE (see platform/acenv.h) 3060d02842fSSascha Wildner */ 3070d02842fSSascha Wildner #if (ACPI_MUTEX_TYPE != ACPI_BINARY_SEMAPHORE) 3080d02842fSSascha Wildner 3090d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsCreateMutex 3100d02842fSSascha Wildner ACPI_STATUS 3110d02842fSSascha Wildner AcpiOsCreateMutex ( 3120d02842fSSascha Wildner ACPI_MUTEX *OutHandle); 3130d02842fSSascha Wildner #endif 3140d02842fSSascha Wildner 3150d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsDeleteMutex 3160d02842fSSascha Wildner void 3170d02842fSSascha Wildner AcpiOsDeleteMutex ( 3180d02842fSSascha Wildner ACPI_MUTEX Handle); 3190d02842fSSascha Wildner #endif 3200d02842fSSascha Wildner 3210d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsAcquireMutex 3220d02842fSSascha Wildner ACPI_STATUS 3230d02842fSSascha Wildner AcpiOsAcquireMutex ( 3240d02842fSSascha Wildner ACPI_MUTEX Handle, 3250d02842fSSascha Wildner UINT16 Timeout); 3260d02842fSSascha Wildner #endif 3270d02842fSSascha Wildner 3280d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsReleaseMutex 3290d02842fSSascha Wildner void 3300d02842fSSascha Wildner AcpiOsReleaseMutex ( 3310d02842fSSascha Wildner ACPI_MUTEX Handle); 3320d02842fSSascha Wildner #endif 3330d02842fSSascha Wildner 3340d02842fSSascha Wildner #endif 3350d02842fSSascha Wildner 3360d02842fSSascha Wildner 3370d02842fSSascha Wildner /* 3380d02842fSSascha Wildner * Memory allocation and mapping 3390d02842fSSascha Wildner */ 3400d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsAllocate 3410d02842fSSascha Wildner void * 3420d02842fSSascha Wildner AcpiOsAllocate ( 3430d02842fSSascha Wildner ACPI_SIZE Size); 3440d02842fSSascha Wildner #endif 3450d02842fSSascha Wildner 3460d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsAllocateZeroed 3470d02842fSSascha Wildner void * 3480d02842fSSascha Wildner AcpiOsAllocateZeroed ( 3490d02842fSSascha Wildner ACPI_SIZE Size); 3500d02842fSSascha Wildner #endif 3510d02842fSSascha Wildner 3520d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsFree 3530d02842fSSascha Wildner void 3540d02842fSSascha Wildner AcpiOsFree ( 3550d02842fSSascha Wildner void * Memory); 3560d02842fSSascha Wildner #endif 3570d02842fSSascha Wildner 3580d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsMapMemory 3590d02842fSSascha Wildner void * 3600d02842fSSascha Wildner AcpiOsMapMemory ( 3610d02842fSSascha Wildner ACPI_PHYSICAL_ADDRESS Where, 3620d02842fSSascha Wildner ACPI_SIZE Length); 3630d02842fSSascha Wildner #endif 3640d02842fSSascha Wildner 3650d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsUnmapMemory 3660d02842fSSascha Wildner void 3670d02842fSSascha Wildner AcpiOsUnmapMemory ( 3680d02842fSSascha Wildner void *LogicalAddress, 3690d02842fSSascha Wildner ACPI_SIZE Size); 3700d02842fSSascha Wildner #endif 3710d02842fSSascha Wildner 3720d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetPhysicalAddress 3730d02842fSSascha Wildner ACPI_STATUS 3740d02842fSSascha Wildner AcpiOsGetPhysicalAddress ( 3750d02842fSSascha Wildner void *LogicalAddress, 3760d02842fSSascha Wildner ACPI_PHYSICAL_ADDRESS *PhysicalAddress); 3770d02842fSSascha Wildner #endif 3780d02842fSSascha Wildner 3790d02842fSSascha Wildner 3800d02842fSSascha Wildner /* 3810d02842fSSascha Wildner * Memory/Object Cache 3820d02842fSSascha Wildner */ 3830d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsCreateCache 3840d02842fSSascha Wildner ACPI_STATUS 3850d02842fSSascha Wildner AcpiOsCreateCache ( 3860d02842fSSascha Wildner char *CacheName, 3870d02842fSSascha Wildner UINT16 ObjectSize, 3880d02842fSSascha Wildner UINT16 MaxDepth, 3890d02842fSSascha Wildner ACPI_CACHE_T **ReturnCache); 3900d02842fSSascha Wildner #endif 3910d02842fSSascha Wildner 3920d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsDeleteCache 3930d02842fSSascha Wildner ACPI_STATUS 3940d02842fSSascha Wildner AcpiOsDeleteCache ( 3950d02842fSSascha Wildner ACPI_CACHE_T *Cache); 3960d02842fSSascha Wildner #endif 3970d02842fSSascha Wildner 3980d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsPurgeCache 3990d02842fSSascha Wildner ACPI_STATUS 4000d02842fSSascha Wildner AcpiOsPurgeCache ( 4010d02842fSSascha Wildner ACPI_CACHE_T *Cache); 4020d02842fSSascha Wildner #endif 4030d02842fSSascha Wildner 4040d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsAcquireObject 4050d02842fSSascha Wildner void * 4060d02842fSSascha Wildner AcpiOsAcquireObject ( 4070d02842fSSascha Wildner ACPI_CACHE_T *Cache); 4080d02842fSSascha Wildner #endif 4090d02842fSSascha Wildner 4100d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsReleaseObject 4110d02842fSSascha Wildner ACPI_STATUS 4120d02842fSSascha Wildner AcpiOsReleaseObject ( 4130d02842fSSascha Wildner ACPI_CACHE_T *Cache, 4140d02842fSSascha Wildner void *Object); 4150d02842fSSascha Wildner #endif 4160d02842fSSascha Wildner 4170d02842fSSascha Wildner 4180d02842fSSascha Wildner /* 4190d02842fSSascha Wildner * Interrupt handlers 4200d02842fSSascha Wildner */ 4210d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsInstallInterruptHandler 4220d02842fSSascha Wildner ACPI_STATUS 4230d02842fSSascha Wildner AcpiOsInstallInterruptHandler ( 4240d02842fSSascha Wildner UINT32 InterruptNumber, 4250d02842fSSascha Wildner ACPI_OSD_HANDLER ServiceRoutine, 4260d02842fSSascha Wildner void *Context); 4270d02842fSSascha Wildner #endif 4280d02842fSSascha Wildner 4290d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsRemoveInterruptHandler 4300d02842fSSascha Wildner ACPI_STATUS 4310d02842fSSascha Wildner AcpiOsRemoveInterruptHandler ( 4320d02842fSSascha Wildner UINT32 InterruptNumber, 4330d02842fSSascha Wildner ACPI_OSD_HANDLER ServiceRoutine); 4340d02842fSSascha Wildner #endif 4350d02842fSSascha Wildner 4360d02842fSSascha Wildner 4370d02842fSSascha Wildner /* 4380d02842fSSascha Wildner * Threads and Scheduling 4390d02842fSSascha Wildner */ 4400d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetThreadId 4410d02842fSSascha Wildner ACPI_THREAD_ID 4420d02842fSSascha Wildner AcpiOsGetThreadId ( 4430d02842fSSascha Wildner void); 4440d02842fSSascha Wildner #endif 4450d02842fSSascha Wildner 4460d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsExecute 4470d02842fSSascha Wildner ACPI_STATUS 4480d02842fSSascha Wildner AcpiOsExecute ( 4490d02842fSSascha Wildner ACPI_EXECUTE_TYPE Type, 4500d02842fSSascha Wildner ACPI_OSD_EXEC_CALLBACK Function, 4510d02842fSSascha Wildner void *Context); 4520d02842fSSascha Wildner #endif 4530d02842fSSascha Wildner 4540d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsWaitEventsComplete 4550d02842fSSascha Wildner void 4560d02842fSSascha Wildner AcpiOsWaitEventsComplete ( 4570d02842fSSascha Wildner void); 4580d02842fSSascha Wildner #endif 4590d02842fSSascha Wildner 4600d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsSleep 4610d02842fSSascha Wildner void 4620d02842fSSascha Wildner AcpiOsSleep ( 4630d02842fSSascha Wildner UINT64 Milliseconds); 4640d02842fSSascha Wildner #endif 4650d02842fSSascha Wildner 4660d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsStall 4670d02842fSSascha Wildner void 4680d02842fSSascha Wildner AcpiOsStall ( 4690d02842fSSascha Wildner UINT32 Microseconds); 4700d02842fSSascha Wildner #endif 4710d02842fSSascha Wildner 4720d02842fSSascha Wildner 4730d02842fSSascha Wildner /* 4740d02842fSSascha Wildner * Platform and hardware-independent I/O interfaces 4750d02842fSSascha Wildner */ 4760d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsReadPort 4770d02842fSSascha Wildner ACPI_STATUS 4780d02842fSSascha Wildner AcpiOsReadPort ( 4790d02842fSSascha Wildner ACPI_IO_ADDRESS Address, 4800d02842fSSascha Wildner UINT32 *Value, 4810d02842fSSascha Wildner UINT32 Width); 4820d02842fSSascha Wildner #endif 4830d02842fSSascha Wildner 4840d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsWritePort 4850d02842fSSascha Wildner ACPI_STATUS 4860d02842fSSascha Wildner AcpiOsWritePort ( 4870d02842fSSascha Wildner ACPI_IO_ADDRESS Address, 4880d02842fSSascha Wildner UINT32 Value, 4890d02842fSSascha Wildner UINT32 Width); 4900d02842fSSascha Wildner #endif 4910d02842fSSascha Wildner 4920d02842fSSascha Wildner 4930d02842fSSascha Wildner /* 4940d02842fSSascha Wildner * Platform and hardware-independent physical memory interfaces 4950d02842fSSascha Wildner */ 4960d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsReadMemory 4970d02842fSSascha Wildner ACPI_STATUS 4980d02842fSSascha Wildner AcpiOsReadMemory ( 4990d02842fSSascha Wildner ACPI_PHYSICAL_ADDRESS Address, 5000d02842fSSascha Wildner UINT64 *Value, 5010d02842fSSascha Wildner UINT32 Width); 5020d02842fSSascha Wildner #endif 5030d02842fSSascha Wildner 5040d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsWriteMemory 5050d02842fSSascha Wildner ACPI_STATUS 5060d02842fSSascha Wildner AcpiOsWriteMemory ( 5070d02842fSSascha Wildner ACPI_PHYSICAL_ADDRESS Address, 5080d02842fSSascha Wildner UINT64 Value, 5090d02842fSSascha Wildner UINT32 Width); 5100d02842fSSascha Wildner #endif 5110d02842fSSascha Wildner 5120d02842fSSascha Wildner 5130d02842fSSascha Wildner /* 5140d02842fSSascha Wildner * Platform and hardware-independent PCI configuration space access 5150d02842fSSascha Wildner * Note: Can't use "Register" as a parameter, changed to "Reg" -- 5160d02842fSSascha Wildner * certain compilers complain. 5170d02842fSSascha Wildner */ 5180d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsReadPciConfiguration 5190d02842fSSascha Wildner ACPI_STATUS 5200d02842fSSascha Wildner AcpiOsReadPciConfiguration ( 5210d02842fSSascha Wildner ACPI_PCI_ID *PciId, 5220d02842fSSascha Wildner UINT32 Reg, 5230d02842fSSascha Wildner UINT64 *Value, 5240d02842fSSascha Wildner UINT32 Width); 5250d02842fSSascha Wildner #endif 5260d02842fSSascha Wildner 5270d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsWritePciConfiguration 5280d02842fSSascha Wildner ACPI_STATUS 5290d02842fSSascha Wildner AcpiOsWritePciConfiguration ( 5300d02842fSSascha Wildner ACPI_PCI_ID *PciId, 5310d02842fSSascha Wildner UINT32 Reg, 5320d02842fSSascha Wildner UINT64 Value, 5330d02842fSSascha Wildner UINT32 Width); 5340d02842fSSascha Wildner #endif 5350d02842fSSascha Wildner 5360d02842fSSascha Wildner 5370d02842fSSascha Wildner /* 5380d02842fSSascha Wildner * Miscellaneous 5390d02842fSSascha Wildner */ 5400d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsReadable 5410d02842fSSascha Wildner BOOLEAN 5420d02842fSSascha Wildner AcpiOsReadable ( 5430d02842fSSascha Wildner void *Pointer, 5440d02842fSSascha Wildner ACPI_SIZE Length); 5450d02842fSSascha Wildner #endif 5460d02842fSSascha Wildner 5470d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsWritable 5480d02842fSSascha Wildner BOOLEAN 5490d02842fSSascha Wildner AcpiOsWritable ( 5500d02842fSSascha Wildner void *Pointer, 5510d02842fSSascha Wildner ACPI_SIZE Length); 5520d02842fSSascha Wildner #endif 5530d02842fSSascha Wildner 5540d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetTimer 5550d02842fSSascha Wildner UINT64 5560d02842fSSascha Wildner AcpiOsGetTimer ( 5570d02842fSSascha Wildner void); 5580d02842fSSascha Wildner #endif 5590d02842fSSascha Wildner 5600d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsSignal 5610d02842fSSascha Wildner ACPI_STATUS 5620d02842fSSascha Wildner AcpiOsSignal ( 5630d02842fSSascha Wildner UINT32 Function, 5640d02842fSSascha Wildner void *Info); 5650d02842fSSascha Wildner #endif 5660d02842fSSascha Wildner 56738b5d46cSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsEnterSleep 56838b5d46cSSascha Wildner ACPI_STATUS 56938b5d46cSSascha Wildner AcpiOsEnterSleep ( 57038b5d46cSSascha Wildner UINT8 SleepState, 57138b5d46cSSascha Wildner UINT32 RegaValue, 57238b5d46cSSascha Wildner UINT32 RegbValue); 57338b5d46cSSascha Wildner #endif 57438b5d46cSSascha Wildner 5750d02842fSSascha Wildner 5760d02842fSSascha Wildner /* 5770d02842fSSascha Wildner * Debug print routines 5780d02842fSSascha Wildner */ 5790d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsPrintf 580e5412f1eSSascha Wildner ACPI_PRINTF_LIKE (1) 5810d02842fSSascha Wildner void ACPI_INTERNAL_VAR_XFACE 5820d02842fSSascha Wildner AcpiOsPrintf ( 5830d02842fSSascha Wildner const char *Format, 5840d02842fSSascha Wildner ...); 5850d02842fSSascha Wildner #endif 5860d02842fSSascha Wildner 5870d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsVprintf 5880d02842fSSascha Wildner void 5890d02842fSSascha Wildner AcpiOsVprintf ( 5900d02842fSSascha Wildner const char *Format, 5910d02842fSSascha Wildner va_list Args); 5920d02842fSSascha Wildner #endif 5930d02842fSSascha Wildner 5940d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsRedirectOutput 5950d02842fSSascha Wildner void 5960d02842fSSascha Wildner AcpiOsRedirectOutput ( 5970d02842fSSascha Wildner void *Destination); 5980d02842fSSascha Wildner #endif 5990d02842fSSascha Wildner 6000d02842fSSascha Wildner 6010d02842fSSascha Wildner /* 60238b5d46cSSascha Wildner * Debug IO 6030d02842fSSascha Wildner */ 6040d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetLine 6050d02842fSSascha Wildner ACPI_STATUS 6060d02842fSSascha Wildner AcpiOsGetLine ( 6070d02842fSSascha Wildner char *Buffer, 6080d02842fSSascha Wildner UINT32 BufferLength, 6090d02842fSSascha Wildner UINT32 *BytesRead); 6100d02842fSSascha Wildner #endif 6110d02842fSSascha Wildner 61238b5d46cSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsInitializeDebugger 61338b5d46cSSascha Wildner ACPI_STATUS 61438b5d46cSSascha Wildner AcpiOsInitializeDebugger ( 61538b5d46cSSascha Wildner void); 61638b5d46cSSascha Wildner #endif 61738b5d46cSSascha Wildner 61838b5d46cSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsTerminateDebugger 61938b5d46cSSascha Wildner void 62038b5d46cSSascha Wildner AcpiOsTerminateDebugger ( 62138b5d46cSSascha Wildner void); 62238b5d46cSSascha Wildner #endif 62338b5d46cSSascha Wildner 62438b5d46cSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsWaitCommandReady 62538b5d46cSSascha Wildner ACPI_STATUS 62638b5d46cSSascha Wildner AcpiOsWaitCommandReady ( 62738b5d46cSSascha Wildner void); 62838b5d46cSSascha Wildner #endif 62938b5d46cSSascha Wildner 63038b5d46cSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsNotifyCommandComplete 63138b5d46cSSascha Wildner ACPI_STATUS 63238b5d46cSSascha Wildner AcpiOsNotifyCommandComplete ( 63338b5d46cSSascha Wildner void); 63438b5d46cSSascha Wildner #endif 63538b5d46cSSascha Wildner 636277350a0SSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsTracePoint 637277350a0SSascha Wildner void 638277350a0SSascha Wildner AcpiOsTracePoint ( 639277350a0SSascha Wildner ACPI_TRACE_EVENT_TYPE Type, 640277350a0SSascha Wildner BOOLEAN Begin, 641277350a0SSascha Wildner UINT8 *Aml, 642277350a0SSascha Wildner char *Pathname); 643277350a0SSascha Wildner #endif 644277350a0SSascha Wildner 6450d02842fSSascha Wildner 6460d02842fSSascha Wildner /* 6470d02842fSSascha Wildner * Obtain ACPI table(s) 6480d02842fSSascha Wildner */ 6490d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetTableByName 6500d02842fSSascha Wildner ACPI_STATUS 6510d02842fSSascha Wildner AcpiOsGetTableByName ( 6520d02842fSSascha Wildner char *Signature, 6530d02842fSSascha Wildner UINT32 Instance, 6540d02842fSSascha Wildner ACPI_TABLE_HEADER **Table, 6550d02842fSSascha Wildner ACPI_PHYSICAL_ADDRESS *Address); 6560d02842fSSascha Wildner #endif 6570d02842fSSascha Wildner 6580d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetTableByIndex 6590d02842fSSascha Wildner ACPI_STATUS 6600d02842fSSascha Wildner AcpiOsGetTableByIndex ( 6610d02842fSSascha Wildner UINT32 Index, 6620d02842fSSascha Wildner ACPI_TABLE_HEADER **Table, 6630d02842fSSascha Wildner UINT32 *Instance, 6640d02842fSSascha Wildner ACPI_PHYSICAL_ADDRESS *Address); 6650d02842fSSascha Wildner #endif 6660d02842fSSascha Wildner 6670d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetTableByAddress 6680d02842fSSascha Wildner ACPI_STATUS 6690d02842fSSascha Wildner AcpiOsGetTableByAddress ( 6700d02842fSSascha Wildner ACPI_PHYSICAL_ADDRESS Address, 6710d02842fSSascha Wildner ACPI_TABLE_HEADER **Table); 6720d02842fSSascha Wildner #endif 6730d02842fSSascha Wildner 6740d02842fSSascha Wildner 6750d02842fSSascha Wildner /* 6760d02842fSSascha Wildner * Directory manipulation 6770d02842fSSascha Wildner */ 6780d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsOpenDirectory 6790d02842fSSascha Wildner void * 6800d02842fSSascha Wildner AcpiOsOpenDirectory ( 6810d02842fSSascha Wildner char *Pathname, 6820d02842fSSascha Wildner char *WildcardSpec, 6830d02842fSSascha Wildner char RequestedFileType); 6840d02842fSSascha Wildner #endif 6850d02842fSSascha Wildner 6860d02842fSSascha Wildner /* RequesteFileType values */ 6870d02842fSSascha Wildner 6880d02842fSSascha Wildner #define REQUEST_FILE_ONLY 0 6890d02842fSSascha Wildner #define REQUEST_DIR_ONLY 1 6900d02842fSSascha Wildner 6910d02842fSSascha Wildner 6920d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetNextFilename 6930d02842fSSascha Wildner char * 6940d02842fSSascha Wildner AcpiOsGetNextFilename ( 6950d02842fSSascha Wildner void *DirHandle); 6960d02842fSSascha Wildner #endif 6970d02842fSSascha Wildner 6980d02842fSSascha Wildner #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsCloseDirectory 6990d02842fSSascha Wildner void 7000d02842fSSascha Wildner AcpiOsCloseDirectory ( 7010d02842fSSascha Wildner void *DirHandle); 7020d02842fSSascha Wildner #endif 7030d02842fSSascha Wildner 7040d02842fSSascha Wildner 7050d02842fSSascha Wildner #endif /* __ACPIOSXF_H__ */ 706