17c478bd9Sstevel@tonic-gate 27c478bd9Sstevel@tonic-gate /****************************************************************************** 37c478bd9Sstevel@tonic-gate * 47c478bd9Sstevel@tonic-gate * Name: acpiosxf.h - All interfaces to the OS Services Layer (OSL). These 57c478bd9Sstevel@tonic-gate * interfaces must be implemented by OSL to interface the 67c478bd9Sstevel@tonic-gate * ACPI components to the host operating system. 77c478bd9Sstevel@tonic-gate * 87c478bd9Sstevel@tonic-gate *****************************************************************************/ 97c478bd9Sstevel@tonic-gate 107c478bd9Sstevel@tonic-gate 117c478bd9Sstevel@tonic-gate /****************************************************************************** 127c478bd9Sstevel@tonic-gate * 137c478bd9Sstevel@tonic-gate * 1. Copyright Notice 147c478bd9Sstevel@tonic-gate * 1530082d0cSmyers * Some or all of this work - Copyright (c) 1999 - 2006, Intel Corp. 167c478bd9Sstevel@tonic-gate * All rights reserved. 177c478bd9Sstevel@tonic-gate * 187c478bd9Sstevel@tonic-gate * 2. License 197c478bd9Sstevel@tonic-gate * 207c478bd9Sstevel@tonic-gate * 2.1. This is your license from Intel Corp. under its intellectual property 217c478bd9Sstevel@tonic-gate * rights. You may have additional license terms from the party that provided 227c478bd9Sstevel@tonic-gate * you this software, covering your right to use that party's intellectual 237c478bd9Sstevel@tonic-gate * property rights. 247c478bd9Sstevel@tonic-gate * 257c478bd9Sstevel@tonic-gate * 2.2. Intel grants, free of charge, to any person ("Licensee") obtaining a 267c478bd9Sstevel@tonic-gate * copy of the source code appearing in this file ("Covered Code") an 277c478bd9Sstevel@tonic-gate * irrevocable, perpetual, worldwide license under Intel's copyrights in the 287c478bd9Sstevel@tonic-gate * base code distributed originally by Intel ("Original Intel Code") to copy, 297c478bd9Sstevel@tonic-gate * make derivatives, distribute, use and display any portion of the Covered 307c478bd9Sstevel@tonic-gate * Code in any form, with the right to sublicense such rights; and 317c478bd9Sstevel@tonic-gate * 327c478bd9Sstevel@tonic-gate * 2.3. Intel grants Licensee a non-exclusive and non-transferable patent 337c478bd9Sstevel@tonic-gate * license (with the right to sublicense), under only those claims of Intel 347c478bd9Sstevel@tonic-gate * patents that are infringed by the Original Intel Code, to make, use, sell, 357c478bd9Sstevel@tonic-gate * offer to sell, and import the Covered Code and derivative works thereof 367c478bd9Sstevel@tonic-gate * solely to the minimum extent necessary to exer 377c478bd9Sstevel@tonic-gate se the above copyright 387c478bd9Sstevel@tonic-gate * license, and in no event shall the patent license extend to any additions 397c478bd9Sstevel@tonic-gate * to or modifications of the Original Intel Code. No other license or right 407c478bd9Sstevel@tonic-gate * is granted directly or by implication, estoppel or otherwise; 417c478bd9Sstevel@tonic-gate * 427c478bd9Sstevel@tonic-gate * The above copyright and patent license is granted only if the following 437c478bd9Sstevel@tonic-gate * conditions are met: 447c478bd9Sstevel@tonic-gate * 457c478bd9Sstevel@tonic-gate * 3. Conditions 467c478bd9Sstevel@tonic-gate * 477c478bd9Sstevel@tonic-gate * 3.1. Redistribution of Source with Rights to Further Distribute Source. 487c478bd9Sstevel@tonic-gate * Redistribution of source code of any substantial portion of the Covered 497c478bd9Sstevel@tonic-gate * Code or modification with rights to further distribute source must include 507c478bd9Sstevel@tonic-gate * the above Copyright Notice, the above License, this list of Conditions, 517c478bd9Sstevel@tonic-gate * and the following Disclaimer and Export Compliance provision. In addition, 527c478bd9Sstevel@tonic-gate * Licensee must cause all Covered Code to which Licensee contributes to 537c478bd9Sstevel@tonic-gate * contain a file documenting the changes Licensee made to create that Covered 547c478bd9Sstevel@tonic-gate * Code and the date of any change. Licensee must include in that file the 557c478bd9Sstevel@tonic-gate * documentation of any changes made by any predecessor Licensee. Licensee 567c478bd9Sstevel@tonic-gate * must include a prominent statement that the modification is derived, 577c478bd9Sstevel@tonic-gate * directly or indirectly, from Original Intel Code. 587c478bd9Sstevel@tonic-gate * 597c478bd9Sstevel@tonic-gate * 3.2. Redistribution of Source with no Rights to Further Distribute Source. 607c478bd9Sstevel@tonic-gate * Redistribution of source code of any substantial portion of the Covered 617c478bd9Sstevel@tonic-gate * Code or modification without rights to further distribute source must 627c478bd9Sstevel@tonic-gate * include the following Disclaimer and Export Compliance provision in the 637c478bd9Sstevel@tonic-gate * documentation and/or other materials provided with distribution. In 647c478bd9Sstevel@tonic-gate * addition, Licensee may not authorize further sublicense of source of any 657c478bd9Sstevel@tonic-gate * portion of the Covered Code, and must include terms to the effect that the 667c478bd9Sstevel@tonic-gate * license from Licensee to its licensee is limited to the intellectual 677c478bd9Sstevel@tonic-gate * property embodied in the software Licensee provides to its licensee, and 687c478bd9Sstevel@tonic-gate * not to intellectual property embodied in modifications its licensee may 697c478bd9Sstevel@tonic-gate * make. 707c478bd9Sstevel@tonic-gate * 717c478bd9Sstevel@tonic-gate * 3.3. Redistribution of Executable. Redistribution in executable form of any 727c478bd9Sstevel@tonic-gate * substantial portion of the Covered Code or modification must reproduce the 737c478bd9Sstevel@tonic-gate * above Copyright Notice, and the following Disclaimer and Export Compliance 747c478bd9Sstevel@tonic-gate * provision in the documentation and/or other materials provided with the 757c478bd9Sstevel@tonic-gate * distribution. 767c478bd9Sstevel@tonic-gate * 777c478bd9Sstevel@tonic-gate * 3.4. Intel retains all right, title, and interest in and to the Original 787c478bd9Sstevel@tonic-gate * Intel Code. 797c478bd9Sstevel@tonic-gate * 807c478bd9Sstevel@tonic-gate * 3.5. Neither the name Intel nor any other trademark owned or controlled by 817c478bd9Sstevel@tonic-gate * Intel shall be used in advertising or otherwise to promote the sale, use or 827c478bd9Sstevel@tonic-gate * other dealings in products derived from or relating to the Covered Code 837c478bd9Sstevel@tonic-gate * without prior written authorization from Intel. 847c478bd9Sstevel@tonic-gate * 857c478bd9Sstevel@tonic-gate * 4. Disclaimer and Export Compliance 867c478bd9Sstevel@tonic-gate * 877c478bd9Sstevel@tonic-gate * 4.1. INTEL MAKES NO WARRANTY OF ANY KIND REGARDING ANY SOFTWARE PROVIDED 887c478bd9Sstevel@tonic-gate * HERE. ANY SOFTWARE ORIGINATING FROM INTEL OR DERIVED FROM INTEL SOFTWARE 897c478bd9Sstevel@tonic-gate * IS PROVIDED "AS IS," AND INTEL WILL NOT PROVIDE ANY SUPPORT, ASSISTANCE, 907c478bd9Sstevel@tonic-gate * INSTALLATION, TRAINING OR OTHER SERVICES. INTEL WILL NOT PROVIDE ANY 917c478bd9Sstevel@tonic-gate * UPDATES, ENHANCEMENTS OR EXTENSIONS. INTEL SPECIFICALLY DISCLAIMS ANY 927c478bd9Sstevel@tonic-gate * IMPLIED WARRANTIES OF MERCHANTABILITY, NONINFRINGEMENT AND FITNESS FOR A 937c478bd9Sstevel@tonic-gate * PARTICULAR PURPOSE. 947c478bd9Sstevel@tonic-gate * 957c478bd9Sstevel@tonic-gate * 4.2. IN NO EVENT SHALL INTEL HAVE ANY LIABILITY TO LICENSEE, ITS LICENSEES 967c478bd9Sstevel@tonic-gate * OR ANY OTHER THIRD PARTY, FOR ANY LOST PROFITS, LOST DATA, LOSS OF USE OR 977c478bd9Sstevel@tonic-gate * COSTS OF PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES, OR FOR ANY INDIRECT, 987c478bd9Sstevel@tonic-gate * SPECIAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THIS AGREEMENT, UNDER ANY 997c478bd9Sstevel@tonic-gate * CAUSE OF ACTION OR THEORY OF LIABILITY, AND IRRESPECTIVE OF WHETHER INTEL 1007c478bd9Sstevel@tonic-gate * HAS ADVANCE NOTICE OF THE POSSIBILITY OF SUCH DAMAGES. THESE LIMITATIONS 1017c478bd9Sstevel@tonic-gate * SHALL APPLY NOTWITHSTANDING THE FAILURE OF THE ESSENTIAL PURPOSE OF ANY 1027c478bd9Sstevel@tonic-gate * LIMITED REMEDY. 1037c478bd9Sstevel@tonic-gate * 1047c478bd9Sstevel@tonic-gate * 4.3. Licensee shall not export, either directly or indirectly, any of this 1057c478bd9Sstevel@tonic-gate * software or system incorporating such software without first obtaining any 1067c478bd9Sstevel@tonic-gate * required license or other approval from the U. S. Department of Commerce or 1077c478bd9Sstevel@tonic-gate * any other agency or department of the United States Government. In the 1087c478bd9Sstevel@tonic-gate * event Licensee exports any such software from the United States or 1097c478bd9Sstevel@tonic-gate * re-exports any such software from a foreign destination, Licensee shall 1107c478bd9Sstevel@tonic-gate * ensure that the distribution and export/re-export of the software is in 1117c478bd9Sstevel@tonic-gate * compliance with all laws, regulations, orders, or other restrictions of the 1127c478bd9Sstevel@tonic-gate * U.S. Export Administration Regulations. Licensee agrees that neither it nor 1137c478bd9Sstevel@tonic-gate * any of its subsidiaries will export/re-export any technical data, process, 1147c478bd9Sstevel@tonic-gate * software, or service, directly or indirectly, to any country for which the 1157c478bd9Sstevel@tonic-gate * United States government or any agency thereof requires an export license, 1167c478bd9Sstevel@tonic-gate * other governmental approval, or letter of assurance, without first obtaining 1177c478bd9Sstevel@tonic-gate * such license, approval or letter. 1187c478bd9Sstevel@tonic-gate * 1197c478bd9Sstevel@tonic-gate *****************************************************************************/ 1207c478bd9Sstevel@tonic-gate 1217c478bd9Sstevel@tonic-gate #ifndef __ACPIOSXF_H__ 1227c478bd9Sstevel@tonic-gate #define __ACPIOSXF_H__ 1237c478bd9Sstevel@tonic-gate 1247c478bd9Sstevel@tonic-gate #include "platform/acenv.h" 1257c478bd9Sstevel@tonic-gate #include "actypes.h" 1267c478bd9Sstevel@tonic-gate 1277c478bd9Sstevel@tonic-gate 128*27f7c583Smyers /* Types for AcpiOsExecute */ 1297c478bd9Sstevel@tonic-gate 130*27f7c583Smyers typedef enum 131*27f7c583Smyers { 132*27f7c583Smyers OSL_GLOBAL_LOCK_HANDLER, 133*27f7c583Smyers OSL_NOTIFY_HANDLER, 134*27f7c583Smyers OSL_GPE_HANDLER, 135*27f7c583Smyers OSL_DEBUGGER_THREAD, 136*27f7c583Smyers OSL_EC_POLL_HANDLER, 137*27f7c583Smyers OSL_EC_BURST_HANDLER 138*27f7c583Smyers 139*27f7c583Smyers } ACPI_EXECUTE_TYPE; 1407c478bd9Sstevel@tonic-gate 1417c478bd9Sstevel@tonic-gate #define ACPI_NO_UNIT_LIMIT ((UINT32) -1) 1427c478bd9Sstevel@tonic-gate #define ACPI_MUTEX_SEM 1 1437c478bd9Sstevel@tonic-gate 1447c478bd9Sstevel@tonic-gate 1457c478bd9Sstevel@tonic-gate /* Functions for AcpiOsSignal */ 1467c478bd9Sstevel@tonic-gate 1477c478bd9Sstevel@tonic-gate #define ACPI_SIGNAL_FATAL 0 1487c478bd9Sstevel@tonic-gate #define ACPI_SIGNAL_BREAKPOINT 1 1497c478bd9Sstevel@tonic-gate 1507c478bd9Sstevel@tonic-gate typedef struct acpi_signal_fatal_info 1517c478bd9Sstevel@tonic-gate { 1527c478bd9Sstevel@tonic-gate UINT32 Type; 1537c478bd9Sstevel@tonic-gate UINT32 Code; 1547c478bd9Sstevel@tonic-gate UINT32 Argument; 1557c478bd9Sstevel@tonic-gate 1567c478bd9Sstevel@tonic-gate } ACPI_SIGNAL_FATAL_INFO; 1577c478bd9Sstevel@tonic-gate 1587c478bd9Sstevel@tonic-gate 1597c478bd9Sstevel@tonic-gate /* 1607c478bd9Sstevel@tonic-gate * OSL Initialization and shutdown primitives 1617c478bd9Sstevel@tonic-gate */ 1627c478bd9Sstevel@tonic-gate ACPI_STATUS 1637c478bd9Sstevel@tonic-gate AcpiOsInitialize ( 1647c478bd9Sstevel@tonic-gate void); 1657c478bd9Sstevel@tonic-gate 1667c478bd9Sstevel@tonic-gate ACPI_STATUS 1677c478bd9Sstevel@tonic-gate AcpiOsTerminate ( 1687c478bd9Sstevel@tonic-gate void); 1697c478bd9Sstevel@tonic-gate 1707c478bd9Sstevel@tonic-gate 1717c478bd9Sstevel@tonic-gate /* 1727c478bd9Sstevel@tonic-gate * ACPI Table interfaces 1737c478bd9Sstevel@tonic-gate */ 1747c478bd9Sstevel@tonic-gate ACPI_STATUS 1757c478bd9Sstevel@tonic-gate AcpiOsGetRootPointer ( 1767c478bd9Sstevel@tonic-gate UINT32 Flags, 1777c478bd9Sstevel@tonic-gate ACPI_POINTER *Address); 1787c478bd9Sstevel@tonic-gate 1797c478bd9Sstevel@tonic-gate ACPI_STATUS 1807c478bd9Sstevel@tonic-gate AcpiOsPredefinedOverride ( 1817c478bd9Sstevel@tonic-gate const ACPI_PREDEFINED_NAMES *InitVal, 1827c478bd9Sstevel@tonic-gate ACPI_STRING *NewVal); 1837c478bd9Sstevel@tonic-gate 1847c478bd9Sstevel@tonic-gate ACPI_STATUS 1857c478bd9Sstevel@tonic-gate AcpiOsTableOverride ( 1867c478bd9Sstevel@tonic-gate ACPI_TABLE_HEADER *ExistingTable, 1877c478bd9Sstevel@tonic-gate ACPI_TABLE_HEADER **NewTable); 1887c478bd9Sstevel@tonic-gate 1897c478bd9Sstevel@tonic-gate 1907c478bd9Sstevel@tonic-gate /* 191*27f7c583Smyers * Spinlock primitives 192*27f7c583Smyers */ 193*27f7c583Smyers ACPI_STATUS 194*27f7c583Smyers AcpiOsCreateLock ( 195*27f7c583Smyers ACPI_SPINLOCK *OutHandle); 196*27f7c583Smyers 197*27f7c583Smyers void 198*27f7c583Smyers AcpiOsDeleteLock ( 199*27f7c583Smyers ACPI_SPINLOCK Handle); 200*27f7c583Smyers 201*27f7c583Smyers ACPI_CPU_FLAGS 202*27f7c583Smyers AcpiOsAcquireLock ( 203*27f7c583Smyers ACPI_SPINLOCK Handle); 204*27f7c583Smyers 205*27f7c583Smyers void 206*27f7c583Smyers AcpiOsReleaseLock ( 207*27f7c583Smyers ACPI_SPINLOCK Handle, 208*27f7c583Smyers ACPI_CPU_FLAGS Flags); 209*27f7c583Smyers 210*27f7c583Smyers 211*27f7c583Smyers /* 212*27f7c583Smyers * Semaphore primitives 2137c478bd9Sstevel@tonic-gate */ 2147c478bd9Sstevel@tonic-gate ACPI_STATUS 2157c478bd9Sstevel@tonic-gate AcpiOsCreateSemaphore ( 2167c478bd9Sstevel@tonic-gate UINT32 MaxUnits, 2177c478bd9Sstevel@tonic-gate UINT32 InitialUnits, 218*27f7c583Smyers ACPI_SEMAPHORE *OutHandle); 2197c478bd9Sstevel@tonic-gate 2207c478bd9Sstevel@tonic-gate ACPI_STATUS 2217c478bd9Sstevel@tonic-gate AcpiOsDeleteSemaphore ( 222*27f7c583Smyers ACPI_SEMAPHORE Handle); 2237c478bd9Sstevel@tonic-gate 2247c478bd9Sstevel@tonic-gate ACPI_STATUS 2257c478bd9Sstevel@tonic-gate AcpiOsWaitSemaphore ( 226*27f7c583Smyers ACPI_SEMAPHORE Handle, 2277c478bd9Sstevel@tonic-gate UINT32 Units, 2287c478bd9Sstevel@tonic-gate UINT16 Timeout); 2297c478bd9Sstevel@tonic-gate 2307c478bd9Sstevel@tonic-gate ACPI_STATUS 2317c478bd9Sstevel@tonic-gate AcpiOsSignalSemaphore ( 232*27f7c583Smyers ACPI_SEMAPHORE Handle, 2337c478bd9Sstevel@tonic-gate UINT32 Units); 2347c478bd9Sstevel@tonic-gate 235*27f7c583Smyers 236*27f7c583Smyers /* 237*27f7c583Smyers * Mutex primitives 238*27f7c583Smyers */ 2397c478bd9Sstevel@tonic-gate ACPI_STATUS 240*27f7c583Smyers AcpiOsCreateMutex ( 241*27f7c583Smyers ACPI_MUTEX *OutHandle); 2427c478bd9Sstevel@tonic-gate 2437c478bd9Sstevel@tonic-gate void 244*27f7c583Smyers AcpiOsDeleteMutex ( 245*27f7c583Smyers ACPI_MUTEX Handle); 2467c478bd9Sstevel@tonic-gate 247*27f7c583Smyers ACPI_STATUS 248*27f7c583Smyers AcpiOsAcquireMutex ( 249*27f7c583Smyers ACPI_MUTEX Handle, 250*27f7c583Smyers UINT16 Timeout); 2517c478bd9Sstevel@tonic-gate 2527c478bd9Sstevel@tonic-gate void 253*27f7c583Smyers AcpiOsReleaseMutex ( 254*27f7c583Smyers ACPI_MUTEX Handle); 255*27f7c583Smyers 256*27f7c583Smyers /* Temporary macros for Mutex* interfaces, map to existing semaphore xfaces */ 257*27f7c583Smyers 258*27f7c583Smyers #define AcpiOsCreateMutex(OutHandle) AcpiOsCreateSemaphore (1, 1, OutHandle) 259*27f7c583Smyers #define AcpiOsDeleteMutex(Handle) (void) AcpiOsDeleteSemaphore (Handle) 260*27f7c583Smyers #define AcpiOsAcquireMutex(Handle,Time) AcpiOsWaitSemaphore (Handle, 1, Time) 261*27f7c583Smyers #define AcpiOsReleaseMutex(Handle) (void) AcpiOsSignalSemaphore (Handle, 1) 2627c478bd9Sstevel@tonic-gate 2637c478bd9Sstevel@tonic-gate 2647c478bd9Sstevel@tonic-gate /* 2657c478bd9Sstevel@tonic-gate * Memory allocation and mapping 2667c478bd9Sstevel@tonic-gate */ 2677c478bd9Sstevel@tonic-gate void * 2687c478bd9Sstevel@tonic-gate AcpiOsAllocate ( 2697c478bd9Sstevel@tonic-gate ACPI_SIZE Size); 2707c478bd9Sstevel@tonic-gate 2717c478bd9Sstevel@tonic-gate void 2727c478bd9Sstevel@tonic-gate AcpiOsFree ( 2737c478bd9Sstevel@tonic-gate void * Memory); 2747c478bd9Sstevel@tonic-gate 2757c478bd9Sstevel@tonic-gate ACPI_STATUS 2767c478bd9Sstevel@tonic-gate AcpiOsMapMemory ( 2777c478bd9Sstevel@tonic-gate ACPI_PHYSICAL_ADDRESS PhysicalAddress, 2787c478bd9Sstevel@tonic-gate ACPI_SIZE Size, 2797c478bd9Sstevel@tonic-gate void **LogicalAddress); 2807c478bd9Sstevel@tonic-gate 2817c478bd9Sstevel@tonic-gate void 2827c478bd9Sstevel@tonic-gate AcpiOsUnmapMemory ( 2837c478bd9Sstevel@tonic-gate void *LogicalAddress, 2847c478bd9Sstevel@tonic-gate ACPI_SIZE Size); 2857c478bd9Sstevel@tonic-gate 2867c478bd9Sstevel@tonic-gate ACPI_STATUS 2877c478bd9Sstevel@tonic-gate AcpiOsGetPhysicalAddress ( 2887c478bd9Sstevel@tonic-gate void *LogicalAddress, 2897c478bd9Sstevel@tonic-gate ACPI_PHYSICAL_ADDRESS *PhysicalAddress); 2907c478bd9Sstevel@tonic-gate 2917c478bd9Sstevel@tonic-gate 292450d6964Smyers /* 293450d6964Smyers * Memory/Object Cache 294450d6964Smyers */ 295450d6964Smyers ACPI_STATUS 296450d6964Smyers AcpiOsCreateCache ( 297450d6964Smyers char *CacheName, 298450d6964Smyers UINT16 ObjectSize, 299450d6964Smyers UINT16 MaxDepth, 300450d6964Smyers ACPI_CACHE_T **ReturnCache); 301450d6964Smyers 302450d6964Smyers ACPI_STATUS 303450d6964Smyers AcpiOsDeleteCache ( 304450d6964Smyers ACPI_CACHE_T *Cache); 305450d6964Smyers 306450d6964Smyers ACPI_STATUS 307450d6964Smyers AcpiOsPurgeCache ( 308450d6964Smyers ACPI_CACHE_T *Cache); 309450d6964Smyers 310450d6964Smyers void * 311450d6964Smyers AcpiOsAcquireObject ( 312450d6964Smyers ACPI_CACHE_T *Cache); 313450d6964Smyers 314450d6964Smyers ACPI_STATUS 315450d6964Smyers AcpiOsReleaseObject ( 316450d6964Smyers ACPI_CACHE_T *Cache, 317450d6964Smyers void *Object); 318450d6964Smyers 319450d6964Smyers 3207c478bd9Sstevel@tonic-gate /* 3217c478bd9Sstevel@tonic-gate * Interrupt handlers 3227c478bd9Sstevel@tonic-gate */ 3237c478bd9Sstevel@tonic-gate ACPI_STATUS 3247c478bd9Sstevel@tonic-gate AcpiOsInstallInterruptHandler ( 3257c478bd9Sstevel@tonic-gate UINT32 InterruptNumber, 3267c478bd9Sstevel@tonic-gate ACPI_OSD_HANDLER ServiceRoutine, 3277c478bd9Sstevel@tonic-gate void *Context); 3287c478bd9Sstevel@tonic-gate 3297c478bd9Sstevel@tonic-gate ACPI_STATUS 3307c478bd9Sstevel@tonic-gate AcpiOsRemoveInterruptHandler ( 3317c478bd9Sstevel@tonic-gate UINT32 InterruptNumber, 3327c478bd9Sstevel@tonic-gate ACPI_OSD_HANDLER ServiceRoutine); 3337c478bd9Sstevel@tonic-gate 3347c478bd9Sstevel@tonic-gate 3357c478bd9Sstevel@tonic-gate /* 3367c478bd9Sstevel@tonic-gate * Threads and Scheduling 3377c478bd9Sstevel@tonic-gate */ 338*27f7c583Smyers ACPI_THREAD_ID 3397c478bd9Sstevel@tonic-gate AcpiOsGetThreadId ( 3407c478bd9Sstevel@tonic-gate void); 3417c478bd9Sstevel@tonic-gate 3427c478bd9Sstevel@tonic-gate ACPI_STATUS 343*27f7c583Smyers AcpiOsExecute ( 344*27f7c583Smyers ACPI_EXECUTE_TYPE Type, 3457c478bd9Sstevel@tonic-gate ACPI_OSD_EXEC_CALLBACK Function, 3467c478bd9Sstevel@tonic-gate void *Context); 3477c478bd9Sstevel@tonic-gate 3487c478bd9Sstevel@tonic-gate void 3497c478bd9Sstevel@tonic-gate AcpiOsWaitEventsComplete ( 3507c478bd9Sstevel@tonic-gate void *Context); 3517c478bd9Sstevel@tonic-gate 3527c478bd9Sstevel@tonic-gate void 3537c478bd9Sstevel@tonic-gate AcpiOsSleep ( 3547c478bd9Sstevel@tonic-gate ACPI_INTEGER Milliseconds); 3557c478bd9Sstevel@tonic-gate 3567c478bd9Sstevel@tonic-gate void 3577c478bd9Sstevel@tonic-gate AcpiOsStall ( 3587c478bd9Sstevel@tonic-gate UINT32 Microseconds); 3597c478bd9Sstevel@tonic-gate 3607c478bd9Sstevel@tonic-gate 3617c478bd9Sstevel@tonic-gate /* 3627c478bd9Sstevel@tonic-gate * Platform and hardware-independent I/O interfaces 3637c478bd9Sstevel@tonic-gate */ 3647c478bd9Sstevel@tonic-gate ACPI_STATUS 3657c478bd9Sstevel@tonic-gate AcpiOsReadPort ( 3667c478bd9Sstevel@tonic-gate ACPI_IO_ADDRESS Address, 3677c478bd9Sstevel@tonic-gate UINT32 *Value, 3687c478bd9Sstevel@tonic-gate UINT32 Width); 3697c478bd9Sstevel@tonic-gate 3707c478bd9Sstevel@tonic-gate ACPI_STATUS 3717c478bd9Sstevel@tonic-gate AcpiOsWritePort ( 3727c478bd9Sstevel@tonic-gate ACPI_IO_ADDRESS Address, 3737c478bd9Sstevel@tonic-gate UINT32 Value, 3747c478bd9Sstevel@tonic-gate UINT32 Width); 3757c478bd9Sstevel@tonic-gate 3767c478bd9Sstevel@tonic-gate 3777c478bd9Sstevel@tonic-gate /* 3787c478bd9Sstevel@tonic-gate * Platform and hardware-independent physical memory interfaces 3797c478bd9Sstevel@tonic-gate */ 3807c478bd9Sstevel@tonic-gate ACPI_STATUS 3817c478bd9Sstevel@tonic-gate AcpiOsReadMemory ( 3827c478bd9Sstevel@tonic-gate ACPI_PHYSICAL_ADDRESS Address, 3837c478bd9Sstevel@tonic-gate UINT32 *Value, 3847c478bd9Sstevel@tonic-gate UINT32 Width); 3857c478bd9Sstevel@tonic-gate 3867c478bd9Sstevel@tonic-gate ACPI_STATUS 3877c478bd9Sstevel@tonic-gate AcpiOsWriteMemory ( 3887c478bd9Sstevel@tonic-gate ACPI_PHYSICAL_ADDRESS Address, 3897c478bd9Sstevel@tonic-gate UINT32 Value, 3907c478bd9Sstevel@tonic-gate UINT32 Width); 3917c478bd9Sstevel@tonic-gate 3927c478bd9Sstevel@tonic-gate 3937c478bd9Sstevel@tonic-gate /* 3947c478bd9Sstevel@tonic-gate * Platform and hardware-independent PCI configuration space access 3957c478bd9Sstevel@tonic-gate * Note: Can't use "Register" as a parameter, changed to "Reg" -- 3967c478bd9Sstevel@tonic-gate * certain compilers complain. 3977c478bd9Sstevel@tonic-gate */ 3987c478bd9Sstevel@tonic-gate ACPI_STATUS 3997c478bd9Sstevel@tonic-gate AcpiOsReadPciConfiguration ( 4007c478bd9Sstevel@tonic-gate ACPI_PCI_ID *PciId, 4017c478bd9Sstevel@tonic-gate UINT32 Reg, 4027c478bd9Sstevel@tonic-gate void *Value, 4037c478bd9Sstevel@tonic-gate UINT32 Width); 4047c478bd9Sstevel@tonic-gate 4057c478bd9Sstevel@tonic-gate ACPI_STATUS 4067c478bd9Sstevel@tonic-gate AcpiOsWritePciConfiguration ( 4077c478bd9Sstevel@tonic-gate ACPI_PCI_ID *PciId, 4087c478bd9Sstevel@tonic-gate UINT32 Reg, 4097c478bd9Sstevel@tonic-gate ACPI_INTEGER Value, 4107c478bd9Sstevel@tonic-gate UINT32 Width); 4117c478bd9Sstevel@tonic-gate 412*27f7c583Smyers 4137c478bd9Sstevel@tonic-gate /* 4147c478bd9Sstevel@tonic-gate * Interim function needed for PCI IRQ routing 4157c478bd9Sstevel@tonic-gate */ 4167c478bd9Sstevel@tonic-gate void 4177c478bd9Sstevel@tonic-gate AcpiOsDerivePciId( 4187c478bd9Sstevel@tonic-gate ACPI_HANDLE Rhandle, 4197c478bd9Sstevel@tonic-gate ACPI_HANDLE Chandle, 4207c478bd9Sstevel@tonic-gate ACPI_PCI_ID **PciId); 4217c478bd9Sstevel@tonic-gate 422*27f7c583Smyers 4237c478bd9Sstevel@tonic-gate /* 4247c478bd9Sstevel@tonic-gate * Miscellaneous 4257c478bd9Sstevel@tonic-gate */ 426*27f7c583Smyers ACPI_STATUS 427*27f7c583Smyers AcpiOsValidateInterface ( 428*27f7c583Smyers char *Interface); 429*27f7c583Smyers 430*27f7c583Smyers ACPI_STATUS 431*27f7c583Smyers AcpiOsValidateAddress ( 432*27f7c583Smyers UINT8 SpaceId, 433*27f7c583Smyers ACPI_PHYSICAL_ADDRESS Address, 434*27f7c583Smyers ACPI_SIZE Length); 435*27f7c583Smyers 4367c478bd9Sstevel@tonic-gate BOOLEAN 4377c478bd9Sstevel@tonic-gate AcpiOsReadable ( 4387c478bd9Sstevel@tonic-gate void *Pointer, 4397c478bd9Sstevel@tonic-gate ACPI_SIZE Length); 4407c478bd9Sstevel@tonic-gate 4417c478bd9Sstevel@tonic-gate BOOLEAN 4427c478bd9Sstevel@tonic-gate AcpiOsWritable ( 4437c478bd9Sstevel@tonic-gate void *Pointer, 4447c478bd9Sstevel@tonic-gate ACPI_SIZE Length); 4457c478bd9Sstevel@tonic-gate 4467c478bd9Sstevel@tonic-gate UINT64 4477c478bd9Sstevel@tonic-gate AcpiOsGetTimer ( 4487c478bd9Sstevel@tonic-gate void); 4497c478bd9Sstevel@tonic-gate 4507c478bd9Sstevel@tonic-gate ACPI_STATUS 4517c478bd9Sstevel@tonic-gate AcpiOsSignal ( 4527c478bd9Sstevel@tonic-gate UINT32 Function, 4537c478bd9Sstevel@tonic-gate void *Info); 4547c478bd9Sstevel@tonic-gate 455*27f7c583Smyers 4567c478bd9Sstevel@tonic-gate /* 4577c478bd9Sstevel@tonic-gate * Debug print routines 4587c478bd9Sstevel@tonic-gate */ 4597c478bd9Sstevel@tonic-gate void ACPI_INTERNAL_VAR_XFACE 4607c478bd9Sstevel@tonic-gate AcpiOsPrintf ( 4617c478bd9Sstevel@tonic-gate const char *Format, 4627c478bd9Sstevel@tonic-gate ...); 4637c478bd9Sstevel@tonic-gate 4647c478bd9Sstevel@tonic-gate void 4657c478bd9Sstevel@tonic-gate AcpiOsVprintf ( 4667c478bd9Sstevel@tonic-gate const char *Format, 4677c478bd9Sstevel@tonic-gate va_list Args); 4687c478bd9Sstevel@tonic-gate 4697c478bd9Sstevel@tonic-gate void 4707c478bd9Sstevel@tonic-gate AcpiOsRedirectOutput ( 4717c478bd9Sstevel@tonic-gate void *Destination); 4727c478bd9Sstevel@tonic-gate 4737c478bd9Sstevel@tonic-gate 4747c478bd9Sstevel@tonic-gate /* 4757c478bd9Sstevel@tonic-gate * Debug input 4767c478bd9Sstevel@tonic-gate */ 4777c478bd9Sstevel@tonic-gate UINT32 4787c478bd9Sstevel@tonic-gate AcpiOsGetLine ( 4797c478bd9Sstevel@tonic-gate char *Buffer); 4807c478bd9Sstevel@tonic-gate 4817c478bd9Sstevel@tonic-gate 4827c478bd9Sstevel@tonic-gate /* 4837c478bd9Sstevel@tonic-gate * Directory manipulation 4847c478bd9Sstevel@tonic-gate */ 4857c478bd9Sstevel@tonic-gate void * 4867c478bd9Sstevel@tonic-gate AcpiOsOpenDirectory ( 4877c478bd9Sstevel@tonic-gate char *Pathname, 4887c478bd9Sstevel@tonic-gate char *WildcardSpec, 4897c478bd9Sstevel@tonic-gate char RequestedFileType); 4907c478bd9Sstevel@tonic-gate 4917c478bd9Sstevel@tonic-gate /* RequesteFileType values */ 4927c478bd9Sstevel@tonic-gate 4937c478bd9Sstevel@tonic-gate #define REQUEST_FILE_ONLY 0 4947c478bd9Sstevel@tonic-gate #define REQUEST_DIR_ONLY 1 4957c478bd9Sstevel@tonic-gate 4967c478bd9Sstevel@tonic-gate 4977c478bd9Sstevel@tonic-gate char * 4987c478bd9Sstevel@tonic-gate AcpiOsGetNextFilename ( 4997c478bd9Sstevel@tonic-gate void *DirHandle); 5007c478bd9Sstevel@tonic-gate 5017c478bd9Sstevel@tonic-gate void 5027c478bd9Sstevel@tonic-gate AcpiOsCloseDirectory ( 5037c478bd9Sstevel@tonic-gate void *DirHandle); 5047c478bd9Sstevel@tonic-gate 5057c478bd9Sstevel@tonic-gate 5067c478bd9Sstevel@tonic-gate #endif /* __ACPIOSXF_H__ */ 507