Home | History | Annotate | Line # | Download | only in include
acpiosxf.h revision 1.9.2.2
      1      1.1    jruoho /******************************************************************************
      2      1.1    jruoho  *
      3      1.5  christos  * Name: acpiosxf.h - All interfaces to the OS Services Layer (OSL). These
      4      1.1    jruoho  *                    interfaces must be implemented by OSL to interface the
      5      1.1    jruoho  *                    ACPI components to the host operating system.
      6      1.1    jruoho  *
      7      1.1    jruoho  *****************************************************************************/
      8      1.1    jruoho 
      9      1.3    jruoho /*
     10  1.9.2.2  pgoyette  * Copyright (C) 2000 - 2017, Intel Corp.
     11      1.1    jruoho  * All rights reserved.
     12      1.1    jruoho  *
     13      1.3    jruoho  * Redistribution and use in source and binary forms, with or without
     14      1.3    jruoho  * modification, are permitted provided that the following conditions
     15      1.3    jruoho  * are met:
     16      1.3    jruoho  * 1. Redistributions of source code must retain the above copyright
     17      1.3    jruoho  *    notice, this list of conditions, and the following disclaimer,
     18      1.3    jruoho  *    without modification.
     19      1.3    jruoho  * 2. Redistributions in binary form must reproduce at minimum a disclaimer
     20      1.3    jruoho  *    substantially similar to the "NO WARRANTY" disclaimer below
     21      1.3    jruoho  *    ("Disclaimer") and any redistribution must be conditioned upon
     22      1.3    jruoho  *    including a substantially similar Disclaimer requirement for further
     23      1.3    jruoho  *    binary redistribution.
     24      1.3    jruoho  * 3. Neither the names of the above-listed copyright holders nor the names
     25      1.3    jruoho  *    of any contributors may be used to endorse or promote products derived
     26      1.3    jruoho  *    from this software without specific prior written permission.
     27      1.3    jruoho  *
     28      1.3    jruoho  * Alternatively, this software may be distributed under the terms of the
     29      1.3    jruoho  * GNU General Public License ("GPL") version 2 as published by the Free
     30      1.3    jruoho  * Software Foundation.
     31      1.3    jruoho  *
     32      1.3    jruoho  * NO WARRANTY
     33      1.3    jruoho  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
     34      1.3    jruoho  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
     35      1.3    jruoho  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
     36      1.3    jruoho  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
     37      1.3    jruoho  * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     38      1.3    jruoho  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     39      1.3    jruoho  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     40      1.3    jruoho  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
     41      1.3    jruoho  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
     42      1.3    jruoho  * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     43      1.3    jruoho  * POSSIBILITY OF SUCH DAMAGES.
     44      1.3    jruoho  */
     45      1.1    jruoho 
     46      1.1    jruoho #ifndef __ACPIOSXF_H__
     47      1.1    jruoho #define __ACPIOSXF_H__
     48      1.1    jruoho 
     49      1.1    jruoho #include "platform/acenv.h"
     50      1.1    jruoho #include "actypes.h"
     51      1.1    jruoho 
     52      1.1    jruoho 
     53      1.1    jruoho /* Types for AcpiOsExecute */
     54      1.1    jruoho 
     55      1.1    jruoho typedef enum
     56      1.1    jruoho {
     57      1.1    jruoho     OSL_GLOBAL_LOCK_HANDLER,
     58      1.1    jruoho     OSL_NOTIFY_HANDLER,
     59      1.1    jruoho     OSL_GPE_HANDLER,
     60      1.9  christos     OSL_DEBUGGER_MAIN_THREAD,
     61      1.9  christos     OSL_DEBUGGER_EXEC_THREAD,
     62      1.1    jruoho     OSL_EC_POLL_HANDLER,
     63      1.1    jruoho     OSL_EC_BURST_HANDLER
     64      1.1    jruoho 
     65      1.1    jruoho } ACPI_EXECUTE_TYPE;
     66      1.1    jruoho 
     67      1.1    jruoho #define ACPI_NO_UNIT_LIMIT          ((UINT32) -1)
     68      1.1    jruoho #define ACPI_MUTEX_SEM              1
     69      1.1    jruoho 
     70      1.1    jruoho 
     71      1.1    jruoho /* Functions for AcpiOsSignal */
     72      1.1    jruoho 
     73      1.1    jruoho #define ACPI_SIGNAL_FATAL           0
     74      1.1    jruoho #define ACPI_SIGNAL_BREAKPOINT      1
     75      1.1    jruoho 
     76      1.1    jruoho typedef struct acpi_signal_fatal_info
     77      1.1    jruoho {
     78      1.1    jruoho     UINT32                  Type;
     79      1.1    jruoho     UINT32                  Code;
     80      1.1    jruoho     UINT32                  Argument;
     81      1.1    jruoho 
     82      1.1    jruoho } ACPI_SIGNAL_FATAL_INFO;
     83      1.1    jruoho 
     84      1.1    jruoho 
     85      1.1    jruoho /*
     86      1.1    jruoho  * OSL Initialization and shutdown primitives
     87      1.1    jruoho  */
     88      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsInitialize
     89      1.1    jruoho ACPI_STATUS
     90      1.1    jruoho AcpiOsInitialize (
     91      1.1    jruoho     void);
     92      1.5  christos #endif
     93      1.1    jruoho 
     94      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsTerminate
     95      1.1    jruoho ACPI_STATUS
     96      1.1    jruoho AcpiOsTerminate (
     97      1.1    jruoho     void);
     98      1.5  christos #endif
     99      1.1    jruoho 
    100      1.1    jruoho 
    101      1.1    jruoho /*
    102      1.1    jruoho  * ACPI Table interfaces
    103      1.1    jruoho  */
    104      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetRootPointer
    105      1.1    jruoho ACPI_PHYSICAL_ADDRESS
    106      1.1    jruoho AcpiOsGetRootPointer (
    107      1.1    jruoho     void);
    108      1.5  christos #endif
    109      1.1    jruoho 
    110      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsPredefinedOverride
    111      1.1    jruoho ACPI_STATUS
    112      1.1    jruoho AcpiOsPredefinedOverride (
    113      1.1    jruoho     const ACPI_PREDEFINED_NAMES *InitVal,
    114      1.1    jruoho     ACPI_STRING                 *NewVal);
    115      1.5  christos #endif
    116      1.1    jruoho 
    117      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsTableOverride
    118      1.1    jruoho ACPI_STATUS
    119      1.1    jruoho AcpiOsTableOverride (
    120      1.1    jruoho     ACPI_TABLE_HEADER       *ExistingTable,
    121      1.1    jruoho     ACPI_TABLE_HEADER       **NewTable);
    122      1.5  christos #endif
    123      1.5  christos 
    124      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsPhysicalTableOverride
    125      1.5  christos ACPI_STATUS
    126      1.5  christos AcpiOsPhysicalTableOverride (
    127      1.5  christos     ACPI_TABLE_HEADER       *ExistingTable,
    128      1.5  christos     ACPI_PHYSICAL_ADDRESS   *NewAddress,
    129      1.5  christos     UINT32                  *NewTableLength);
    130      1.5  christos #endif
    131      1.1    jruoho 
    132      1.1    jruoho 
    133      1.1    jruoho /*
    134      1.1    jruoho  * Spinlock primitives
    135      1.1    jruoho  */
    136      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsCreateLock
    137      1.1    jruoho ACPI_STATUS
    138      1.1    jruoho AcpiOsCreateLock (
    139      1.1    jruoho     ACPI_SPINLOCK           *OutHandle);
    140      1.5  christos #endif
    141      1.1    jruoho 
    142      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsDeleteLock
    143      1.1    jruoho void
    144      1.1    jruoho AcpiOsDeleteLock (
    145      1.1    jruoho     ACPI_SPINLOCK           Handle);
    146      1.5  christos #endif
    147      1.1    jruoho 
    148      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsAcquireLock
    149      1.1    jruoho ACPI_CPU_FLAGS
    150      1.1    jruoho AcpiOsAcquireLock (
    151      1.1    jruoho     ACPI_SPINLOCK           Handle);
    152      1.5  christos #endif
    153      1.1    jruoho 
    154      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsReleaseLock
    155      1.1    jruoho void
    156      1.1    jruoho AcpiOsReleaseLock (
    157      1.1    jruoho     ACPI_SPINLOCK           Handle,
    158      1.1    jruoho     ACPI_CPU_FLAGS          Flags);
    159      1.5  christos #endif
    160      1.1    jruoho 
    161      1.1    jruoho 
    162      1.1    jruoho /*
    163      1.1    jruoho  * Semaphore primitives
    164      1.1    jruoho  */
    165      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsCreateSemaphore
    166      1.1    jruoho ACPI_STATUS
    167      1.1    jruoho AcpiOsCreateSemaphore (
    168      1.1    jruoho     UINT32                  MaxUnits,
    169      1.1    jruoho     UINT32                  InitialUnits,
    170      1.1    jruoho     ACPI_SEMAPHORE          *OutHandle);
    171      1.5  christos #endif
    172      1.1    jruoho 
    173      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsDeleteSemaphore
    174      1.1    jruoho ACPI_STATUS
    175      1.1    jruoho AcpiOsDeleteSemaphore (
    176      1.1    jruoho     ACPI_SEMAPHORE          Handle);
    177      1.5  christos #endif
    178      1.1    jruoho 
    179      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsWaitSemaphore
    180      1.1    jruoho ACPI_STATUS
    181      1.1    jruoho AcpiOsWaitSemaphore (
    182      1.1    jruoho     ACPI_SEMAPHORE          Handle,
    183      1.1    jruoho     UINT32                  Units,
    184      1.1    jruoho     UINT16                  Timeout);
    185      1.5  christos #endif
    186      1.1    jruoho 
    187      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsSignalSemaphore
    188      1.1    jruoho ACPI_STATUS
    189      1.1    jruoho AcpiOsSignalSemaphore (
    190      1.1    jruoho     ACPI_SEMAPHORE          Handle,
    191      1.1    jruoho     UINT32                  Units);
    192      1.5  christos #endif
    193      1.1    jruoho 
    194      1.1    jruoho 
    195      1.1    jruoho /*
    196      1.1    jruoho  * Mutex primitives. May be configured to use semaphores instead via
    197      1.1    jruoho  * ACPI_MUTEX_TYPE (see platform/acenv.h)
    198      1.1    jruoho  */
    199      1.1    jruoho #if (ACPI_MUTEX_TYPE != ACPI_BINARY_SEMAPHORE)
    200      1.1    jruoho 
    201      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsCreateMutex
    202      1.1    jruoho ACPI_STATUS
    203      1.1    jruoho AcpiOsCreateMutex (
    204      1.1    jruoho     ACPI_MUTEX              *OutHandle);
    205      1.5  christos #endif
    206      1.1    jruoho 
    207      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsDeleteMutex
    208      1.1    jruoho void
    209      1.1    jruoho AcpiOsDeleteMutex (
    210      1.1    jruoho     ACPI_MUTEX              Handle);
    211      1.5  christos #endif
    212      1.1    jruoho 
    213      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsAcquireMutex
    214      1.1    jruoho ACPI_STATUS
    215      1.1    jruoho AcpiOsAcquireMutex (
    216      1.1    jruoho     ACPI_MUTEX              Handle,
    217      1.1    jruoho     UINT16                  Timeout);
    218      1.5  christos #endif
    219      1.1    jruoho 
    220      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsReleaseMutex
    221      1.1    jruoho void
    222      1.1    jruoho AcpiOsReleaseMutex (
    223      1.1    jruoho     ACPI_MUTEX              Handle);
    224      1.1    jruoho #endif
    225      1.1    jruoho 
    226      1.5  christos #endif
    227      1.5  christos 
    228      1.1    jruoho 
    229      1.1    jruoho /*
    230      1.1    jruoho  * Memory allocation and mapping
    231      1.1    jruoho  */
    232      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsAllocate
    233      1.1    jruoho void *
    234      1.1    jruoho AcpiOsAllocate (
    235      1.1    jruoho     ACPI_SIZE               Size);
    236      1.5  christos #endif
    237      1.5  christos 
    238      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsAllocateZeroed
    239      1.5  christos void *
    240      1.5  christos AcpiOsAllocateZeroed (
    241      1.5  christos     ACPI_SIZE               Size);
    242      1.5  christos #endif
    243      1.1    jruoho 
    244      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsFree
    245      1.1    jruoho void
    246      1.1    jruoho AcpiOsFree (
    247      1.1    jruoho     void *                  Memory);
    248      1.5  christos #endif
    249      1.1    jruoho 
    250      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsMapMemory
    251      1.1    jruoho void *
    252      1.1    jruoho AcpiOsMapMemory (
    253      1.1    jruoho     ACPI_PHYSICAL_ADDRESS   Where,
    254      1.1    jruoho     ACPI_SIZE               Length);
    255      1.5  christos #endif
    256      1.1    jruoho 
    257      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsUnmapMemory
    258      1.1    jruoho void
    259      1.1    jruoho AcpiOsUnmapMemory (
    260      1.1    jruoho     void                    *LogicalAddress,
    261      1.1    jruoho     ACPI_SIZE               Size);
    262      1.5  christos #endif
    263      1.1    jruoho 
    264      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetPhysicalAddress
    265      1.1    jruoho ACPI_STATUS
    266      1.1    jruoho AcpiOsGetPhysicalAddress (
    267      1.1    jruoho     void                    *LogicalAddress,
    268      1.1    jruoho     ACPI_PHYSICAL_ADDRESS   *PhysicalAddress);
    269      1.5  christos #endif
    270      1.1    jruoho 
    271      1.1    jruoho 
    272      1.1    jruoho /*
    273      1.1    jruoho  * Memory/Object Cache
    274      1.1    jruoho  */
    275      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsCreateCache
    276      1.1    jruoho ACPI_STATUS
    277      1.1    jruoho AcpiOsCreateCache (
    278      1.2    jruoho     const char              *CacheName,
    279      1.1    jruoho     UINT16                  ObjectSize,
    280      1.1    jruoho     UINT16                  MaxDepth,
    281      1.1    jruoho     ACPI_CACHE_T            **ReturnCache);
    282      1.5  christos #endif
    283      1.1    jruoho 
    284      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsDeleteCache
    285      1.1    jruoho ACPI_STATUS
    286      1.1    jruoho AcpiOsDeleteCache (
    287      1.1    jruoho     ACPI_CACHE_T            *Cache);
    288      1.5  christos #endif
    289      1.1    jruoho 
    290      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsPurgeCache
    291      1.1    jruoho ACPI_STATUS
    292      1.1    jruoho AcpiOsPurgeCache (
    293      1.1    jruoho     ACPI_CACHE_T            *Cache);
    294      1.5  christos #endif
    295      1.1    jruoho 
    296      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsAcquireObject
    297      1.1    jruoho void *
    298      1.1    jruoho AcpiOsAcquireObject (
    299      1.1    jruoho     ACPI_CACHE_T            *Cache);
    300      1.5  christos #endif
    301      1.1    jruoho 
    302      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsReleaseObject
    303      1.1    jruoho ACPI_STATUS
    304      1.1    jruoho AcpiOsReleaseObject (
    305      1.1    jruoho     ACPI_CACHE_T            *Cache,
    306      1.1    jruoho     void                    *Object);
    307      1.5  christos #endif
    308      1.1    jruoho 
    309      1.1    jruoho 
    310      1.1    jruoho /*
    311      1.1    jruoho  * Interrupt handlers
    312      1.1    jruoho  */
    313      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsInstallInterruptHandler
    314      1.1    jruoho ACPI_STATUS
    315      1.1    jruoho AcpiOsInstallInterruptHandler (
    316      1.1    jruoho     UINT32                  InterruptNumber,
    317      1.1    jruoho     ACPI_OSD_HANDLER        ServiceRoutine,
    318      1.1    jruoho     void                    *Context);
    319      1.5  christos #endif
    320      1.1    jruoho 
    321      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsRemoveInterruptHandler
    322      1.1    jruoho ACPI_STATUS
    323      1.1    jruoho AcpiOsRemoveInterruptHandler (
    324      1.1    jruoho     UINT32                  InterruptNumber,
    325      1.1    jruoho     ACPI_OSD_HANDLER        ServiceRoutine);
    326      1.5  christos #endif
    327      1.1    jruoho 
    328      1.1    jruoho 
    329      1.1    jruoho /*
    330      1.1    jruoho  * Threads and Scheduling
    331      1.1    jruoho  */
    332      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetThreadId
    333      1.1    jruoho ACPI_THREAD_ID
    334      1.1    jruoho AcpiOsGetThreadId (
    335      1.1    jruoho     void);
    336      1.5  christos #endif
    337      1.1    jruoho 
    338      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsExecute
    339      1.1    jruoho ACPI_STATUS
    340      1.1    jruoho AcpiOsExecute (
    341      1.1    jruoho     ACPI_EXECUTE_TYPE       Type,
    342      1.1    jruoho     ACPI_OSD_EXEC_CALLBACK  Function,
    343      1.1    jruoho     void                    *Context);
    344      1.5  christos #endif
    345      1.1    jruoho 
    346      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsWaitEventsComplete
    347      1.1    jruoho void
    348      1.1    jruoho AcpiOsWaitEventsComplete (
    349      1.5  christos     void);
    350      1.5  christos #endif
    351      1.1    jruoho 
    352      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsSleep
    353      1.1    jruoho void
    354      1.1    jruoho AcpiOsSleep (
    355      1.1    jruoho     UINT64                  Milliseconds);
    356      1.5  christos #endif
    357      1.1    jruoho 
    358      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsStall
    359      1.1    jruoho void
    360      1.1    jruoho AcpiOsStall (
    361      1.1    jruoho     UINT32                  Microseconds);
    362      1.5  christos #endif
    363      1.1    jruoho 
    364      1.1    jruoho 
    365      1.1    jruoho /*
    366      1.1    jruoho  * Platform and hardware-independent I/O interfaces
    367      1.1    jruoho  */
    368      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsReadPort
    369      1.1    jruoho ACPI_STATUS
    370      1.1    jruoho AcpiOsReadPort (
    371      1.1    jruoho     ACPI_IO_ADDRESS         Address,
    372      1.1    jruoho     UINT32                  *Value,
    373      1.1    jruoho     UINT32                  Width);
    374      1.5  christos #endif
    375      1.1    jruoho 
    376      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsWritePort
    377      1.1    jruoho ACPI_STATUS
    378      1.1    jruoho AcpiOsWritePort (
    379      1.1    jruoho     ACPI_IO_ADDRESS         Address,
    380      1.1    jruoho     UINT32                  Value,
    381      1.1    jruoho     UINT32                  Width);
    382      1.5  christos #endif
    383      1.1    jruoho 
    384      1.1    jruoho 
    385      1.1    jruoho /*
    386      1.1    jruoho  * Platform and hardware-independent physical memory interfaces
    387      1.1    jruoho  */
    388      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsReadMemory
    389      1.1    jruoho ACPI_STATUS
    390      1.1    jruoho AcpiOsReadMemory (
    391      1.1    jruoho     ACPI_PHYSICAL_ADDRESS   Address,
    392      1.5  christos     UINT64                  *Value,
    393      1.1    jruoho     UINT32                  Width);
    394      1.5  christos #endif
    395      1.1    jruoho 
    396      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsWriteMemory
    397      1.1    jruoho ACPI_STATUS
    398      1.1    jruoho AcpiOsWriteMemory (
    399      1.1    jruoho     ACPI_PHYSICAL_ADDRESS   Address,
    400      1.5  christos     UINT64                  Value,
    401      1.1    jruoho     UINT32                  Width);
    402      1.5  christos #endif
    403      1.1    jruoho 
    404      1.1    jruoho 
    405      1.1    jruoho /*
    406      1.1    jruoho  * Platform and hardware-independent PCI configuration space access
    407      1.1    jruoho  * Note: Can't use "Register" as a parameter, changed to "Reg" --
    408      1.1    jruoho  * certain compilers complain.
    409      1.1    jruoho  */
    410      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsReadPciConfiguration
    411      1.1    jruoho ACPI_STATUS
    412      1.1    jruoho AcpiOsReadPciConfiguration (
    413      1.1    jruoho     ACPI_PCI_ID             *PciId,
    414      1.1    jruoho     UINT32                  Reg,
    415      1.3    jruoho     UINT64                  *Value,
    416      1.1    jruoho     UINT32                  Width);
    417      1.5  christos #endif
    418      1.1    jruoho 
    419      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsWritePciConfiguration
    420      1.1    jruoho ACPI_STATUS
    421      1.1    jruoho AcpiOsWritePciConfiguration (
    422      1.1    jruoho     ACPI_PCI_ID             *PciId,
    423      1.1    jruoho     UINT32                  Reg,
    424      1.1    jruoho     UINT64                  Value,
    425      1.1    jruoho     UINT32                  Width);
    426      1.5  christos #endif
    427      1.1    jruoho 
    428      1.1    jruoho 
    429      1.1    jruoho /*
    430      1.1    jruoho  * Miscellaneous
    431      1.1    jruoho  */
    432      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsReadable
    433      1.1    jruoho BOOLEAN
    434      1.1    jruoho AcpiOsReadable (
    435      1.1    jruoho     void                    *Pointer,
    436      1.1    jruoho     ACPI_SIZE               Length);
    437      1.5  christos #endif
    438      1.1    jruoho 
    439      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsWritable
    440      1.1    jruoho BOOLEAN
    441      1.1    jruoho AcpiOsWritable (
    442      1.1    jruoho     void                    *Pointer,
    443      1.1    jruoho     ACPI_SIZE               Length);
    444      1.5  christos #endif
    445      1.1    jruoho 
    446      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetTimer
    447      1.1    jruoho UINT64
    448      1.1    jruoho AcpiOsGetTimer (
    449      1.1    jruoho     void);
    450      1.5  christos #endif
    451      1.1    jruoho 
    452      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsSignal
    453      1.1    jruoho ACPI_STATUS
    454      1.1    jruoho AcpiOsSignal (
    455      1.1    jruoho     UINT32                  Function,
    456      1.1    jruoho     void                    *Info);
    457      1.5  christos #endif
    458      1.1    jruoho 
    459  1.9.2.2  pgoyette #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsEnterSleep
    460  1.9.2.2  pgoyette ACPI_STATUS
    461  1.9.2.2  pgoyette AcpiOsEnterSleep (
    462  1.9.2.2  pgoyette     UINT8                   SleepState,
    463  1.9.2.2  pgoyette     UINT32                  RegaValue,
    464  1.9.2.2  pgoyette     UINT32                  RegbValue);
    465  1.9.2.2  pgoyette #endif
    466  1.9.2.2  pgoyette 
    467      1.1    jruoho 
    468      1.1    jruoho /*
    469      1.1    jruoho  * Debug print routines
    470      1.1    jruoho  */
    471      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsPrintf
    472      1.1    jruoho void ACPI_INTERNAL_VAR_XFACE
    473      1.1    jruoho AcpiOsPrintf (
    474      1.1    jruoho     const char              *Format,
    475      1.1    jruoho     ...);
    476      1.5  christos #endif
    477      1.1    jruoho 
    478      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsVprintf
    479      1.1    jruoho void
    480      1.1    jruoho AcpiOsVprintf (
    481      1.1    jruoho     const char              *Format,
    482      1.1    jruoho     va_list                 Args);
    483      1.5  christos #endif
    484      1.1    jruoho 
    485      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsRedirectOutput
    486      1.1    jruoho void
    487      1.1    jruoho AcpiOsRedirectOutput (
    488      1.1    jruoho     void                    *Destination);
    489      1.5  christos #endif
    490      1.1    jruoho 
    491      1.1    jruoho 
    492      1.1    jruoho /*
    493  1.9.2.2  pgoyette  * Debug IO
    494      1.1    jruoho  */
    495      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetLine
    496      1.4    jruoho ACPI_STATUS
    497      1.1    jruoho AcpiOsGetLine (
    498      1.4    jruoho     char                    *Buffer,
    499      1.4    jruoho     UINT32                  BufferLength,
    500      1.4    jruoho     UINT32                  *BytesRead);
    501      1.5  christos #endif
    502      1.5  christos 
    503  1.9.2.2  pgoyette #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsInitializeDebugger
    504  1.9.2.2  pgoyette ACPI_STATUS
    505  1.9.2.2  pgoyette AcpiOsInitializeDebugger (
    506  1.9.2.2  pgoyette     void);
    507  1.9.2.2  pgoyette #endif
    508  1.9.2.2  pgoyette 
    509  1.9.2.2  pgoyette #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsTerminateDebugger
    510  1.9.2.2  pgoyette void
    511  1.9.2.2  pgoyette AcpiOsTerminateDebugger (
    512  1.9.2.2  pgoyette     void);
    513  1.9.2.2  pgoyette #endif
    514  1.9.2.2  pgoyette 
    515  1.9.2.2  pgoyette #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsWaitCommandReady
    516  1.9.2.2  pgoyette ACPI_STATUS
    517  1.9.2.2  pgoyette AcpiOsWaitCommandReady (
    518  1.9.2.2  pgoyette     void);
    519  1.9.2.2  pgoyette #endif
    520  1.9.2.2  pgoyette 
    521  1.9.2.2  pgoyette #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsNotifyCommandComplete
    522  1.9.2.2  pgoyette ACPI_STATUS
    523  1.9.2.2  pgoyette AcpiOsNotifyCommandComplete (
    524  1.9.2.2  pgoyette     void);
    525  1.9.2.2  pgoyette #endif
    526  1.9.2.2  pgoyette 
    527  1.9.2.1  pgoyette #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsTracePoint
    528  1.9.2.1  pgoyette void
    529  1.9.2.1  pgoyette AcpiOsTracePoint (
    530  1.9.2.1  pgoyette     ACPI_TRACE_EVENT_TYPE   Type,
    531  1.9.2.1  pgoyette     BOOLEAN                 Begin,
    532  1.9.2.1  pgoyette     UINT8                   *Aml,
    533  1.9.2.1  pgoyette     char                    *Pathname);
    534  1.9.2.1  pgoyette #endif
    535  1.9.2.1  pgoyette 
    536      1.5  christos 
    537      1.5  christos /*
    538      1.5  christos  * Obtain ACPI table(s)
    539      1.5  christos  */
    540      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetTableByName
    541      1.5  christos ACPI_STATUS
    542      1.5  christos AcpiOsGetTableByName (
    543      1.5  christos     char                    *Signature,
    544      1.5  christos     UINT32                  Instance,
    545      1.5  christos     ACPI_TABLE_HEADER       **Table,
    546      1.5  christos     ACPI_PHYSICAL_ADDRESS   *Address);
    547      1.5  christos #endif
    548      1.5  christos 
    549      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetTableByIndex
    550      1.5  christos ACPI_STATUS
    551      1.5  christos AcpiOsGetTableByIndex (
    552      1.5  christos     UINT32                  Index,
    553      1.5  christos     ACPI_TABLE_HEADER       **Table,
    554      1.5  christos     UINT32                  *Instance,
    555      1.5  christos     ACPI_PHYSICAL_ADDRESS   *Address);
    556      1.5  christos #endif
    557      1.5  christos 
    558      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetTableByAddress
    559      1.5  christos ACPI_STATUS
    560      1.5  christos AcpiOsGetTableByAddress (
    561      1.5  christos     ACPI_PHYSICAL_ADDRESS   Address,
    562      1.5  christos     ACPI_TABLE_HEADER       **Table);
    563      1.5  christos #endif
    564      1.1    jruoho 
    565      1.1    jruoho 
    566      1.1    jruoho /*
    567      1.1    jruoho  * Directory manipulation
    568      1.1    jruoho  */
    569      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsOpenDirectory
    570      1.1    jruoho void *
    571      1.1    jruoho AcpiOsOpenDirectory (
    572      1.1    jruoho     char                    *Pathname,
    573      1.1    jruoho     char                    *WildcardSpec,
    574      1.1    jruoho     char                    RequestedFileType);
    575      1.5  christos #endif
    576      1.1    jruoho 
    577      1.1    jruoho /* RequesteFileType values */
    578      1.1    jruoho 
    579      1.1    jruoho #define REQUEST_FILE_ONLY                   0
    580      1.1    jruoho #define REQUEST_DIR_ONLY                    1
    581      1.1    jruoho 
    582      1.1    jruoho 
    583      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetNextFilename
    584      1.1    jruoho char *
    585      1.1    jruoho AcpiOsGetNextFilename (
    586      1.1    jruoho     void                    *DirHandle);
    587      1.5  christos #endif
    588      1.1    jruoho 
    589      1.5  christos #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsCloseDirectory
    590      1.1    jruoho void
    591      1.1    jruoho AcpiOsCloseDirectory (
    592      1.1    jruoho     void                    *DirHandle);
    593      1.5  christos #endif
    594      1.1    jruoho 
    595      1.1    jruoho 
    596      1.1    jruoho #endif /* __ACPIOSXF_H__ */
    597