Home | History | Annotate | Line # | Download | only in include
acpiosxf.h revision 1.4.12.1
      1       1.1  jruoho /******************************************************************************
      2       1.1  jruoho  *
      3  1.4.12.1     tls  * 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.4.12.1     tls  * Copyright (C) 2000 - 2013, 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.1  jruoho     OSL_DEBUGGER_THREAD,
     61       1.1  jruoho     OSL_EC_POLL_HANDLER,
     62       1.1  jruoho     OSL_EC_BURST_HANDLER
     63       1.1  jruoho 
     64       1.1  jruoho } ACPI_EXECUTE_TYPE;
     65       1.1  jruoho 
     66       1.1  jruoho #define ACPI_NO_UNIT_LIMIT          ((UINT32) -1)
     67       1.1  jruoho #define ACPI_MUTEX_SEM              1
     68       1.1  jruoho 
     69       1.1  jruoho 
     70       1.1  jruoho /* Functions for AcpiOsSignal */
     71       1.1  jruoho 
     72       1.1  jruoho #define ACPI_SIGNAL_FATAL           0
     73       1.1  jruoho #define ACPI_SIGNAL_BREAKPOINT      1
     74       1.1  jruoho 
     75       1.1  jruoho typedef struct acpi_signal_fatal_info
     76       1.1  jruoho {
     77       1.1  jruoho     UINT32                  Type;
     78       1.1  jruoho     UINT32                  Code;
     79       1.1  jruoho     UINT32                  Argument;
     80       1.1  jruoho 
     81       1.1  jruoho } ACPI_SIGNAL_FATAL_INFO;
     82       1.1  jruoho 
     83       1.1  jruoho 
     84       1.1  jruoho /*
     85       1.1  jruoho  * OSL Initialization and shutdown primitives
     86       1.1  jruoho  */
     87  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsInitialize
     88       1.1  jruoho ACPI_STATUS
     89       1.1  jruoho AcpiOsInitialize (
     90       1.1  jruoho     void);
     91  1.4.12.1     tls #endif
     92       1.1  jruoho 
     93  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsTerminate
     94       1.1  jruoho ACPI_STATUS
     95       1.1  jruoho AcpiOsTerminate (
     96       1.1  jruoho     void);
     97  1.4.12.1     tls #endif
     98       1.1  jruoho 
     99       1.1  jruoho 
    100       1.1  jruoho /*
    101       1.1  jruoho  * ACPI Table interfaces
    102       1.1  jruoho  */
    103  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetRootPointer
    104       1.1  jruoho ACPI_PHYSICAL_ADDRESS
    105       1.1  jruoho AcpiOsGetRootPointer (
    106       1.1  jruoho     void);
    107  1.4.12.1     tls #endif
    108       1.1  jruoho 
    109  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsPredefinedOverride
    110       1.1  jruoho ACPI_STATUS
    111       1.1  jruoho AcpiOsPredefinedOverride (
    112       1.1  jruoho     const ACPI_PREDEFINED_NAMES *InitVal,
    113       1.1  jruoho     ACPI_STRING                 *NewVal);
    114  1.4.12.1     tls #endif
    115       1.1  jruoho 
    116  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsTableOverride
    117       1.1  jruoho ACPI_STATUS
    118       1.1  jruoho AcpiOsTableOverride (
    119       1.1  jruoho     ACPI_TABLE_HEADER       *ExistingTable,
    120       1.1  jruoho     ACPI_TABLE_HEADER       **NewTable);
    121  1.4.12.1     tls #endif
    122  1.4.12.1     tls 
    123  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsPhysicalTableOverride
    124  1.4.12.1     tls ACPI_STATUS
    125  1.4.12.1     tls AcpiOsPhysicalTableOverride (
    126  1.4.12.1     tls     ACPI_TABLE_HEADER       *ExistingTable,
    127  1.4.12.1     tls     ACPI_PHYSICAL_ADDRESS   *NewAddress,
    128  1.4.12.1     tls     UINT32                  *NewTableLength);
    129  1.4.12.1     tls #endif
    130       1.1  jruoho 
    131       1.1  jruoho 
    132       1.1  jruoho /*
    133       1.1  jruoho  * Spinlock primitives
    134       1.1  jruoho  */
    135  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsCreateLock
    136       1.1  jruoho ACPI_STATUS
    137       1.1  jruoho AcpiOsCreateLock (
    138       1.1  jruoho     ACPI_SPINLOCK           *OutHandle);
    139  1.4.12.1     tls #endif
    140       1.1  jruoho 
    141  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsDeleteLock
    142       1.1  jruoho void
    143       1.1  jruoho AcpiOsDeleteLock (
    144       1.1  jruoho     ACPI_SPINLOCK           Handle);
    145  1.4.12.1     tls #endif
    146       1.1  jruoho 
    147  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsAcquireLock
    148       1.1  jruoho ACPI_CPU_FLAGS
    149       1.1  jruoho AcpiOsAcquireLock (
    150       1.1  jruoho     ACPI_SPINLOCK           Handle);
    151  1.4.12.1     tls #endif
    152       1.1  jruoho 
    153  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsReleaseLock
    154       1.1  jruoho void
    155       1.1  jruoho AcpiOsReleaseLock (
    156       1.1  jruoho     ACPI_SPINLOCK           Handle,
    157       1.1  jruoho     ACPI_CPU_FLAGS          Flags);
    158  1.4.12.1     tls #endif
    159       1.1  jruoho 
    160       1.1  jruoho 
    161       1.1  jruoho /*
    162       1.1  jruoho  * Semaphore primitives
    163       1.1  jruoho  */
    164  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsCreateSemaphore
    165       1.1  jruoho ACPI_STATUS
    166       1.1  jruoho AcpiOsCreateSemaphore (
    167       1.1  jruoho     UINT32                  MaxUnits,
    168       1.1  jruoho     UINT32                  InitialUnits,
    169       1.1  jruoho     ACPI_SEMAPHORE          *OutHandle);
    170  1.4.12.1     tls #endif
    171       1.1  jruoho 
    172  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsDeleteSemaphore
    173       1.1  jruoho ACPI_STATUS
    174       1.1  jruoho AcpiOsDeleteSemaphore (
    175       1.1  jruoho     ACPI_SEMAPHORE          Handle);
    176  1.4.12.1     tls #endif
    177       1.1  jruoho 
    178  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsWaitSemaphore
    179       1.1  jruoho ACPI_STATUS
    180       1.1  jruoho AcpiOsWaitSemaphore (
    181       1.1  jruoho     ACPI_SEMAPHORE          Handle,
    182       1.1  jruoho     UINT32                  Units,
    183       1.1  jruoho     UINT16                  Timeout);
    184  1.4.12.1     tls #endif
    185       1.1  jruoho 
    186  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsSignalSemaphore
    187       1.1  jruoho ACPI_STATUS
    188       1.1  jruoho AcpiOsSignalSemaphore (
    189       1.1  jruoho     ACPI_SEMAPHORE          Handle,
    190       1.1  jruoho     UINT32                  Units);
    191  1.4.12.1     tls #endif
    192       1.1  jruoho 
    193       1.1  jruoho 
    194       1.1  jruoho /*
    195       1.1  jruoho  * Mutex primitives. May be configured to use semaphores instead via
    196       1.1  jruoho  * ACPI_MUTEX_TYPE (see platform/acenv.h)
    197       1.1  jruoho  */
    198       1.1  jruoho #if (ACPI_MUTEX_TYPE != ACPI_BINARY_SEMAPHORE)
    199       1.1  jruoho 
    200  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsCreateMutex
    201       1.1  jruoho ACPI_STATUS
    202       1.1  jruoho AcpiOsCreateMutex (
    203       1.1  jruoho     ACPI_MUTEX              *OutHandle);
    204  1.4.12.1     tls #endif
    205       1.1  jruoho 
    206  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsDeleteMutex
    207       1.1  jruoho void
    208       1.1  jruoho AcpiOsDeleteMutex (
    209       1.1  jruoho     ACPI_MUTEX              Handle);
    210  1.4.12.1     tls #endif
    211       1.1  jruoho 
    212  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsAcquireMutex
    213       1.1  jruoho ACPI_STATUS
    214       1.1  jruoho AcpiOsAcquireMutex (
    215       1.1  jruoho     ACPI_MUTEX              Handle,
    216       1.1  jruoho     UINT16                  Timeout);
    217  1.4.12.1     tls #endif
    218       1.1  jruoho 
    219  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsReleaseMutex
    220       1.1  jruoho void
    221       1.1  jruoho AcpiOsReleaseMutex (
    222       1.1  jruoho     ACPI_MUTEX              Handle);
    223       1.1  jruoho #endif
    224       1.1  jruoho 
    225  1.4.12.1     tls #endif
    226  1.4.12.1     tls 
    227       1.1  jruoho 
    228       1.1  jruoho /*
    229       1.1  jruoho  * Memory allocation and mapping
    230       1.1  jruoho  */
    231  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsAllocate
    232       1.1  jruoho void *
    233       1.1  jruoho AcpiOsAllocate (
    234       1.1  jruoho     ACPI_SIZE               Size);
    235  1.4.12.1     tls #endif
    236  1.4.12.1     tls 
    237  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsAllocateZeroed
    238  1.4.12.1     tls void *
    239  1.4.12.1     tls AcpiOsAllocateZeroed (
    240  1.4.12.1     tls     ACPI_SIZE               Size);
    241  1.4.12.1     tls #endif
    242       1.1  jruoho 
    243  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsFree
    244       1.1  jruoho void
    245       1.1  jruoho AcpiOsFree (
    246       1.1  jruoho     void *                  Memory);
    247  1.4.12.1     tls #endif
    248       1.1  jruoho 
    249  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsMapMemory
    250       1.1  jruoho void *
    251       1.1  jruoho AcpiOsMapMemory (
    252       1.1  jruoho     ACPI_PHYSICAL_ADDRESS   Where,
    253       1.1  jruoho     ACPI_SIZE               Length);
    254  1.4.12.1     tls #endif
    255       1.1  jruoho 
    256  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsUnmapMemory
    257       1.1  jruoho void
    258       1.1  jruoho AcpiOsUnmapMemory (
    259       1.1  jruoho     void                    *LogicalAddress,
    260       1.1  jruoho     ACPI_SIZE               Size);
    261  1.4.12.1     tls #endif
    262       1.1  jruoho 
    263  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetPhysicalAddress
    264       1.1  jruoho ACPI_STATUS
    265       1.1  jruoho AcpiOsGetPhysicalAddress (
    266       1.1  jruoho     void                    *LogicalAddress,
    267       1.1  jruoho     ACPI_PHYSICAL_ADDRESS   *PhysicalAddress);
    268  1.4.12.1     tls #endif
    269       1.1  jruoho 
    270       1.1  jruoho 
    271       1.1  jruoho /*
    272       1.1  jruoho  * Memory/Object Cache
    273       1.1  jruoho  */
    274  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsCreateCache
    275       1.1  jruoho ACPI_STATUS
    276       1.1  jruoho AcpiOsCreateCache (
    277       1.2  jruoho     const char              *CacheName,
    278       1.1  jruoho     UINT16                  ObjectSize,
    279       1.1  jruoho     UINT16                  MaxDepth,
    280       1.1  jruoho     ACPI_CACHE_T            **ReturnCache);
    281  1.4.12.1     tls #endif
    282       1.1  jruoho 
    283  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsDeleteCache
    284       1.1  jruoho ACPI_STATUS
    285       1.1  jruoho AcpiOsDeleteCache (
    286       1.1  jruoho     ACPI_CACHE_T            *Cache);
    287  1.4.12.1     tls #endif
    288       1.1  jruoho 
    289  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsPurgeCache
    290       1.1  jruoho ACPI_STATUS
    291       1.1  jruoho AcpiOsPurgeCache (
    292       1.1  jruoho     ACPI_CACHE_T            *Cache);
    293  1.4.12.1     tls #endif
    294       1.1  jruoho 
    295  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsAcquireObject
    296       1.1  jruoho void *
    297       1.1  jruoho AcpiOsAcquireObject (
    298       1.1  jruoho     ACPI_CACHE_T            *Cache);
    299  1.4.12.1     tls #endif
    300       1.1  jruoho 
    301  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsReleaseObject
    302       1.1  jruoho ACPI_STATUS
    303       1.1  jruoho AcpiOsReleaseObject (
    304       1.1  jruoho     ACPI_CACHE_T            *Cache,
    305       1.1  jruoho     void                    *Object);
    306  1.4.12.1     tls #endif
    307       1.1  jruoho 
    308       1.1  jruoho 
    309       1.1  jruoho /*
    310       1.1  jruoho  * Interrupt handlers
    311       1.1  jruoho  */
    312  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsInstallInterruptHandler
    313       1.1  jruoho ACPI_STATUS
    314       1.1  jruoho AcpiOsInstallInterruptHandler (
    315       1.1  jruoho     UINT32                  InterruptNumber,
    316       1.1  jruoho     ACPI_OSD_HANDLER        ServiceRoutine,
    317       1.1  jruoho     void                    *Context);
    318  1.4.12.1     tls #endif
    319       1.1  jruoho 
    320  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsRemoveInterruptHandler
    321       1.1  jruoho ACPI_STATUS
    322       1.1  jruoho AcpiOsRemoveInterruptHandler (
    323       1.1  jruoho     UINT32                  InterruptNumber,
    324       1.1  jruoho     ACPI_OSD_HANDLER        ServiceRoutine);
    325  1.4.12.1     tls #endif
    326       1.1  jruoho 
    327       1.1  jruoho 
    328       1.1  jruoho /*
    329       1.1  jruoho  * Threads and Scheduling
    330       1.1  jruoho  */
    331  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetThreadId
    332       1.1  jruoho ACPI_THREAD_ID
    333       1.1  jruoho AcpiOsGetThreadId (
    334       1.1  jruoho     void);
    335  1.4.12.1     tls #endif
    336       1.1  jruoho 
    337  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsExecute
    338       1.1  jruoho ACPI_STATUS
    339       1.1  jruoho AcpiOsExecute (
    340       1.1  jruoho     ACPI_EXECUTE_TYPE       Type,
    341       1.1  jruoho     ACPI_OSD_EXEC_CALLBACK  Function,
    342       1.1  jruoho     void                    *Context);
    343  1.4.12.1     tls #endif
    344       1.1  jruoho 
    345  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsWaitEventsComplete
    346       1.1  jruoho void
    347       1.1  jruoho AcpiOsWaitEventsComplete (
    348  1.4.12.1     tls     void);
    349  1.4.12.1     tls #endif
    350       1.1  jruoho 
    351  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsSleep
    352       1.1  jruoho void
    353       1.1  jruoho AcpiOsSleep (
    354       1.1  jruoho     UINT64                  Milliseconds);
    355  1.4.12.1     tls #endif
    356       1.1  jruoho 
    357  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsStall
    358       1.1  jruoho void
    359       1.1  jruoho AcpiOsStall (
    360       1.1  jruoho     UINT32                  Microseconds);
    361  1.4.12.1     tls #endif
    362       1.1  jruoho 
    363       1.1  jruoho 
    364       1.1  jruoho /*
    365       1.1  jruoho  * Platform and hardware-independent I/O interfaces
    366       1.1  jruoho  */
    367  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsReadPort
    368       1.1  jruoho ACPI_STATUS
    369       1.1  jruoho AcpiOsReadPort (
    370       1.1  jruoho     ACPI_IO_ADDRESS         Address,
    371       1.1  jruoho     UINT32                  *Value,
    372       1.1  jruoho     UINT32                  Width);
    373  1.4.12.1     tls #endif
    374       1.1  jruoho 
    375  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsWritePort
    376       1.1  jruoho ACPI_STATUS
    377       1.1  jruoho AcpiOsWritePort (
    378       1.1  jruoho     ACPI_IO_ADDRESS         Address,
    379       1.1  jruoho     UINT32                  Value,
    380       1.1  jruoho     UINT32                  Width);
    381  1.4.12.1     tls #endif
    382       1.1  jruoho 
    383       1.1  jruoho 
    384       1.1  jruoho /*
    385       1.1  jruoho  * Platform and hardware-independent physical memory interfaces
    386       1.1  jruoho  */
    387  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsReadMemory
    388       1.1  jruoho ACPI_STATUS
    389       1.1  jruoho AcpiOsReadMemory (
    390       1.1  jruoho     ACPI_PHYSICAL_ADDRESS   Address,
    391  1.4.12.1     tls     UINT64                  *Value,
    392       1.1  jruoho     UINT32                  Width);
    393  1.4.12.1     tls #endif
    394       1.1  jruoho 
    395  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsWriteMemory
    396       1.1  jruoho ACPI_STATUS
    397       1.1  jruoho AcpiOsWriteMemory (
    398       1.1  jruoho     ACPI_PHYSICAL_ADDRESS   Address,
    399  1.4.12.1     tls     UINT64                  Value,
    400       1.1  jruoho     UINT32                  Width);
    401  1.4.12.1     tls #endif
    402       1.1  jruoho 
    403       1.1  jruoho 
    404       1.1  jruoho /*
    405       1.1  jruoho  * Platform and hardware-independent PCI configuration space access
    406       1.1  jruoho  * Note: Can't use "Register" as a parameter, changed to "Reg" --
    407       1.1  jruoho  * certain compilers complain.
    408       1.1  jruoho  */
    409  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsReadPciConfiguration
    410       1.1  jruoho ACPI_STATUS
    411       1.1  jruoho AcpiOsReadPciConfiguration (
    412       1.1  jruoho     ACPI_PCI_ID             *PciId,
    413       1.1  jruoho     UINT32                  Reg,
    414       1.3  jruoho     UINT64                  *Value,
    415       1.1  jruoho     UINT32                  Width);
    416  1.4.12.1     tls #endif
    417       1.1  jruoho 
    418  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsWritePciConfiguration
    419       1.1  jruoho ACPI_STATUS
    420       1.1  jruoho AcpiOsWritePciConfiguration (
    421       1.1  jruoho     ACPI_PCI_ID             *PciId,
    422       1.1  jruoho     UINT32                  Reg,
    423       1.1  jruoho     UINT64                  Value,
    424       1.1  jruoho     UINT32                  Width);
    425  1.4.12.1     tls #endif
    426       1.1  jruoho 
    427       1.1  jruoho 
    428       1.1  jruoho /*
    429       1.1  jruoho  * Miscellaneous
    430       1.1  jruoho  */
    431  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsReadable
    432       1.1  jruoho BOOLEAN
    433       1.1  jruoho AcpiOsReadable (
    434       1.1  jruoho     void                    *Pointer,
    435       1.1  jruoho     ACPI_SIZE               Length);
    436  1.4.12.1     tls #endif
    437       1.1  jruoho 
    438  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsWritable
    439       1.1  jruoho BOOLEAN
    440       1.1  jruoho AcpiOsWritable (
    441       1.1  jruoho     void                    *Pointer,
    442       1.1  jruoho     ACPI_SIZE               Length);
    443  1.4.12.1     tls #endif
    444       1.1  jruoho 
    445  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetTimer
    446       1.1  jruoho UINT64
    447       1.1  jruoho AcpiOsGetTimer (
    448       1.1  jruoho     void);
    449  1.4.12.1     tls #endif
    450       1.1  jruoho 
    451  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsSignal
    452       1.1  jruoho ACPI_STATUS
    453       1.1  jruoho AcpiOsSignal (
    454       1.1  jruoho     UINT32                  Function,
    455       1.1  jruoho     void                    *Info);
    456  1.4.12.1     tls #endif
    457       1.1  jruoho 
    458       1.1  jruoho 
    459       1.1  jruoho /*
    460       1.1  jruoho  * Debug print routines
    461       1.1  jruoho  */
    462  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsPrintf
    463       1.1  jruoho void ACPI_INTERNAL_VAR_XFACE
    464       1.1  jruoho AcpiOsPrintf (
    465       1.1  jruoho     const char              *Format,
    466       1.1  jruoho     ...);
    467  1.4.12.1     tls #endif
    468       1.1  jruoho 
    469  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsVprintf
    470       1.1  jruoho void
    471       1.1  jruoho AcpiOsVprintf (
    472       1.1  jruoho     const char              *Format,
    473       1.1  jruoho     va_list                 Args);
    474  1.4.12.1     tls #endif
    475       1.1  jruoho 
    476  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsRedirectOutput
    477       1.1  jruoho void
    478       1.1  jruoho AcpiOsRedirectOutput (
    479       1.1  jruoho     void                    *Destination);
    480  1.4.12.1     tls #endif
    481       1.1  jruoho 
    482       1.1  jruoho 
    483       1.1  jruoho /*
    484       1.1  jruoho  * Debug input
    485       1.1  jruoho  */
    486  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetLine
    487       1.4  jruoho ACPI_STATUS
    488       1.1  jruoho AcpiOsGetLine (
    489       1.4  jruoho     char                    *Buffer,
    490       1.4  jruoho     UINT32                  BufferLength,
    491       1.4  jruoho     UINT32                  *BytesRead);
    492  1.4.12.1     tls #endif
    493  1.4.12.1     tls 
    494  1.4.12.1     tls 
    495  1.4.12.1     tls /*
    496  1.4.12.1     tls  * Obtain ACPI table(s)
    497  1.4.12.1     tls  */
    498  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetTableByName
    499  1.4.12.1     tls ACPI_STATUS
    500  1.4.12.1     tls AcpiOsGetTableByName (
    501  1.4.12.1     tls     char                    *Signature,
    502  1.4.12.1     tls     UINT32                  Instance,
    503  1.4.12.1     tls     ACPI_TABLE_HEADER       **Table,
    504  1.4.12.1     tls     ACPI_PHYSICAL_ADDRESS   *Address);
    505  1.4.12.1     tls #endif
    506  1.4.12.1     tls 
    507  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetTableByIndex
    508  1.4.12.1     tls ACPI_STATUS
    509  1.4.12.1     tls AcpiOsGetTableByIndex (
    510  1.4.12.1     tls     UINT32                  Index,
    511  1.4.12.1     tls     ACPI_TABLE_HEADER       **Table,
    512  1.4.12.1     tls     UINT32                  *Instance,
    513  1.4.12.1     tls     ACPI_PHYSICAL_ADDRESS   *Address);
    514  1.4.12.1     tls #endif
    515  1.4.12.1     tls 
    516  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetTableByAddress
    517  1.4.12.1     tls ACPI_STATUS
    518  1.4.12.1     tls AcpiOsGetTableByAddress (
    519  1.4.12.1     tls     ACPI_PHYSICAL_ADDRESS   Address,
    520  1.4.12.1     tls     ACPI_TABLE_HEADER       **Table);
    521  1.4.12.1     tls #endif
    522       1.1  jruoho 
    523       1.1  jruoho 
    524       1.1  jruoho /*
    525       1.1  jruoho  * Directory manipulation
    526       1.1  jruoho  */
    527  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsOpenDirectory
    528       1.1  jruoho void *
    529       1.1  jruoho AcpiOsOpenDirectory (
    530       1.1  jruoho     char                    *Pathname,
    531       1.1  jruoho     char                    *WildcardSpec,
    532       1.1  jruoho     char                    RequestedFileType);
    533  1.4.12.1     tls #endif
    534       1.1  jruoho 
    535       1.1  jruoho /* RequesteFileType values */
    536       1.1  jruoho 
    537       1.1  jruoho #define REQUEST_FILE_ONLY                   0
    538       1.1  jruoho #define REQUEST_DIR_ONLY                    1
    539       1.1  jruoho 
    540       1.1  jruoho 
    541  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetNextFilename
    542       1.1  jruoho char *
    543       1.1  jruoho AcpiOsGetNextFilename (
    544       1.1  jruoho     void                    *DirHandle);
    545  1.4.12.1     tls #endif
    546       1.1  jruoho 
    547  1.4.12.1     tls #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsCloseDirectory
    548       1.1  jruoho void
    549       1.1  jruoho AcpiOsCloseDirectory (
    550       1.1  jruoho     void                    *DirHandle);
    551  1.4.12.1     tls #endif
    552       1.1  jruoho 
    553       1.1  jruoho 
    554       1.1  jruoho #endif /* __ACPIOSXF_H__ */
    555