17c478bd9Sstevel@tonic-gate /******************************************************************************
27c478bd9Sstevel@tonic-gate  *
37c478bd9Sstevel@tonic-gate  * Name: acwin.h - OS specific defines, etc.
4*db2bae30SDana Myers  *       $Revision: 1.30 $
57c478bd9Sstevel@tonic-gate  *
67c478bd9Sstevel@tonic-gate  *****************************************************************************/
77c478bd9Sstevel@tonic-gate 
87c478bd9Sstevel@tonic-gate /******************************************************************************
97c478bd9Sstevel@tonic-gate  *
107c478bd9Sstevel@tonic-gate  * 1. Copyright Notice
117c478bd9Sstevel@tonic-gate  *
12*db2bae30SDana Myers  * Some or all of this work - Copyright (c) 1999 - 2008, Intel Corp.
137c478bd9Sstevel@tonic-gate  * All rights reserved.
147c478bd9Sstevel@tonic-gate  *
157c478bd9Sstevel@tonic-gate  * 2. License
167c478bd9Sstevel@tonic-gate  *
177c478bd9Sstevel@tonic-gate  * 2.1. This is your license from Intel Corp. under its intellectual property
187c478bd9Sstevel@tonic-gate  * rights.  You may have additional license terms from the party that provided
197c478bd9Sstevel@tonic-gate  * you this software, covering your right to use that party's intellectual
207c478bd9Sstevel@tonic-gate  * property rights.
217c478bd9Sstevel@tonic-gate  *
227c478bd9Sstevel@tonic-gate  * 2.2. Intel grants, free of charge, to any person ("Licensee") obtaining a
237c478bd9Sstevel@tonic-gate  * copy of the source code appearing in this file ("Covered Code") an
247c478bd9Sstevel@tonic-gate  * irrevocable, perpetual, worldwide license under Intel's copyrights in the
257c478bd9Sstevel@tonic-gate  * base code distributed originally by Intel ("Original Intel Code") to copy,
267c478bd9Sstevel@tonic-gate  * make derivatives, distribute, use and display any portion of the Covered
277c478bd9Sstevel@tonic-gate  * Code in any form, with the right to sublicense such rights; and
287c478bd9Sstevel@tonic-gate  *
297c478bd9Sstevel@tonic-gate  * 2.3. Intel grants Licensee a non-exclusive and non-transferable patent
307c478bd9Sstevel@tonic-gate  * license (with the right to sublicense), under only those claims of Intel
317c478bd9Sstevel@tonic-gate  * patents that are infringed by the Original Intel Code, to make, use, sell,
327c478bd9Sstevel@tonic-gate  * offer to sell, and import the Covered Code and derivative works thereof
337c478bd9Sstevel@tonic-gate  * solely to the minimum extent necessary to exercise the above copyright
347c478bd9Sstevel@tonic-gate  * license, and in no event shall the patent license extend to any additions
357c478bd9Sstevel@tonic-gate  * to or modifications of the Original Intel Code.  No other license or right
367c478bd9Sstevel@tonic-gate  * is granted directly or by implication, estoppel or otherwise;
377c478bd9Sstevel@tonic-gate  *
387c478bd9Sstevel@tonic-gate  * The above copyright and patent license is granted only if the following
397c478bd9Sstevel@tonic-gate  * conditions are met:
407c478bd9Sstevel@tonic-gate  *
417c478bd9Sstevel@tonic-gate  * 3. Conditions
427c478bd9Sstevel@tonic-gate  *
437c478bd9Sstevel@tonic-gate  * 3.1. Redistribution of Source with Rights to Further Distribute Source.
447c478bd9Sstevel@tonic-gate  * Redistribution of source code of any substantial portion of the Covered
457c478bd9Sstevel@tonic-gate  * Code or modification with rights to further distribute source must include
467c478bd9Sstevel@tonic-gate  * the above Copyright Notice, the above License, this list of Conditions,
477c478bd9Sstevel@tonic-gate  * and the following Disclaimer and Export Compliance provision.  In addition,
487c478bd9Sstevel@tonic-gate  * Licensee must cause all Covered Code to which Licensee contributes to
497c478bd9Sstevel@tonic-gate  * contain a file documenting the changes Licensee made to create that Covered
507c478bd9Sstevel@tonic-gate  * Code and the date of any change.  Licensee must include in that file the
517c478bd9Sstevel@tonic-gate  * documentation of any changes made by any predecessor Licensee.  Licensee
527c478bd9Sstevel@tonic-gate  * must include a prominent statement that the modification is derived,
537c478bd9Sstevel@tonic-gate  * directly or indirectly, from Original Intel Code.
547c478bd9Sstevel@tonic-gate  *
557c478bd9Sstevel@tonic-gate  * 3.2. Redistribution of Source with no Rights to Further Distribute Source.
567c478bd9Sstevel@tonic-gate  * Redistribution of source code of any substantial portion of the Covered
577c478bd9Sstevel@tonic-gate  * Code or modification without rights to further distribute source must
587c478bd9Sstevel@tonic-gate  * include the following Disclaimer and Export Compliance provision in the
597c478bd9Sstevel@tonic-gate  * documentation and/or other materials provided with distribution.  In
607c478bd9Sstevel@tonic-gate  * addition, Licensee may not authorize further sublicense of source of any
617c478bd9Sstevel@tonic-gate  * portion of the Covered Code, and must include terms to the effect that the
627c478bd9Sstevel@tonic-gate  * license from Licensee to its licensee is limited to the intellectual
637c478bd9Sstevel@tonic-gate  * property embodied in the software Licensee provides to its licensee, and
647c478bd9Sstevel@tonic-gate  * not to intellectual property embodied in modifications its licensee may
657c478bd9Sstevel@tonic-gate  * make.
667c478bd9Sstevel@tonic-gate  *
677c478bd9Sstevel@tonic-gate  * 3.3. Redistribution of Executable. Redistribution in executable form of any
687c478bd9Sstevel@tonic-gate  * substantial portion of the Covered Code or modification must reproduce the
697c478bd9Sstevel@tonic-gate  * above Copyright Notice, and the following Disclaimer and Export Compliance
707c478bd9Sstevel@tonic-gate  * provision in the documentation and/or other materials provided with the
717c478bd9Sstevel@tonic-gate  * distribution.
727c478bd9Sstevel@tonic-gate  *
737c478bd9Sstevel@tonic-gate  * 3.4. Intel retains all right, title, and interest in and to the Original
747c478bd9Sstevel@tonic-gate  * Intel Code.
757c478bd9Sstevel@tonic-gate  *
767c478bd9Sstevel@tonic-gate  * 3.5. Neither the name Intel nor any other trademark owned or controlled by
777c478bd9Sstevel@tonic-gate  * Intel shall be used in advertising or otherwise to promote the sale, use or
787c478bd9Sstevel@tonic-gate  * other dealings in products derived from or relating to the Covered Code
797c478bd9Sstevel@tonic-gate  * without prior written authorization from Intel.
807c478bd9Sstevel@tonic-gate  *
817c478bd9Sstevel@tonic-gate  * 4. Disclaimer and Export Compliance
827c478bd9Sstevel@tonic-gate  *
837c478bd9Sstevel@tonic-gate  * 4.1. INTEL MAKES NO WARRANTY OF ANY KIND REGARDING ANY SOFTWARE PROVIDED
847c478bd9Sstevel@tonic-gate  * HERE.  ANY SOFTWARE ORIGINATING FROM INTEL OR DERIVED FROM INTEL SOFTWARE
857c478bd9Sstevel@tonic-gate  * IS PROVIDED "AS IS," AND INTEL WILL NOT PROVIDE ANY SUPPORT,  ASSISTANCE,
867c478bd9Sstevel@tonic-gate  * INSTALLATION, TRAINING OR OTHER SERVICES.  INTEL WILL NOT PROVIDE ANY
877c478bd9Sstevel@tonic-gate  * UPDATES, ENHANCEMENTS OR EXTENSIONS.  INTEL SPECIFICALLY DISCLAIMS ANY
887c478bd9Sstevel@tonic-gate  * IMPLIED WARRANTIES OF MERCHANTABILITY, NONINFRINGEMENT AND FITNESS FOR A
897c478bd9Sstevel@tonic-gate  * PARTICULAR PURPOSE.
907c478bd9Sstevel@tonic-gate  *
917c478bd9Sstevel@tonic-gate  * 4.2. IN NO EVENT SHALL INTEL HAVE ANY LIABILITY TO LICENSEE, ITS LICENSEES
927c478bd9Sstevel@tonic-gate  * OR ANY OTHER THIRD PARTY, FOR ANY LOST PROFITS, LOST DATA, LOSS OF USE OR
937c478bd9Sstevel@tonic-gate  * COSTS OF PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES, OR FOR ANY INDIRECT,
947c478bd9Sstevel@tonic-gate  * SPECIAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THIS AGREEMENT, UNDER ANY
957c478bd9Sstevel@tonic-gate  * CAUSE OF ACTION OR THEORY OF LIABILITY, AND IRRESPECTIVE OF WHETHER INTEL
967c478bd9Sstevel@tonic-gate  * HAS ADVANCE NOTICE OF THE POSSIBILITY OF SUCH DAMAGES.  THESE LIMITATIONS
977c478bd9Sstevel@tonic-gate  * SHALL APPLY NOTWITHSTANDING THE FAILURE OF THE ESSENTIAL PURPOSE OF ANY
987c478bd9Sstevel@tonic-gate  * LIMITED REMEDY.
997c478bd9Sstevel@tonic-gate  *
1007c478bd9Sstevel@tonic-gate  * 4.3. Licensee shall not export, either directly or indirectly, any of this
1017c478bd9Sstevel@tonic-gate  * software or system incorporating such software without first obtaining any
1027c478bd9Sstevel@tonic-gate  * required license or other approval from the U. S. Department of Commerce or
1037c478bd9Sstevel@tonic-gate  * any other agency or department of the United States Government.  In the
1047c478bd9Sstevel@tonic-gate  * event Licensee exports any such software from the United States or
1057c478bd9Sstevel@tonic-gate  * re-exports any such software from a foreign destination, Licensee shall
1067c478bd9Sstevel@tonic-gate  * ensure that the distribution and export/re-export of the software is in
1077c478bd9Sstevel@tonic-gate  * compliance with all laws, regulations, orders, or other restrictions of the
1087c478bd9Sstevel@tonic-gate  * U.S. Export Administration Regulations. Licensee agrees that neither it nor
1097c478bd9Sstevel@tonic-gate  * any of its subsidiaries will export/re-export any technical data, process,
1107c478bd9Sstevel@tonic-gate  * software, or service, directly or indirectly, to any country for which the
1117c478bd9Sstevel@tonic-gate  * United States government or any agency thereof requires an export license,
1127c478bd9Sstevel@tonic-gate  * other governmental approval, or letter of assurance, without first obtaining
1137c478bd9Sstevel@tonic-gate  * such license, approval or letter.
1147c478bd9Sstevel@tonic-gate  *
1157c478bd9Sstevel@tonic-gate  *****************************************************************************/
1167c478bd9Sstevel@tonic-gate 
1177c478bd9Sstevel@tonic-gate #ifndef __ACWIN_H__
1187c478bd9Sstevel@tonic-gate #define __ACWIN_H__
1197c478bd9Sstevel@tonic-gate 
1207c478bd9Sstevel@tonic-gate /*! [Begin] no source code translation (Keep the include) */
1217c478bd9Sstevel@tonic-gate 
1227c478bd9Sstevel@tonic-gate /* Windows uses VC */
1237c478bd9Sstevel@tonic-gate #ifdef _MSC_VER
1247c478bd9Sstevel@tonic-gate #include "acmsvc.h"
1257c478bd9Sstevel@tonic-gate #endif
1267c478bd9Sstevel@tonic-gate /*! [End] no source code translation !*/
1277c478bd9Sstevel@tonic-gate 
1287c478bd9Sstevel@tonic-gate #define ACPI_MACHINE_WIDTH      32
1297c478bd9Sstevel@tonic-gate 
1307c478bd9Sstevel@tonic-gate #define isascii                 __isascii
131*db2bae30SDana Myers #define inline                  __inline
1327c478bd9Sstevel@tonic-gate 
1337c478bd9Sstevel@tonic-gate #define ACPI_USE_STANDARD_HEADERS
1347c478bd9Sstevel@tonic-gate 
13530082d0cSmyers #ifdef ACPI_DEFINE_ALTERNATE_TYPES
13630082d0cSmyers /*
13730082d0cSmyers  * Types used only in (Linux) translated source, defined here to enable
13830082d0cSmyers  * cross-platform compilation (i.e., generate the Linux code on Windows,
13930082d0cSmyers  * for test purposes only)
14030082d0cSmyers  */
14130082d0cSmyers typedef int                             s32;
14230082d0cSmyers typedef unsigned char                   u8;
14330082d0cSmyers typedef unsigned short                  u16;
14430082d0cSmyers typedef unsigned int                    u32;
14530082d0cSmyers typedef COMPILER_DEPENDENT_UINT64       u64;
14630082d0cSmyers #endif
14730082d0cSmyers 
14830082d0cSmyers 
1497c478bd9Sstevel@tonic-gate /*
1507c478bd9Sstevel@tonic-gate  * Handle platform- and compiler-specific assembly language differences.
1517c478bd9Sstevel@tonic-gate  *
1527c478bd9Sstevel@tonic-gate  * Notes:
1537c478bd9Sstevel@tonic-gate  * 1) Interrupt 3 is used to break into a debugger
1547c478bd9Sstevel@tonic-gate  * 2) Interrupts are turned off during ACPI register setup
1557c478bd9Sstevel@tonic-gate  */
1567c478bd9Sstevel@tonic-gate 
1577c478bd9Sstevel@tonic-gate /*! [Begin] no source code translation  */
1587c478bd9Sstevel@tonic-gate 
1597c478bd9Sstevel@tonic-gate #define ACPI_ASM_MACROS
1607c478bd9Sstevel@tonic-gate #ifdef ACPI_APPLICATION
1617c478bd9Sstevel@tonic-gate #define BREAKPOINT3
1627c478bd9Sstevel@tonic-gate #define ACPI_DISABLE_IRQS()
1637c478bd9Sstevel@tonic-gate #define ACPI_ENABLE_IRQS()
1647c478bd9Sstevel@tonic-gate #define ACPI_FLUSH_CPU_CACHE()
1657c478bd9Sstevel@tonic-gate #else
1667c478bd9Sstevel@tonic-gate #define BREAKPOINT3             __asm {int 3}
1677c478bd9Sstevel@tonic-gate #define ACPI_DISABLE_IRQS()     __asm {cli}
1687c478bd9Sstevel@tonic-gate #define ACPI_ENABLE_IRQS()      __asm {sti}
1697c478bd9Sstevel@tonic-gate #define ACPI_FLUSH_CPU_CACHE()  __asm {WBINVD}
1707c478bd9Sstevel@tonic-gate #endif
1717c478bd9Sstevel@tonic-gate 
172186507a7Smyers #ifdef _DEBUG
173186507a7Smyers #define ACPI_SIMPLE_RETURN_MACROS
174186507a7Smyers #endif
1757c478bd9Sstevel@tonic-gate 
176*db2bae30SDana Myers /*! [End] no source code translation !*/
177*db2bae30SDana Myers 
1787c478bd9Sstevel@tonic-gate /*
179*db2bae30SDana Myers  * Global Lock acquire/release code
180*db2bae30SDana Myers  *
181*db2bae30SDana Myers  * Note: Handles case where the FACS pointer is null
1827c478bd9Sstevel@tonic-gate  */
183*db2bae30SDana Myers #define ACPI_ACQUIRE_GLOBAL_LOCK(FacsPtr, Acq)  __asm \
184*db2bae30SDana Myers {                                                   \
185*db2bae30SDana Myers         __asm mov           eax, 0xFF               \
186*db2bae30SDana Myers         __asm mov           ecx, FacsPtr            \
187*db2bae30SDana Myers         __asm or            ecx, ecx                \
188*db2bae30SDana Myers         __asm jz            exit_acq                \
189*db2bae30SDana Myers         __asm lea           ecx, [ecx].GlobalLock   \
190*db2bae30SDana Myers                                                     \
1917c478bd9Sstevel@tonic-gate         __asm acq10:                                \
1927c478bd9Sstevel@tonic-gate         __asm mov           eax, [ecx]              \
1937c478bd9Sstevel@tonic-gate         __asm mov           edx, eax                \
1947c478bd9Sstevel@tonic-gate         __asm and           edx, 0xFFFFFFFE         \
1957c478bd9Sstevel@tonic-gate         __asm bts           edx, 1                  \
1967c478bd9Sstevel@tonic-gate         __asm adc           edx, 0                  \
1977c478bd9Sstevel@tonic-gate         __asm lock cmpxchg  dword ptr [ecx], edx    \
1987c478bd9Sstevel@tonic-gate         __asm jnz           acq10                   \
1997c478bd9Sstevel@tonic-gate                                                     \
2007c478bd9Sstevel@tonic-gate         __asm cmp           dl, 3                   \
2017c478bd9Sstevel@tonic-gate         __asm sbb           eax, eax                \
202*db2bae30SDana Myers                                                     \
203*db2bae30SDana Myers         __asm exit_acq:                             \
2047c478bd9Sstevel@tonic-gate         __asm mov           Acq, al                 \
2057c478bd9Sstevel@tonic-gate }
2067c478bd9Sstevel@tonic-gate 
207*db2bae30SDana Myers #define ACPI_RELEASE_GLOBAL_LOCK(FacsPtr, Pnd) __asm \
208*db2bae30SDana Myers {                                                   \
209*db2bae30SDana Myers         __asm xor           eax, eax                \
210*db2bae30SDana Myers         __asm mov           ecx, FacsPtr            \
211*db2bae30SDana Myers         __asm or            ecx, ecx                \
212*db2bae30SDana Myers         __asm jz            exit_rel                \
213*db2bae30SDana Myers         __asm lea           ecx, [ecx].GlobalLock   \
214*db2bae30SDana Myers                                                     \
2157c478bd9Sstevel@tonic-gate         __asm Rel10:                                \
2167c478bd9Sstevel@tonic-gate         __asm mov           eax, [ecx]              \
2177c478bd9Sstevel@tonic-gate         __asm mov           edx, eax                \
2187c478bd9Sstevel@tonic-gate         __asm and           edx, 0xFFFFFFFC         \
2197c478bd9Sstevel@tonic-gate         __asm lock cmpxchg  dword ptr [ecx], edx    \
2207c478bd9Sstevel@tonic-gate         __asm jnz           Rel10                   \
2217c478bd9Sstevel@tonic-gate                                                     \
2227c478bd9Sstevel@tonic-gate         __asm cmp           dl, 3                   \
2237c478bd9Sstevel@tonic-gate         __asm and           eax, 1                  \
224*db2bae30SDana Myers                                                     \
225*db2bae30SDana Myers         __asm exit_rel:                             \
2267c478bd9Sstevel@tonic-gate         __asm mov           Pnd, al                 \
2277c478bd9Sstevel@tonic-gate }
2287c478bd9Sstevel@tonic-gate 
2297c478bd9Sstevel@tonic-gate #endif /* __ACWIN_H__ */
230