10d02842fSSascha Wildner /******************************************************************************
20d02842fSSascha Wildner  *
30d02842fSSascha Wildner  * Module Name: oswintbl - Windows OSL for obtaining ACPI tables
40d02842fSSascha Wildner  *
50d02842fSSascha Wildner  *****************************************************************************/
60d02842fSSascha Wildner 
7b4315fc7SSascha Wildner /******************************************************************************
8b4315fc7SSascha Wildner  *
9b4315fc7SSascha Wildner  * 1. Copyright Notice
10b4315fc7SSascha Wildner  *
11*383048acSSascha Wildner  * Some or all of this work - Copyright (c) 1999 - 2021, Intel Corp.
120d02842fSSascha Wildner  * All rights reserved.
130d02842fSSascha Wildner  *
14b4315fc7SSascha Wildner  * 2. License
15b4315fc7SSascha Wildner  *
16b4315fc7SSascha Wildner  * 2.1. This is your license from Intel Corp. under its intellectual property
17b4315fc7SSascha Wildner  * rights. You may have additional license terms from the party that provided
18b4315fc7SSascha Wildner  * you this software, covering your right to use that party's intellectual
19b4315fc7SSascha Wildner  * property rights.
20b4315fc7SSascha Wildner  *
21b4315fc7SSascha Wildner  * 2.2. Intel grants, free of charge, to any person ("Licensee") obtaining a
22b4315fc7SSascha Wildner  * copy of the source code appearing in this file ("Covered Code") an
23b4315fc7SSascha Wildner  * irrevocable, perpetual, worldwide license under Intel's copyrights in the
24b4315fc7SSascha Wildner  * base code distributed originally by Intel ("Original Intel Code") to copy,
25b4315fc7SSascha Wildner  * make derivatives, distribute, use and display any portion of the Covered
26b4315fc7SSascha Wildner  * Code in any form, with the right to sublicense such rights; and
27b4315fc7SSascha Wildner  *
28b4315fc7SSascha Wildner  * 2.3. Intel grants Licensee a non-exclusive and non-transferable patent
29b4315fc7SSascha Wildner  * license (with the right to sublicense), under only those claims of Intel
30b4315fc7SSascha Wildner  * patents that are infringed by the Original Intel Code, to make, use, sell,
31b4315fc7SSascha Wildner  * offer to sell, and import the Covered Code and derivative works thereof
32b4315fc7SSascha Wildner  * solely to the minimum extent necessary to exercise the above copyright
33b4315fc7SSascha Wildner  * license, and in no event shall the patent license extend to any additions
34b4315fc7SSascha Wildner  * to or modifications of the Original Intel Code. No other license or right
35b4315fc7SSascha Wildner  * is granted directly or by implication, estoppel or otherwise;
36b4315fc7SSascha Wildner  *
37b4315fc7SSascha Wildner  * The above copyright and patent license is granted only if the following
38b4315fc7SSascha Wildner  * conditions are met:
39b4315fc7SSascha Wildner  *
40b4315fc7SSascha Wildner  * 3. Conditions
41b4315fc7SSascha Wildner  *
42b4315fc7SSascha Wildner  * 3.1. Redistribution of Source with Rights to Further Distribute Source.
43b4315fc7SSascha Wildner  * Redistribution of source code of any substantial portion of the Covered
44b4315fc7SSascha Wildner  * Code or modification with rights to further distribute source must include
45b4315fc7SSascha Wildner  * the above Copyright Notice, the above License, this list of Conditions,
46b4315fc7SSascha Wildner  * and the following Disclaimer and Export Compliance provision. In addition,
47b4315fc7SSascha Wildner  * Licensee must cause all Covered Code to which Licensee contributes to
48b4315fc7SSascha Wildner  * contain a file documenting the changes Licensee made to create that Covered
49b4315fc7SSascha Wildner  * Code and the date of any change. Licensee must include in that file the
50b4315fc7SSascha Wildner  * documentation of any changes made by any predecessor Licensee. Licensee
51b4315fc7SSascha Wildner  * must include a prominent statement that the modification is derived,
52b4315fc7SSascha Wildner  * directly or indirectly, from Original Intel Code.
53b4315fc7SSascha Wildner  *
54b4315fc7SSascha Wildner  * 3.2. Redistribution of Source with no Rights to Further Distribute Source.
55b4315fc7SSascha Wildner  * Redistribution of source code of any substantial portion of the Covered
56b4315fc7SSascha Wildner  * Code or modification without rights to further distribute source must
57b4315fc7SSascha Wildner  * include the following Disclaimer and Export Compliance provision in the
58b4315fc7SSascha Wildner  * documentation and/or other materials provided with distribution. In
59b4315fc7SSascha Wildner  * addition, Licensee may not authorize further sublicense of source of any
60b4315fc7SSascha Wildner  * portion of the Covered Code, and must include terms to the effect that the
61b4315fc7SSascha Wildner  * license from Licensee to its licensee is limited to the intellectual
62b4315fc7SSascha Wildner  * property embodied in the software Licensee provides to its licensee, and
63b4315fc7SSascha Wildner  * not to intellectual property embodied in modifications its licensee may
64b4315fc7SSascha Wildner  * make.
65b4315fc7SSascha Wildner  *
66b4315fc7SSascha Wildner  * 3.3. Redistribution of Executable. Redistribution in executable form of any
67b4315fc7SSascha Wildner  * substantial portion of the Covered Code or modification must reproduce the
68b4315fc7SSascha Wildner  * above Copyright Notice, and the following Disclaimer and Export Compliance
69b4315fc7SSascha Wildner  * provision in the documentation and/or other materials provided with the
70b4315fc7SSascha Wildner  * distribution.
71b4315fc7SSascha Wildner  *
72b4315fc7SSascha Wildner  * 3.4. Intel retains all right, title, and interest in and to the Original
73b4315fc7SSascha Wildner  * Intel Code.
74b4315fc7SSascha Wildner  *
75b4315fc7SSascha Wildner  * 3.5. Neither the name Intel nor any other trademark owned or controlled by
76b4315fc7SSascha Wildner  * Intel shall be used in advertising or otherwise to promote the sale, use or
77b4315fc7SSascha Wildner  * other dealings in products derived from or relating to the Covered Code
78b4315fc7SSascha Wildner  * without prior written authorization from Intel.
79b4315fc7SSascha Wildner  *
80b4315fc7SSascha Wildner  * 4. Disclaimer and Export Compliance
81b4315fc7SSascha Wildner  *
82b4315fc7SSascha Wildner  * 4.1. INTEL MAKES NO WARRANTY OF ANY KIND REGARDING ANY SOFTWARE PROVIDED
83b4315fc7SSascha Wildner  * HERE. ANY SOFTWARE ORIGINATING FROM INTEL OR DERIVED FROM INTEL SOFTWARE
84b4315fc7SSascha Wildner  * IS PROVIDED "AS IS," AND INTEL WILL NOT PROVIDE ANY SUPPORT, ASSISTANCE,
85b4315fc7SSascha Wildner  * INSTALLATION, TRAINING OR OTHER SERVICES. INTEL WILL NOT PROVIDE ANY
86b4315fc7SSascha Wildner  * UPDATES, ENHANCEMENTS OR EXTENSIONS. INTEL SPECIFICALLY DISCLAIMS ANY
87b4315fc7SSascha Wildner  * IMPLIED WARRANTIES OF MERCHANTABILITY, NONINFRINGEMENT AND FITNESS FOR A
88b4315fc7SSascha Wildner  * PARTICULAR PURPOSE.
89b4315fc7SSascha Wildner  *
90b4315fc7SSascha Wildner  * 4.2. IN NO EVENT SHALL INTEL HAVE ANY LIABILITY TO LICENSEE, ITS LICENSEES
91b4315fc7SSascha Wildner  * OR ANY OTHER THIRD PARTY, FOR ANY LOST PROFITS, LOST DATA, LOSS OF USE OR
92b4315fc7SSascha Wildner  * COSTS OF PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES, OR FOR ANY INDIRECT,
93b4315fc7SSascha Wildner  * SPECIAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THIS AGREEMENT, UNDER ANY
94b4315fc7SSascha Wildner  * CAUSE OF ACTION OR THEORY OF LIABILITY, AND IRRESPECTIVE OF WHETHER INTEL
95b4315fc7SSascha Wildner  * HAS ADVANCE NOTICE OF THE POSSIBILITY OF SUCH DAMAGES. THESE LIMITATIONS
96b4315fc7SSascha Wildner  * SHALL APPLY NOTWITHSTANDING THE FAILURE OF THE ESSENTIAL PURPOSE OF ANY
97b4315fc7SSascha Wildner  * LIMITED REMEDY.
98b4315fc7SSascha Wildner  *
99b4315fc7SSascha Wildner  * 4.3. Licensee shall not export, either directly or indirectly, any of this
100b4315fc7SSascha Wildner  * software or system incorporating such software without first obtaining any
101b4315fc7SSascha Wildner  * required license or other approval from the U. S. Department of Commerce or
102b4315fc7SSascha Wildner  * any other agency or department of the United States Government. In the
103b4315fc7SSascha Wildner  * event Licensee exports any such software from the United States or
104b4315fc7SSascha Wildner  * re-exports any such software from a foreign destination, Licensee shall
105b4315fc7SSascha Wildner  * ensure that the distribution and export/re-export of the software is in
106b4315fc7SSascha Wildner  * compliance with all laws, regulations, orders, or other restrictions of the
107b4315fc7SSascha Wildner  * U.S. Export Administration Regulations. Licensee agrees that neither it nor
108b4315fc7SSascha Wildner  * any of its subsidiaries will export/re-export any technical data, process,
109b4315fc7SSascha Wildner  * software, or service, directly or indirectly, to any country for which the
110b4315fc7SSascha Wildner  * United States government or any agency thereof requires an export license,
111b4315fc7SSascha Wildner  * other governmental approval, or letter of assurance, without first obtaining
112b4315fc7SSascha Wildner  * such license, approval or letter.
113b4315fc7SSascha Wildner  *
114b4315fc7SSascha Wildner  *****************************************************************************
115b4315fc7SSascha Wildner  *
116b4315fc7SSascha Wildner  * Alternatively, you may choose to be licensed under the terms of the
117b4315fc7SSascha Wildner  * following license:
118b4315fc7SSascha Wildner  *
1190d02842fSSascha Wildner  * Redistribution and use in source and binary forms, with or without
1200d02842fSSascha Wildner  * modification, are permitted provided that the following conditions
1210d02842fSSascha Wildner  * are met:
1220d02842fSSascha Wildner  * 1. Redistributions of source code must retain the above copyright
1230d02842fSSascha Wildner  *    notice, this list of conditions, and the following disclaimer,
1240d02842fSSascha Wildner  *    without modification.
1250d02842fSSascha Wildner  * 2. Redistributions in binary form must reproduce at minimum a disclaimer
1260d02842fSSascha Wildner  *    substantially similar to the "NO WARRANTY" disclaimer below
1270d02842fSSascha Wildner  *    ("Disclaimer") and any redistribution must be conditioned upon
1280d02842fSSascha Wildner  *    including a substantially similar Disclaimer requirement for further
1290d02842fSSascha Wildner  *    binary redistribution.
1300d02842fSSascha Wildner  * 3. Neither the names of the above-listed copyright holders nor the names
1310d02842fSSascha Wildner  *    of any contributors may be used to endorse or promote products derived
1320d02842fSSascha Wildner  *    from this software without specific prior written permission.
1330d02842fSSascha Wildner  *
134b4315fc7SSascha Wildner  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
135b4315fc7SSascha Wildner  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
136b4315fc7SSascha Wildner  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
137b4315fc7SSascha Wildner  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
138b4315fc7SSascha Wildner  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
139b4315fc7SSascha Wildner  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
140b4315fc7SSascha Wildner  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
141b4315fc7SSascha Wildner  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
142b4315fc7SSascha Wildner  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
143b4315fc7SSascha Wildner  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
144b4315fc7SSascha Wildner  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
145b4315fc7SSascha Wildner  *
146b4315fc7SSascha Wildner  * Alternatively, you may choose to be licensed under the terms of the
1470d02842fSSascha Wildner  * GNU General Public License ("GPL") version 2 as published by the Free
1480d02842fSSascha Wildner  * Software Foundation.
1490d02842fSSascha Wildner  *
150b4315fc7SSascha Wildner  *****************************************************************************/
1510d02842fSSascha Wildner 
1520d02842fSSascha Wildner #include "acpi.h"
1530d02842fSSascha Wildner #include "accommon.h"
1540d02842fSSascha Wildner #include "acutils.h"
1550d02842fSSascha Wildner #include <stdio.h>
1560d02842fSSascha Wildner 
1570d02842fSSascha Wildner #ifdef WIN32
1580d02842fSSascha Wildner #pragma warning(disable:4115)   /* warning C4115: (caused by rpcasync.h) */
1590d02842fSSascha Wildner #include <windows.h>
1600d02842fSSascha Wildner 
1610d02842fSSascha Wildner #elif WIN64
1620d02842fSSascha Wildner #include <windowsx.h>
1630d02842fSSascha Wildner #endif
1640d02842fSSascha Wildner 
1650d02842fSSascha Wildner #define _COMPONENT          ACPI_OS_SERVICES
1660d02842fSSascha Wildner         ACPI_MODULE_NAME    ("oswintbl")
1670d02842fSSascha Wildner 
1680d02842fSSascha Wildner /* Local prototypes */
1690d02842fSSascha Wildner 
1700d02842fSSascha Wildner static char *
1710d02842fSSascha Wildner WindowsFormatException (
1720d02842fSSascha Wildner     LONG                WinStatus);
1730d02842fSSascha Wildner 
1740d02842fSSascha Wildner /* Globals */
1750d02842fSSascha Wildner 
1760d02842fSSascha Wildner #define LOCAL_BUFFER_SIZE           64
1770d02842fSSascha Wildner 
1780d02842fSSascha Wildner static char             KeyBuffer[LOCAL_BUFFER_SIZE];
1790d02842fSSascha Wildner static char             ErrorBuffer[LOCAL_BUFFER_SIZE];
1800d02842fSSascha Wildner 
1810d02842fSSascha Wildner /*
182ff3cb46dSSascha Wildner  * List of table signatures reported by EnumSystemFirmwareTables ()
1830d02842fSSascha Wildner  */
184ff3cb46dSSascha Wildner UINT32                  *Gbl_AvailableTableSignatures;
185ff3cb46dSSascha Wildner UINT32                  Gbl_TableCount = 0;
186ff3cb46dSSascha Wildner UINT32                  Gbl_SsdtInstance = 0;
1870d02842fSSascha Wildner 
188ff3cb46dSSascha Wildner BOOLEAN                 Gbl_TableListInitialized = FALSE;
1890d02842fSSascha Wildner 
190ff3cb46dSSascha Wildner static ACPI_STATUS
191ff3cb46dSSascha Wildner OslTableInitialize (
192ff3cb46dSSascha Wildner     void);
1930d02842fSSascha Wildner 
1940d02842fSSascha Wildner 
1950d02842fSSascha Wildner /******************************************************************************
1960d02842fSSascha Wildner  *
1970d02842fSSascha Wildner  * FUNCTION:    WindowsFormatException
1980d02842fSSascha Wildner  *
1990d02842fSSascha Wildner  * PARAMETERS:  WinStatus       - Status from a Windows system call
2000d02842fSSascha Wildner  *
2010d02842fSSascha Wildner  * RETURN:      Formatted (ascii) exception code. Front-end to Windows
2020d02842fSSascha Wildner  *              FormatMessage interface.
2030d02842fSSascha Wildner  *
2040d02842fSSascha Wildner  * DESCRIPTION: Decode a windows exception
2050d02842fSSascha Wildner  *
2060d02842fSSascha Wildner  *****************************************************************************/
2070d02842fSSascha Wildner 
2080d02842fSSascha Wildner static char *
WindowsFormatException(LONG WinStatus)2090d02842fSSascha Wildner WindowsFormatException (
2100d02842fSSascha Wildner     LONG                WinStatus)
2110d02842fSSascha Wildner {
2120d02842fSSascha Wildner 
2130d02842fSSascha Wildner     ErrorBuffer[0] = 0;
2140d02842fSSascha Wildner     FormatMessage (FORMAT_MESSAGE_FROM_SYSTEM, NULL, WinStatus, 0,
2150d02842fSSascha Wildner         ErrorBuffer, LOCAL_BUFFER_SIZE, NULL);
2160d02842fSSascha Wildner 
2170d02842fSSascha Wildner     return (ErrorBuffer);
2180d02842fSSascha Wildner }
2190d02842fSSascha Wildner 
2200d02842fSSascha Wildner 
2210d02842fSSascha Wildner /******************************************************************************
2220d02842fSSascha Wildner  *
2230d02842fSSascha Wildner  * FUNCTION:    AcpiOsGetTableByAddress
2240d02842fSSascha Wildner  *
2250d02842fSSascha Wildner  * PARAMETERS:  Address         - Physical address of the ACPI table
2260d02842fSSascha Wildner  *              Table           - Where a pointer to the table is returned
2270d02842fSSascha Wildner  *
2280d02842fSSascha Wildner  * RETURN:      Status; Table buffer is returned if AE_OK.
2290d02842fSSascha Wildner  *              AE_NOT_FOUND: A valid table was not found at the address
2300d02842fSSascha Wildner  *
2310d02842fSSascha Wildner  * DESCRIPTION: Get an ACPI table via a physical memory address.
2320d02842fSSascha Wildner  *
2330d02842fSSascha Wildner  * NOTE:        Cannot be implemented without a Windows device driver.
2340d02842fSSascha Wildner  *
2350d02842fSSascha Wildner  *****************************************************************************/
2360d02842fSSascha Wildner 
2370d02842fSSascha Wildner ACPI_STATUS
AcpiOsGetTableByAddress(ACPI_PHYSICAL_ADDRESS Address,ACPI_TABLE_HEADER ** Table)2380d02842fSSascha Wildner AcpiOsGetTableByAddress (
2390d02842fSSascha Wildner     ACPI_PHYSICAL_ADDRESS   Address,
2400d02842fSSascha Wildner     ACPI_TABLE_HEADER       **Table)
2410d02842fSSascha Wildner {
2420d02842fSSascha Wildner 
2430d02842fSSascha Wildner     fprintf (stderr, "Get table by address is not supported on Windows\n");
2440d02842fSSascha Wildner     return (AE_SUPPORT);
2450d02842fSSascha Wildner }
2460d02842fSSascha Wildner 
2470d02842fSSascha Wildner 
2480d02842fSSascha Wildner /******************************************************************************
2490d02842fSSascha Wildner  *
2500d02842fSSascha Wildner  * FUNCTION:    AcpiOsGetTableByIndex
2510d02842fSSascha Wildner  *
2520d02842fSSascha Wildner  * PARAMETERS:  Index           - Which table to get
2530d02842fSSascha Wildner  *              Table           - Where a pointer to the table is returned
2540d02842fSSascha Wildner  *              Instance        - Where a pointer to the table instance no. is
2550d02842fSSascha Wildner  *                                returned
2560d02842fSSascha Wildner  *              Address         - Where the table physical address is returned
2570d02842fSSascha Wildner  *
2580d02842fSSascha Wildner  * RETURN:      Status; Table buffer and physical address returned if AE_OK.
2590d02842fSSascha Wildner  *              AE_LIMIT: Index is beyond valid limit
2600d02842fSSascha Wildner  *
2610d02842fSSascha Wildner  * DESCRIPTION: Get an ACPI table via an index value (0 through n). Returns
2620d02842fSSascha Wildner  *              AE_LIMIT when an invalid index is reached. Index is not
2630d02842fSSascha Wildner  *              necessarily an index into the RSDT/XSDT.
264ff3cb46dSSascha Wildner  *              SSDT tables are obtained from the Windows registry. All other
265ff3cb46dSSascha Wildner  *              tables are obtained through GetSystemFirmwareTable ().
2660d02842fSSascha Wildner  *
2670d02842fSSascha Wildner  * NOTE:        Cannot get the physical address from the windows registry;
2680d02842fSSascha Wildner  *              zero is returned instead.
2690d02842fSSascha Wildner  *
2700d02842fSSascha Wildner  *****************************************************************************/
2710d02842fSSascha Wildner 
2720d02842fSSascha Wildner ACPI_STATUS
AcpiOsGetTableByIndex(UINT32 Index,ACPI_TABLE_HEADER ** Table,UINT32 * Instance,ACPI_PHYSICAL_ADDRESS * Address)2730d02842fSSascha Wildner AcpiOsGetTableByIndex (
2740d02842fSSascha Wildner     UINT32                  Index,
2750d02842fSSascha Wildner     ACPI_TABLE_HEADER       **Table,
2760d02842fSSascha Wildner     UINT32                  *Instance,
2770d02842fSSascha Wildner     ACPI_PHYSICAL_ADDRESS   *Address)
2780d02842fSSascha Wildner {
2790d02842fSSascha Wildner     ACPI_STATUS             Status;
280277350a0SSascha Wildner     char                    *Signature;
281ff3cb46dSSascha Wildner     UINT32                  CurrentInstance;
2820d02842fSSascha Wildner 
2830d02842fSSascha Wildner 
284ff3cb46dSSascha Wildner     /* Enumerate all ACPI table signatures on first invocation of this function */
285ff3cb46dSSascha Wildner 
286ff3cb46dSSascha Wildner     Status = OslTableInitialize ();
287ff3cb46dSSascha Wildner     if (ACPI_FAILURE (Status))
2880d02842fSSascha Wildner     {
289ff3cb46dSSascha Wildner         return (Status);
290ff3cb46dSSascha Wildner     }
291ff3cb46dSSascha Wildner 
292ff3cb46dSSascha Wildner     /* Validate Index */
293ff3cb46dSSascha Wildner 
294ff3cb46dSSascha Wildner     if (Index < Gbl_TableCount)
295ff3cb46dSSascha Wildner     {
296ff3cb46dSSascha Wildner         Signature = malloc (ACPI_NAMESEG_SIZE + 1);
297ff3cb46dSSascha Wildner         if (!Signature)
298ff3cb46dSSascha Wildner         {
299ff3cb46dSSascha Wildner             return (AE_NO_MEMORY);
300ff3cb46dSSascha Wildner         }
301ff3cb46dSSascha Wildner 
302ff3cb46dSSascha Wildner         Signature = memmove (Signature, &Gbl_AvailableTableSignatures[Index], ACPI_NAMESEG_SIZE);
303277350a0SSascha Wildner     }
304277350a0SSascha Wildner     else
305277350a0SSascha Wildner     {
306ff3cb46dSSascha Wildner         return (AE_LIMIT);
3070d02842fSSascha Wildner     }
3080d02842fSSascha Wildner 
309ff3cb46dSSascha Wildner     if (ACPI_COMPARE_NAMESEG (Signature, ACPI_SIG_SSDT))
310ff3cb46dSSascha Wildner     {
311ff3cb46dSSascha Wildner         CurrentInstance = Gbl_SsdtInstance;
312ff3cb46dSSascha Wildner         Gbl_SsdtInstance++;
313ff3cb46dSSascha Wildner     }
314ff3cb46dSSascha Wildner     else
315ff3cb46dSSascha Wildner     {
316ff3cb46dSSascha Wildner         CurrentInstance = 0;
317ff3cb46dSSascha Wildner     }
318277350a0SSascha Wildner 
319ff3cb46dSSascha Wildner     Status = AcpiOsGetTableByName (Signature, CurrentInstance, Table, Address);
320277350a0SSascha Wildner     if (ACPI_SUCCESS (Status))
321277350a0SSascha Wildner     {
322ff3cb46dSSascha Wildner         *Instance = CurrentInstance;
323277350a0SSascha Wildner     }
324c1776041SSascha Wildner     else if (Status == AE_NOT_FOUND &&
325c1776041SSascha Wildner         ACPI_COMPARE_NAMESEG (Signature, ACPI_SIG_SSDT))
326277350a0SSascha Wildner     {
327277350a0SSascha Wildner         /* Treat SSDTs that are not found as invalid index. */
328ff3cb46dSSascha Wildner         Status = AE_LIMIT;
329277350a0SSascha Wildner     }
330277350a0SSascha Wildner 
331ff3cb46dSSascha Wildner     free (Signature);
3320d02842fSSascha Wildner     return (Status);
3330d02842fSSascha Wildner }
3340d02842fSSascha Wildner 
335ff3cb46dSSascha Wildner /******************************************************************************
336ff3cb46dSSascha Wildner  *
337ff3cb46dSSascha Wildner  * FUNCTION:    OslTableInitialize
338ff3cb46dSSascha Wildner  *
339ff3cb46dSSascha Wildner  * PARAMETERS:  None
340ff3cb46dSSascha Wildner  *
341ff3cb46dSSascha Wildner  * RETURN:      Status
342ff3cb46dSSascha Wildner  *
343ff3cb46dSSascha Wildner  * DESCRIPTION: Initialize ACPI table data. Enumerate all ACPI table signatures
344ff3cb46dSSascha Wildner  *              and save them to a global list.
345ff3cb46dSSascha Wildner  *
346ff3cb46dSSascha Wildner  *****************************************************************************/
347ff3cb46dSSascha Wildner static ACPI_STATUS
OslTableInitialize(void)348ff3cb46dSSascha Wildner OslTableInitialize (
349ff3cb46dSSascha Wildner     void)
350ff3cb46dSSascha Wildner {
351ff3cb46dSSascha Wildner     UINT32                  ResultSize;
352ff3cb46dSSascha Wildner     UINT32                  DataSize;
353ff3cb46dSSascha Wildner 
354ff3cb46dSSascha Wildner     if (Gbl_TableListInitialized)
355ff3cb46dSSascha Wildner     {
356ff3cb46dSSascha Wildner         return (AE_OK);
357ff3cb46dSSascha Wildner     }
358ff3cb46dSSascha Wildner 
359ff3cb46dSSascha Wildner     /*
360ff3cb46dSSascha Wildner      * ACPI table signatures are always 4 characters. Therefore, the data size
361ff3cb46dSSascha Wildner      * buffer should be a multiple of 4
362ff3cb46dSSascha Wildner      */
363ff3cb46dSSascha Wildner     DataSize = EnumSystemFirmwareTables ('ACPI', NULL, 0);
364ff3cb46dSSascha Wildner     if (DataSize % ACPI_NAMESEG_SIZE)
365ff3cb46dSSascha Wildner     {
366ff3cb46dSSascha Wildner         return (AE_ERROR);
367ff3cb46dSSascha Wildner     }
368ff3cb46dSSascha Wildner 
369ff3cb46dSSascha Wildner     /*
370ff3cb46dSSascha Wildner      * EnumSystemFirmwareTables () does not report the DSDT or XSDT. Work around this
371ff3cb46dSSascha Wildner      * by adding these entries manually.
372ff3cb46dSSascha Wildner      */
373ff3cb46dSSascha Wildner     Gbl_TableCount = 2 + DataSize / ACPI_NAMESEG_SIZE;
374ff3cb46dSSascha Wildner     Gbl_AvailableTableSignatures = malloc (Gbl_TableCount * ACPI_NAMESEG_SIZE);
375ff3cb46dSSascha Wildner     if (!Gbl_AvailableTableSignatures)
376ff3cb46dSSascha Wildner     {
377ff3cb46dSSascha Wildner         return (AE_NO_MEMORY);
378ff3cb46dSSascha Wildner     }
379ff3cb46dSSascha Wildner 
380ff3cb46dSSascha Wildner     ResultSize = EnumSystemFirmwareTables ('ACPI', Gbl_AvailableTableSignatures, DataSize);
381ff3cb46dSSascha Wildner     if (ResultSize > DataSize)
382ff3cb46dSSascha Wildner     {
383ff3cb46dSSascha Wildner         return (AE_ERROR);
384ff3cb46dSSascha Wildner     }
385ff3cb46dSSascha Wildner 
386ff3cb46dSSascha Wildner     /* Insert the DSDT and XSDT tables signatures */
387ff3cb46dSSascha Wildner 
388ff3cb46dSSascha Wildner     Gbl_AvailableTableSignatures [Gbl_TableCount - 1] = 'TDSD';
389ff3cb46dSSascha Wildner     Gbl_AvailableTableSignatures [Gbl_TableCount - 2] = 'TDSX';
390ff3cb46dSSascha Wildner 
391ff3cb46dSSascha Wildner     Gbl_TableListInitialized = TRUE;
392ff3cb46dSSascha Wildner     return (AE_OK);
393ff3cb46dSSascha Wildner }
394ff3cb46dSSascha Wildner 
3950d02842fSSascha Wildner 
3960d02842fSSascha Wildner /******************************************************************************
3970d02842fSSascha Wildner  *
398ff3cb46dSSascha Wildner  * FUNCTION:    WindowsGetTableFromRegistry
3990d02842fSSascha Wildner  *
4000d02842fSSascha Wildner  * PARAMETERS:  Signature       - ACPI Signature for desired table. Must be
4010d02842fSSascha Wildner  *                                a null terminated 4-character string.
4020d02842fSSascha Wildner  *              Instance        - For SSDTs (0...n). Use 0 otherwise.
4030d02842fSSascha Wildner  *              Table           - Where a pointer to the table is returned
4040d02842fSSascha Wildner  *              Address         - Where the table physical address is returned
4050d02842fSSascha Wildner  *
4060d02842fSSascha Wildner  * RETURN:      Status; Table buffer and physical address returned if AE_OK.
4070d02842fSSascha Wildner  *              AE_LIMIT: Instance is beyond valid limit
4080d02842fSSascha Wildner  *              AE_NOT_FOUND: A table with the signature was not found
4090d02842fSSascha Wildner  *
4100d02842fSSascha Wildner  * DESCRIPTION: Get an ACPI table via a table signature (4 ASCII characters).
4110d02842fSSascha Wildner  *              Returns AE_LIMIT when an invalid instance is reached.
4120d02842fSSascha Wildner  *              Table is obtained from the Windows registry.
4130d02842fSSascha Wildner  *
4140d02842fSSascha Wildner  * NOTE:        Assumes the input signature is uppercase.
4150d02842fSSascha Wildner  *              Cannot get the physical address from the windows registry;
4160d02842fSSascha Wildner  *              zero is returned instead.
4170d02842fSSascha Wildner  *
4180d02842fSSascha Wildner  *****************************************************************************/
4190d02842fSSascha Wildner 
420ff3cb46dSSascha Wildner static ACPI_STATUS
WindowsGetTableFromRegistry(char * Signature,UINT32 Instance,ACPI_TABLE_HEADER ** Table,ACPI_PHYSICAL_ADDRESS * Address)421ff3cb46dSSascha Wildner WindowsGetTableFromRegistry (
4220d02842fSSascha Wildner     char                    *Signature,
4230d02842fSSascha Wildner     UINT32                  Instance,
4240d02842fSSascha Wildner     ACPI_TABLE_HEADER       **Table,
4250d02842fSSascha Wildner     ACPI_PHYSICAL_ADDRESS   *Address)
4260d02842fSSascha Wildner {
4270d02842fSSascha Wildner     HKEY                    Handle = NULL;
4280d02842fSSascha Wildner     LONG                    WinStatus;
4290d02842fSSascha Wildner     ULONG                   Type;
4300d02842fSSascha Wildner     ULONG                   NameSize;
4310d02842fSSascha Wildner     ULONG                   DataSize;
4320d02842fSSascha Wildner     HKEY                    SubKey;
4330d02842fSSascha Wildner     ULONG                   i;
4340d02842fSSascha Wildner     ACPI_TABLE_HEADER       *ReturnTable;
435d4972a9cSSascha Wildner     ACPI_STATUS             Status = AE_OK;
4360d02842fSSascha Wildner 
4370d02842fSSascha Wildner 
4380d02842fSSascha Wildner     /* Get a handle to the table key */
4390d02842fSSascha Wildner 
4400d02842fSSascha Wildner     while (1)
4410d02842fSSascha Wildner     {
44225ca8c79SSascha Wildner         strcpy(KeyBuffer, "HARDWARE\\ACPI\\");
4430d02842fSSascha Wildner         if (AcpiUtSafeStrcat(KeyBuffer, sizeof(KeyBuffer), Signature))
4440d02842fSSascha Wildner         {
4450d02842fSSascha Wildner             return (AE_BUFFER_OVERFLOW);
4460d02842fSSascha Wildner         }
4470d02842fSSascha Wildner 
448277350a0SSascha Wildner         /*
449277350a0SSascha Wildner          * Windows stores SSDT at SSDT, SSD1, ..., SSD9, SSDA, ..., SSDS, SSDT,
450277350a0SSascha Wildner          * SSDU, ..., SSDY. If the first (0th) and the 29th tables have the same
451277350a0SSascha Wildner          * OEM ID, Table ID and Revision, then the 29th entry will overwrite the
452277350a0SSascha Wildner          * first entry... Let's hope that we do not have that many entries.
453277350a0SSascha Wildner          */
454c1776041SSascha Wildner         if (Instance > 0 && ACPI_COMPARE_NAMESEG(Signature, ACPI_SIG_SSDT))
455277350a0SSascha Wildner         {
456277350a0SSascha Wildner             if (Instance < 10)
457277350a0SSascha Wildner             {
458277350a0SSascha Wildner                 KeyBuffer[strlen(KeyBuffer) - 1] = '0' + (char)Instance;
459277350a0SSascha Wildner             }
460277350a0SSascha Wildner             else if (Instance < 29)
461277350a0SSascha Wildner             {
462277350a0SSascha Wildner                 KeyBuffer[strlen(KeyBuffer) - 1] = 'A' + (char)(Instance - 10);
463277350a0SSascha Wildner             }
464277350a0SSascha Wildner             else
465277350a0SSascha Wildner             {
466277350a0SSascha Wildner                 return (AE_LIMIT);
467277350a0SSascha Wildner             }
468277350a0SSascha Wildner         }
469277350a0SSascha Wildner 
4700d02842fSSascha Wildner         WinStatus = RegOpenKeyEx(HKEY_LOCAL_MACHINE, KeyBuffer,
4710d02842fSSascha Wildner             0L, KEY_READ, &Handle);
4720d02842fSSascha Wildner 
4730d02842fSSascha Wildner         if (WinStatus != ERROR_SUCCESS)
4740d02842fSSascha Wildner         {
4750d02842fSSascha Wildner             /*
4760d02842fSSascha Wildner              * Somewhere along the way, MS changed the registry entry for
4770d02842fSSascha Wildner              * the FADT from
4780d02842fSSascha Wildner              * HARDWARE/ACPI/FACP  to
4790d02842fSSascha Wildner              * HARDWARE/ACPI/FADT.
4800d02842fSSascha Wildner              *
4810d02842fSSascha Wildner              * This code allows for both.
4820d02842fSSascha Wildner              */
483c1776041SSascha Wildner             if (ACPI_COMPARE_NAMESEG(Signature, "FACP"))
4840d02842fSSascha Wildner             {
4850d02842fSSascha Wildner                 Signature = "FADT";
4860d02842fSSascha Wildner             }
487c1776041SSascha Wildner             else if (ACPI_COMPARE_NAMESEG(Signature, "XSDT"))
4880d02842fSSascha Wildner             {
4890d02842fSSascha Wildner                 Signature = "RSDT";
4900d02842fSSascha Wildner             }
491c1776041SSascha Wildner             else if (ACPI_COMPARE_NAMESEG(Signature, ACPI_SIG_SSDT))
492277350a0SSascha Wildner             {
493ff3cb46dSSascha Wildner                 /*
494ff3cb46dSSascha Wildner                  * SSDT may not be present on older Windows versions, but it is
495ff3cb46dSSascha Wildner                  * also possible that the index is not found.
496ff3cb46dSSascha Wildner                  */
497277350a0SSascha Wildner                 return (AE_NOT_FOUND);
498277350a0SSascha Wildner             }
4990d02842fSSascha Wildner             else
5000d02842fSSascha Wildner             {
5010d02842fSSascha Wildner                 fprintf(stderr,
5020d02842fSSascha Wildner                     "Could not find %s in registry at %s: %s (WinStatus=0x%X)\n",
5030d02842fSSascha Wildner                     Signature, KeyBuffer, WindowsFormatException(WinStatus), WinStatus);
5040d02842fSSascha Wildner                 return (AE_NOT_FOUND);
5050d02842fSSascha Wildner             }
5060d02842fSSascha Wildner         }
5070d02842fSSascha Wildner         else
5080d02842fSSascha Wildner         {
5090d02842fSSascha Wildner             break;
5100d02842fSSascha Wildner         }
5110d02842fSSascha Wildner     }
5120d02842fSSascha Wildner 
5130d02842fSSascha Wildner     /* Actual data for the table is down a couple levels */
5140d02842fSSascha Wildner 
5150d02842fSSascha Wildner     for (i = 0; ;)
5160d02842fSSascha Wildner     {
5170d02842fSSascha Wildner         WinStatus = RegEnumKey(Handle, i, KeyBuffer, sizeof(KeyBuffer));
5180d02842fSSascha Wildner         i++;
5190d02842fSSascha Wildner         if (WinStatus == ERROR_NO_MORE_ITEMS)
5200d02842fSSascha Wildner         {
5210d02842fSSascha Wildner             break;
5220d02842fSSascha Wildner         }
5230d02842fSSascha Wildner 
5240d02842fSSascha Wildner         WinStatus = RegOpenKey(Handle, KeyBuffer, &SubKey);
5250d02842fSSascha Wildner         if (WinStatus != ERROR_SUCCESS)
5260d02842fSSascha Wildner         {
5270d02842fSSascha Wildner             fprintf(stderr, "Could not open %s entry: %s\n",
5280d02842fSSascha Wildner                 Signature, WindowsFormatException(WinStatus));
529d4972a9cSSascha Wildner             Status = AE_ERROR;
530d4972a9cSSascha Wildner             goto Cleanup;
5310d02842fSSascha Wildner         }
5320d02842fSSascha Wildner 
5330d02842fSSascha Wildner         RegCloseKey(Handle);
5340d02842fSSascha Wildner         Handle = SubKey;
5350d02842fSSascha Wildner         i = 0;
5360d02842fSSascha Wildner     }
5370d02842fSSascha Wildner 
5380d02842fSSascha Wildner     /* Find the (binary) table entry */
5390d02842fSSascha Wildner 
5400d02842fSSascha Wildner     for (i = 0; ; i++)
5410d02842fSSascha Wildner     {
5420d02842fSSascha Wildner         NameSize = sizeof(KeyBuffer);
5430d02842fSSascha Wildner         WinStatus = RegEnumValue(Handle, i, KeyBuffer, &NameSize, NULL,
5440d02842fSSascha Wildner             &Type, NULL, 0);
5450d02842fSSascha Wildner         if (WinStatus != ERROR_SUCCESS)
5460d02842fSSascha Wildner         {
5470d02842fSSascha Wildner             fprintf(stderr, "Could not get %s registry entry: %s\n",
5480d02842fSSascha Wildner                 Signature, WindowsFormatException(WinStatus));
549d4972a9cSSascha Wildner             Status = AE_ERROR;
550d4972a9cSSascha Wildner             goto Cleanup;
5510d02842fSSascha Wildner         }
5520d02842fSSascha Wildner 
5530d02842fSSascha Wildner         if (Type == REG_BINARY)
5540d02842fSSascha Wildner         {
5550d02842fSSascha Wildner             break;
5560d02842fSSascha Wildner         }
5570d02842fSSascha Wildner     }
5580d02842fSSascha Wildner 
5590d02842fSSascha Wildner     /* Get the size of the table */
5600d02842fSSascha Wildner 
5610d02842fSSascha Wildner     WinStatus = RegQueryValueEx(Handle, KeyBuffer, NULL, NULL,
5620d02842fSSascha Wildner         NULL, &DataSize);
563066b6da2SSascha Wildner     if (WinStatus != ERROR_SUCCESS)
5640d02842fSSascha Wildner     {
5650d02842fSSascha Wildner         fprintf(stderr, "Could not read the %s table size: %s\n",
5660d02842fSSascha Wildner             Signature, WindowsFormatException(WinStatus));
567d4972a9cSSascha Wildner         Status = AE_ERROR;
568d4972a9cSSascha Wildner         goto Cleanup;
5690d02842fSSascha Wildner     }
5700d02842fSSascha Wildner 
5710d02842fSSascha Wildner     /* Allocate a new buffer for the table */
5720d02842fSSascha Wildner 
5730d02842fSSascha Wildner     ReturnTable = malloc(DataSize);
5740d02842fSSascha Wildner     if (!ReturnTable)
5750d02842fSSascha Wildner     {
576d4972a9cSSascha Wildner         Status = AE_NO_MEMORY;
5770d02842fSSascha Wildner         goto Cleanup;
5780d02842fSSascha Wildner     }
5790d02842fSSascha Wildner 
5800d02842fSSascha Wildner     /* Get the actual table from the registry */
5810d02842fSSascha Wildner 
5820d02842fSSascha Wildner     WinStatus = RegQueryValueEx(Handle, KeyBuffer, NULL, NULL,
5830d02842fSSascha Wildner         (UCHAR *)ReturnTable, &DataSize);
584ff3cb46dSSascha Wildner 
585066b6da2SSascha Wildner     if (WinStatus != ERROR_SUCCESS)
5860d02842fSSascha Wildner     {
5870d02842fSSascha Wildner         fprintf(stderr, "Could not read %s data: %s\n",
5880d02842fSSascha Wildner             Signature, WindowsFormatException(WinStatus));
5890d02842fSSascha Wildner         free(ReturnTable);
590d4972a9cSSascha Wildner         Status = AE_ERROR;
591d4972a9cSSascha Wildner         goto Cleanup;
5920d02842fSSascha Wildner     }
5930d02842fSSascha Wildner 
5940d02842fSSascha Wildner     *Table = ReturnTable;
5950d02842fSSascha Wildner     *Address = 0;
596d4972a9cSSascha Wildner 
597d4972a9cSSascha Wildner Cleanup:
598d4972a9cSSascha Wildner     RegCloseKey(Handle);
599d4972a9cSSascha Wildner     return (Status);
6000d02842fSSascha Wildner }
6010d02842fSSascha Wildner 
6020d02842fSSascha Wildner 
603ff3cb46dSSascha Wildner /******************************************************************************
604ff3cb46dSSascha Wildner  *
605ff3cb46dSSascha Wildner  * FUNCTION:    AcpiOsGetTableByName
606ff3cb46dSSascha Wildner  *
607ff3cb46dSSascha Wildner  * PARAMETERS:  Signature       - ACPI Signature for desired table. Must be
608ff3cb46dSSascha Wildner  *                                a null terminated 4-character string.
609ff3cb46dSSascha Wildner  *              Instance        - For SSDTs (0...n). Use 0 otherwise.
610ff3cb46dSSascha Wildner  *              Table           - Where a pointer to the table is returned
611ff3cb46dSSascha Wildner  *              Address         - Where the table physical address is returned
612ff3cb46dSSascha Wildner  *
613ff3cb46dSSascha Wildner  * RETURN:      Status; Table buffer and physical address returned if AE_OK.
614ff3cb46dSSascha Wildner  *              AE_LIMIT: Instance is beyond valid limit
615ff3cb46dSSascha Wildner  *              AE_NOT_FOUND: A table with the signature was not found
616ff3cb46dSSascha Wildner  *
617ff3cb46dSSascha Wildner  * DESCRIPTION: Get an ACPI table via a table signature (4 ASCII characters).
618ff3cb46dSSascha Wildner  *              Returns AE_LIMIT when an invalid instance is reached.
619ff3cb46dSSascha Wildner  *              Table is obtained from the Windows registry.
620ff3cb46dSSascha Wildner  *
621ff3cb46dSSascha Wildner  * NOTE:        Assumes the input signature is uppercase.
622ff3cb46dSSascha Wildner  *              Cannot get the physical address from the windows registry;
623ff3cb46dSSascha Wildner  *              zero is returned instead.
624ff3cb46dSSascha Wildner  *
625ff3cb46dSSascha Wildner  *****************************************************************************/
626ff3cb46dSSascha Wildner 
627ff3cb46dSSascha Wildner ACPI_STATUS
AcpiOsGetTableByName(char * Signature,UINT32 Instance,ACPI_TABLE_HEADER ** Table,ACPI_PHYSICAL_ADDRESS * Address)628ff3cb46dSSascha Wildner AcpiOsGetTableByName(
629ff3cb46dSSascha Wildner     char                    *Signature,
630ff3cb46dSSascha Wildner     UINT32                  Instance,
631ff3cb46dSSascha Wildner     ACPI_TABLE_HEADER       **Table,
632ff3cb46dSSascha Wildner     ACPI_PHYSICAL_ADDRESS   *Address)
633ff3cb46dSSascha Wildner {
634ff3cb46dSSascha Wildner     LONG                    Result;
635ff3cb46dSSascha Wildner     ACPI_STATUS             Status = AE_OK;
636ff3cb46dSSascha Wildner     UINT32                  DataSize;
637ff3cb46dSSascha Wildner     ACPI_TABLE_HEADER       *ReturnTable;
638ff3cb46dSSascha Wildner     UINT32                  UIntSignature = 0;
639ff3cb46dSSascha Wildner 
640ff3cb46dSSascha Wildner 
641ff3cb46dSSascha Wildner     /* Multiple instances are only supported for SSDT tables. */
642ff3cb46dSSascha Wildner 
643ff3cb46dSSascha Wildner     if (Instance > 0 && !ACPI_COMPARE_NAMESEG (Signature, ACPI_SIG_SSDT))
644ff3cb46dSSascha Wildner     {
645ff3cb46dSSascha Wildner         return (AE_LIMIT);
646ff3cb46dSSascha Wildner     }
647ff3cb46dSSascha Wildner 
648ff3cb46dSSascha Wildner     if (ACPI_COMPARE_NAMESEG (Signature, ACPI_SIG_SSDT))
649ff3cb46dSSascha Wildner     {
650ff3cb46dSSascha Wildner         Status = WindowsGetTableFromRegistry ("SSDT", Instance, Table, Address);
651ff3cb46dSSascha Wildner         return (Status);
652ff3cb46dSSascha Wildner     }
653ff3cb46dSSascha Wildner 
654ff3cb46dSSascha Wildner     /* GetSystemFirmwareTable requires the table signature to be UINT32 */
655ff3cb46dSSascha Wildner 
656ff3cb46dSSascha Wildner     UIntSignature = *ACPI_CAST_PTR (UINT32, Signature);
657ff3cb46dSSascha Wildner     DataSize = GetSystemFirmwareTable('ACPI', UIntSignature, NULL, 0);
658ff3cb46dSSascha Wildner     if (!DataSize)
659ff3cb46dSSascha Wildner     {
660ff3cb46dSSascha Wildner         fprintf(stderr, "The table signature %s does not exist.", Signature);
661ff3cb46dSSascha Wildner         return (AE_ERROR);
662ff3cb46dSSascha Wildner     }
663ff3cb46dSSascha Wildner 
664ff3cb46dSSascha Wildner     ReturnTable = malloc(DataSize);
665ff3cb46dSSascha Wildner     if (!ReturnTable)
666ff3cb46dSSascha Wildner     {
667ff3cb46dSSascha Wildner         return (AE_NO_MEMORY);
668ff3cb46dSSascha Wildner     }
669ff3cb46dSSascha Wildner 
670ff3cb46dSSascha Wildner     Result = GetSystemFirmwareTable('ACPI', UIntSignature, ReturnTable, DataSize);
671ff3cb46dSSascha Wildner     if (Result > (LONG) DataSize)
672ff3cb46dSSascha Wildner     {
673ff3cb46dSSascha Wildner         /* Clean up */
674ff3cb46dSSascha Wildner 
675ff3cb46dSSascha Wildner         fprintf (stderr, "Could not read %s data\n", Signature);
676ff3cb46dSSascha Wildner         free (ReturnTable);
677ff3cb46dSSascha Wildner         return (AE_ERROR);
678ff3cb46dSSascha Wildner     }
679ff3cb46dSSascha Wildner 
680ff3cb46dSSascha Wildner     *Table = ReturnTable;
681ff3cb46dSSascha Wildner     return (Status);
682ff3cb46dSSascha Wildner }
683ff3cb46dSSascha Wildner 
684ff3cb46dSSascha Wildner 
6850d02842fSSascha Wildner /* These are here for acpidump only, so we don't need to link oswinxf */
6860d02842fSSascha Wildner 
6870d02842fSSascha Wildner #ifdef ACPI_DUMP_APP
6880d02842fSSascha Wildner /******************************************************************************
6890d02842fSSascha Wildner  *
6900d02842fSSascha Wildner  * FUNCTION:    AcpiOsMapMemory
6910d02842fSSascha Wildner  *
6920d02842fSSascha Wildner  * PARAMETERS:  Where               - Physical address of memory to be mapped
6930d02842fSSascha Wildner  *              Length              - How much memory to map
6940d02842fSSascha Wildner  *
6950d02842fSSascha Wildner  * RETURN:      Pointer to mapped memory. Null on error.
6960d02842fSSascha Wildner  *
6970d02842fSSascha Wildner  * DESCRIPTION: Map physical memory into caller's address space
6980d02842fSSascha Wildner  *
6990d02842fSSascha Wildner  *****************************************************************************/
7000d02842fSSascha Wildner 
7010d02842fSSascha Wildner void *
AcpiOsMapMemory(ACPI_PHYSICAL_ADDRESS Where,ACPI_SIZE Length)7020d02842fSSascha Wildner AcpiOsMapMemory (
7030d02842fSSascha Wildner     ACPI_PHYSICAL_ADDRESS   Where,
7040d02842fSSascha Wildner     ACPI_SIZE               Length)
7050d02842fSSascha Wildner {
7060d02842fSSascha Wildner 
7070d02842fSSascha Wildner     return (ACPI_TO_POINTER ((ACPI_SIZE) Where));
7080d02842fSSascha Wildner }
7090d02842fSSascha Wildner 
7100d02842fSSascha Wildner 
7110d02842fSSascha Wildner /******************************************************************************
7120d02842fSSascha Wildner  *
7130d02842fSSascha Wildner  * FUNCTION:    AcpiOsUnmapMemory
7140d02842fSSascha Wildner  *
7150d02842fSSascha Wildner  * PARAMETERS:  Where               - Logical address of memory to be unmapped
7160d02842fSSascha Wildner  *              Length              - How much memory to unmap
7170d02842fSSascha Wildner  *
7180d02842fSSascha Wildner  * RETURN:      None.
7190d02842fSSascha Wildner  *
7200d02842fSSascha Wildner  * DESCRIPTION: Delete a previously created mapping. Where and Length must
7210d02842fSSascha Wildner  *              correspond to a previous mapping exactly.
7220d02842fSSascha Wildner  *
7230d02842fSSascha Wildner  *****************************************************************************/
7240d02842fSSascha Wildner 
7250d02842fSSascha Wildner void
AcpiOsUnmapMemory(void * Where,ACPI_SIZE Length)7260d02842fSSascha Wildner AcpiOsUnmapMemory (
7270d02842fSSascha Wildner     void                    *Where,
7280d02842fSSascha Wildner     ACPI_SIZE               Length)
7290d02842fSSascha Wildner {
7300d02842fSSascha Wildner 
7310d02842fSSascha Wildner     return;
7320d02842fSSascha Wildner }
7330d02842fSSascha Wildner #endif
734