1 /* SPDX-License-Identifier: BSD-3-Clause OR GPL-2.0 */
2 /******************************************************************************
4 * Name: acenv.h - Host and compiler configuration
6 * Copyright (C) 2000 - 2020, Intel Corp.
8 *****************************************************************************/
14 * Environment configuration. The purpose of this file is to interface ACPICA
15 * to the local environment. This includes compiler-specific, OS-specific,
16 * and machine-specific configuration.
19 /* Types for ACPI_MUTEX_TYPE */
21 #define ACPI_BINARY_SEMAPHORE 0
22 #define ACPI_OSL_MUTEX 1
24 /* Types for DEBUGGER_THREADING */
26 #define DEBUGGER_SINGLE_THREADED 0
27 #define DEBUGGER_MULTI_THREADED 1
29 /******************************************************************************
31 * Configuration for ACPI tools and utilities
33 *****************************************************************************/
35 /* Common application configuration. All single threaded except for acpi_exec. */
37 #if (defined ACPI_ASL_COMPILER) || \
38 (defined ACPI_BIN_APP) || \
39 (defined ACPI_DUMP_APP) || \
40 (defined ACPI_HELP_APP) || \
41 (defined ACPI_NAMES_APP) || \
42 (defined ACPI_SRC_APP) || \
43 (defined ACPI_XTRACT_APP) || \
44 (defined ACPI_EXAMPLE_APP) || \
45 (defined ACPI_EFI_HELLO)
46 #define ACPI_APPLICATION
47 #define ACPI_SINGLE_THREADED
48 #define USE_NATIVE_ALLOCATE_ZEROED
51 /* iASL configuration */
53 #ifdef ACPI_ASL_COMPILER
54 #define ACPI_DEBUG_OUTPUT
55 #define ACPI_CONSTANT_EVAL_ONLY
56 #define ACPI_LARGE_NAMESPACE_NODE
57 #define ACPI_DATA_TABLE_DISASSEMBLY
58 #define ACPI_32BIT_PHYSICAL_ADDRESS
59 #define ACPI_DISASSEMBLER 1
62 /* acpi_exec configuration. Multithreaded with full AML debugger */
65 #define ACPI_APPLICATION
66 #define ACPI_FULL_DEBUG
67 #define ACPI_MUTEX_DEBUG
68 #define ACPI_DBG_TRACK_ALLOCATIONS
71 /* acpi_help configuration. Error messages disabled. */
74 #define ACPI_NO_ERROR_MESSAGES
77 /* acpi_names configuration. Debug output enabled. */
80 #define ACPI_DEBUG_OUTPUT
83 /* acpi_exec/acpi_names/Example configuration. Native RSDP used. */
85 #if (defined ACPI_EXEC_APP) || \
86 (defined ACPI_EXAMPLE_APP) || \
87 (defined ACPI_NAMES_APP)
88 #define ACPI_USE_NATIVE_RSDP_POINTER
91 /* acpi_dump configuration. Native mapping used if provided by the host */
94 #define ACPI_USE_NATIVE_MEMORY_MAPPING
97 /* acpi_names/Example configuration. Hardware disabled */
99 #if (defined ACPI_EXAMPLE_APP) || \
100 (defined ACPI_NAMES_APP)
101 #define ACPI_REDUCED_HARDWARE 1
104 /* Linkable ACPICA library. Two versions, one with full debug. */
107 #define ACPI_USE_LOCAL_CACHE
108 #define ACPI_DEBUGGER 1
109 #define ACPI_DISASSEMBLER 1
112 #define ACPI_DEBUG_OUTPUT
116 /* Common for all ACPICA applications */
118 #ifdef ACPI_APPLICATION
119 #define ACPI_USE_LOCAL_CACHE
122 /* Common debug/disassembler support */
124 #ifdef ACPI_FULL_DEBUG
125 #define ACPI_DEBUG_OUTPUT
126 #define ACPI_DEBUGGER 1
127 #define ACPI_DISASSEMBLER 1
132 * acpisrc CR\LF support
133 * Unix file line endings do not include the carriage return.
134 * If the acpisrc utility is being built using a microsoft compiler, it means
135 * that it will be running on a windows machine which means that the output is
136 * expected to have CR/LF newlines. If the acpisrc utility is built with
137 * anything else, it will likely run on a system with LF newlines. This flag
138 * tells the acpisrc utility that newlines will be in the LF format.
140 #define ACPI_SRC_OS_LF_ONLY 0
142 /*! [Begin] no source code translation */
144 /******************************************************************************
146 * Host configuration files. The compiler configuration files are included
149 *****************************************************************************/
151 #if defined(__GNUC__) && !defined(__INTEL_COMPILER)
152 #include <acpi/platform/acgcc.h>
154 #elif defined(_MSC_VER)
157 #elif defined(__INTEL_COMPILER)
158 #include <acpi/platform/acintel.h>
162 #if defined(_LINUX) || defined(__linux__)
163 #include <acpi/platform/aclinux.h>
165 #elif defined(_APPLE) || defined(__APPLE__)
166 #include "acmacosx.h"
168 #elif defined(__DragonFly__)
169 #include "acdragonfly.h"
171 #elif defined(__FreeBSD__) || defined(__FreeBSD_kernel__)
172 #include "acfreebsd.h"
174 #elif defined(__NetBSD__)
175 #include "acnetbsd.h"
178 #include "acsolaris.h"
180 #elif defined(MODESTO)
181 #include "acmodesto.h"
183 #elif defined(NETWARE)
184 #include "acnetware.h"
186 #elif defined(_CYGWIN)
187 #include "accygwin.h"
195 #elif defined(_WRS_LIB_BUILD)
196 #include "acvxworks.h"
198 #elif defined(__OS2__)
201 #elif defined(__HAIKU__)
204 #elif defined(__QNX__)
208 * EFI applications can be built with -nostdlib, in this case, it must be
209 * included after including all other host environmental definitions, in
210 * order to override the definitions.
212 #elif defined(_AED_EFI) || defined(_GNU_EFI) || defined(_EDK2_EFI)
217 /* Unknown environment */
219 #error Unknown target environment
222 /*! [End] no source code translation !*/
224 /******************************************************************************
226 * Setup defaults for the required symbols that were not defined in one of
227 * the host/compiler files above.
229 *****************************************************************************/
231 /* 64-bit data types */
233 #ifndef COMPILER_DEPENDENT_INT64
234 #define COMPILER_DEPENDENT_INT64 long long
237 #ifndef COMPILER_DEPENDENT_UINT64
238 #define COMPILER_DEPENDENT_UINT64 unsigned long long
241 /* Type of mutex supported by host. Default is binary semaphores. */
242 #ifndef ACPI_MUTEX_TYPE
243 #define ACPI_MUTEX_TYPE ACPI_BINARY_SEMAPHORE
246 /* Global Lock acquire/release */
248 #ifndef ACPI_ACQUIRE_GLOBAL_LOCK
249 #define ACPI_ACQUIRE_GLOBAL_LOCK(Glptr, acquired) acquired = 1
252 #ifndef ACPI_RELEASE_GLOBAL_LOCK
253 #define ACPI_RELEASE_GLOBAL_LOCK(Glptr, pending) pending = 0
256 /* Flush CPU cache - used when going to sleep. Wbinvd or similar. */
258 #ifndef ACPI_FLUSH_CPU_CACHE
259 #define ACPI_FLUSH_CPU_CACHE()
262 /* "inline" keywords - configurable since inline is not standardized */
268 /* Use ordered initialization if compiler doesn't support designated. */
269 #ifndef ACPI_STRUCT_INIT
270 #define ACPI_STRUCT_INIT(field, value) value
274 * Configurable calling conventions:
276 * ACPI_SYSTEM_XFACE - Interfaces to host OS (handlers, threads)
277 * ACPI_EXTERNAL_XFACE - External ACPI interfaces
278 * ACPI_INTERNAL_XFACE - Internal ACPI interfaces
279 * ACPI_INTERNAL_VAR_XFACE - Internal variable-parameter list interfaces
281 #ifndef ACPI_SYSTEM_XFACE
282 #define ACPI_SYSTEM_XFACE
285 #ifndef ACPI_EXTERNAL_XFACE
286 #define ACPI_EXTERNAL_XFACE
289 #ifndef ACPI_INTERNAL_XFACE
290 #define ACPI_INTERNAL_XFACE
293 #ifndef ACPI_INTERNAL_VAR_XFACE
294 #define ACPI_INTERNAL_VAR_XFACE
298 * Debugger threading model
299 * Use single threaded if the entire subsystem is contained in an application
300 * Use multiple threaded when the subsystem is running in the kernel.
302 * By default the model is single threaded if ACPI_APPLICATION is set,
303 * multi-threaded if ACPI_APPLICATION is not set.
305 #ifndef DEBUGGER_THREADING
306 #if !defined (ACPI_APPLICATION) || defined (ACPI_EXEC_APP)
307 #define DEBUGGER_THREADING DEBUGGER_MULTI_THREADED
310 #define DEBUGGER_THREADING DEBUGGER_SINGLE_THREADED
312 #endif /* !DEBUGGER_THREADING */
314 /******************************************************************************
316 * C library configuration
318 *****************************************************************************/
321 * ACPI_USE_SYSTEM_CLIBRARY - Define this if linking to an actual C library.
322 * Otherwise, local versions of string/memory functions will be used.
323 * ACPI_USE_STANDARD_HEADERS - Define this if linking to a C library and
324 * the standard header files may be used. Defining this implies that
325 * ACPI_USE_SYSTEM_CLIBRARY has been defined.
327 * The ACPICA subsystem only uses low level C library functions that do not
328 * call operating system services and may therefore be inlined in the code.
330 * It may be necessary to tailor these include files to the target
331 * generation environment.
334 /* Use the standard C library headers. We want to keep these to a minimum. */
336 #ifdef ACPI_USE_STANDARD_HEADERS
338 /* Use the standard headers from the standard locations */
343 #if defined (ACPI_APPLICATION) || defined(ACPI_LIBRARY)
351 #endif /* ACPI_USE_STANDARD_HEADERS */
353 #ifdef ACPI_APPLICATION
354 #define ACPI_FILE FILE *
355 #define ACPI_FILE_OUT stdout
356 #define ACPI_FILE_ERR stderr
358 #define ACPI_FILE void *
359 #define ACPI_FILE_OUT NULL
360 #define ACPI_FILE_ERR NULL
361 #endif /* ACPI_APPLICATION */
363 #ifndef ACPI_INIT_FUNCTION
364 #define ACPI_INIT_FUNCTION
367 #endif /* __ACENV_H__ */