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