xref: /linux/include/acpi/platform/acgcc.h (revision 2b64b2ed277ff23e785fbdb65098ee7e1252d64f)
1 /* SPDX-License-Identifier: BSD-3-Clause OR GPL-2.0 */
2 /******************************************************************************
3  *
4  * Name: acgcc.h - GCC specific defines, etc.
5  *
6  * Copyright (C) 2000 - 2019, Intel Corp.
7  *
8  *****************************************************************************/
9 
10 #ifndef __ACGCC_H__
11 #define __ACGCC_H__
12 
13 /*
14  * Use compiler specific <stdarg.h> is a good practice for even when
15  * -nostdinc is specified (i.e., ACPI_USE_STANDARD_HEADERS undefined.
16  */
17 #ifndef va_arg
18 #ifdef ACPI_USE_BUILTIN_STDARG
19 typedef __builtin_va_list va_list;
20 #define va_start(v, l)          __builtin_va_start(v, l)
21 #define va_end(v)               __builtin_va_end(v)
22 #define va_arg(v, l)            __builtin_va_arg(v, l)
23 #define va_copy(d, s)           __builtin_va_copy(d, s)
24 #else
25 #include <stdarg.h>
26 #endif
27 #endif
28 
29 #define ACPI_INLINE             __inline__
30 
31 /* Function name is used for debug output. Non-ANSI, compiler-dependent */
32 
33 #define ACPI_GET_FUNCTION_NAME          __func__
34 
35 /*
36  * This macro is used to tag functions as "printf-like" because
37  * some compilers (like GCC) can catch printf format string problems.
38  */
39 #define ACPI_PRINTF_LIKE(c) __attribute__ ((__format__ (__printf__, c, c+1)))
40 
41 /*
42  * Some compilers complain about unused variables. Sometimes we don't want to
43  * use all the variables (for example, _acpi_module_name). This allows us
44  * to tell the compiler warning in a per-variable manner that a variable
45  * is unused.
46  */
47 #define ACPI_UNUSED_VAR __attribute__ ((unused))
48 
49 /* GCC supports __VA_ARGS__ in macros */
50 
51 #define COMPILER_VA_MACRO               1
52 
53 /* GCC supports native multiply/shift on 32-bit platforms */
54 
55 #define ACPI_USE_NATIVE_MATH64
56 
57 #endif				/* __ACGCC_H__ */
58