xref: /illumos-gate/usr/src/uts/intel/sys/acpi/acpiosxf.h (revision 27f7c583)
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