Erik Schmauss | 9585763 | 2018-03-14 16:13:07 -0700 | [diff] [blame] | 1 | /* SPDX-License-Identifier: BSD-3-Clause OR GPL-2.0 */ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 2 | /****************************************************************************** |
| 3 | * |
Bob Moore | e0c437b | 2009-04-22 13:39:47 +0800 | [diff] [blame] | 4 | * Name: aclinux.h - OS specific defines, etc. for Linux |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 5 | * |
Bob Moore | da6f832 | 2018-01-04 10:06:38 -0800 | [diff] [blame] | 6 | * Copyright (C) 2000 - 2018, Intel Corp. |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 7 | * |
Erik Schmauss | 9585763 | 2018-03-14 16:13:07 -0700 | [diff] [blame] | 8 | *****************************************************************************/ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 9 | |
| 10 | #ifndef __ACLINUX_H__ |
| 11 | #define __ACLINUX_H__ |
| 12 | |
Lv Zheng | 417b4a7 | 2014-07-16 16:58:53 +0800 | [diff] [blame] | 13 | #ifdef __KERNEL__ |
| 14 | |
| 15 | /* ACPICA external files should not include ACPICA headers directly. */ |
| 16 | |
| 17 | #if !defined(BUILDING_ACPICA) && !defined(_LINUX_ACPI_H) |
| 18 | #error "Please don't include <acpi/acpi.h> directly, include <linux/acpi.h> instead." |
| 19 | #endif |
| 20 | |
| 21 | #endif |
| 22 | |
Bob Moore | e0c437b | 2009-04-22 13:39:47 +0800 | [diff] [blame] | 23 | /* Common (in-kernel/user-space) ACPICA configuration */ |
| 24 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 25 | #define ACPI_USE_SYSTEM_CLIBRARY |
| 26 | #define ACPI_USE_DO_WHILE_0 |
Bob Moore | 959c38a | 2018-02-15 13:09:31 -0800 | [diff] [blame] | 27 | #define ACPI_IGNORE_PACKAGE_RESOLUTION_ERRORS |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 28 | |
| 29 | #ifdef __KERNEL__ |
| 30 | |
Lv Zheng | e252652 | 2014-02-11 10:51:43 +0800 | [diff] [blame] | 31 | #define ACPI_USE_SYSTEM_INTTYPES |
Erik Schmauss | 87cd826 | 2018-03-14 16:12:59 -0700 | [diff] [blame] | 32 | #define ACPI_USE_GPE_POLLING |
Lv Zheng | e252652 | 2014-02-11 10:51:43 +0800 | [diff] [blame] | 33 | |
Lv Zheng | 4d946f7 | 2015-10-19 10:25:56 +0800 | [diff] [blame] | 34 | /* Kernel specific ACPICA configuration */ |
Al Stone | af1ae78 | 2014-01-17 11:51:30 -0700 | [diff] [blame] | 35 | |
| 36 | #ifdef CONFIG_ACPI_REDUCED_HARDWARE_ONLY |
| 37 | #define ACPI_REDUCED_HARDWARE 1 |
| 38 | #endif |
| 39 | |
Lv Zheng | 4d946f7 | 2015-10-19 10:25:56 +0800 | [diff] [blame] | 40 | #ifdef CONFIG_ACPI_DEBUGGER |
| 41 | #define ACPI_DEBUGGER |
| 42 | #endif |
| 43 | |
Lv Zheng | b4219a8 | 2016-07-05 13:53:04 +0800 | [diff] [blame] | 44 | #ifdef CONFIG_ACPI_DEBUG |
| 45 | #define ACPI_MUTEX_DEBUG |
| 46 | #endif |
| 47 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 48 | #include <linux/string.h> |
| 49 | #include <linux/kernel.h> |
| 50 | #include <linux/ctype.h> |
Alexey Starikovskiy | 8bd108d | 2008-09-25 21:40:30 +0400 | [diff] [blame] | 51 | #include <linux/sched.h> |
Arun Sharma | 60063497 | 2011-07-26 16:09:06 -0700 | [diff] [blame] | 52 | #include <linux/atomic.h> |
Lv Zheng | 9322058 | 2013-10-29 09:30:41 +0800 | [diff] [blame] | 53 | #include <linux/math64.h> |
Robert Moore | 73459f7 | 2005-06-24 00:00:00 -0400 | [diff] [blame] | 54 | #include <linux/slab.h> |
Bob Moore | 967440e3 | 2006-06-23 17:04:00 -0400 | [diff] [blame] | 55 | #include <linux/spinlock_types.h> |
Lv Zheng | 9322058 | 2013-10-29 09:30:41 +0800 | [diff] [blame] | 56 | #ifdef EXPORT_ACPI_INTERFACES |
| 57 | #include <linux/export.h> |
| 58 | #endif |
Lv Zheng | d334c82 | 2014-07-16 16:58:08 +0800 | [diff] [blame] | 59 | #ifdef CONFIG_ACPI |
Lv Zheng | 07d8391 | 2014-05-12 15:46:38 +0800 | [diff] [blame] | 60 | #include <asm/acenv.h> |
Lv Zheng | d334c82 | 2014-07-16 16:58:08 +0800 | [diff] [blame] | 61 | #endif |
Bob Moore | 8313524 | 2006-10-03 00:00:00 -0400 | [diff] [blame] | 62 | |
Lv Zheng | 2368b1a | 2016-08-04 16:43:19 +0800 | [diff] [blame] | 63 | #define ACPI_INIT_FUNCTION __init |
| 64 | |
Lv Zheng | 42873a8 | 2014-04-30 10:05:15 +0800 | [diff] [blame] | 65 | #ifndef CONFIG_ACPI |
| 66 | |
| 67 | /* External globals for __KERNEL__, stubs is needed */ |
| 68 | |
| 69 | #define ACPI_GLOBAL(t,a) |
| 70 | #define ACPI_INIT_GLOBAL(t,a,b) |
| 71 | |
| 72 | /* Generating stubs for configurable ACPICA macros */ |
| 73 | |
| 74 | #define ACPI_NO_MEM_ALLOCATIONS |
| 75 | |
| 76 | /* Generating stubs for configurable ACPICA functions */ |
| 77 | |
| 78 | #define ACPI_NO_ERROR_MESSAGES |
| 79 | #undef ACPI_DEBUG_OUTPUT |
| 80 | |
| 81 | /* External interface for __KERNEL__, stub is needed */ |
| 82 | |
| 83 | #define ACPI_EXTERNAL_RETURN_STATUS(prototype) \ |
| 84 | static ACPI_INLINE prototype {return(AE_NOT_CONFIGURED);} |
| 85 | #define ACPI_EXTERNAL_RETURN_OK(prototype) \ |
| 86 | static ACPI_INLINE prototype {return(AE_OK);} |
| 87 | #define ACPI_EXTERNAL_RETURN_VOID(prototype) \ |
| 88 | static ACPI_INLINE prototype {return;} |
| 89 | #define ACPI_EXTERNAL_RETURN_UINT32(prototype) \ |
| 90 | static ACPI_INLINE prototype {return(0);} |
| 91 | #define ACPI_EXTERNAL_RETURN_PTR(prototype) \ |
| 92 | static ACPI_INLINE prototype {return(NULL);} |
| 93 | |
| 94 | #endif /* CONFIG_ACPI */ |
| 95 | |
Bob Moore | e0c437b | 2009-04-22 13:39:47 +0800 | [diff] [blame] | 96 | /* Host-dependent types and defines for in-kernel ACPICA */ |
Bob Moore | 8313524 | 2006-10-03 00:00:00 -0400 | [diff] [blame] | 97 | |
| 98 | #define ACPI_MACHINE_WIDTH BITS_PER_LONG |
Lv Zheng | 65082bf | 2017-08-03 14:26:50 +0800 | [diff] [blame] | 99 | #define ACPI_USE_NATIVE_MATH64 |
Bob Moore | 8313524 | 2006-10-03 00:00:00 -0400 | [diff] [blame] | 100 | #define ACPI_EXPORT_SYMBOL(symbol) EXPORT_SYMBOL(symbol); |
| 101 | #define strtoul simple_strtoul |
Robert Moore | 73459f7 | 2005-06-24 00:00:00 -0400 | [diff] [blame] | 102 | |
Bob Moore | e0c437b | 2009-04-22 13:39:47 +0800 | [diff] [blame] | 103 | #define acpi_cache_t struct kmem_cache |
| 104 | #define acpi_spinlock spinlock_t * |
| 105 | #define acpi_cpu_flags unsigned long |
Bob Moore | e0c437b | 2009-04-22 13:39:47 +0800 | [diff] [blame] | 106 | |
Lv Zheng | d13bd5a | 2014-05-12 15:46:32 +0800 | [diff] [blame] | 107 | /* Use native linux version of acpi_os_allocate_zeroed */ |
| 108 | |
| 109 | #define USE_NATIVE_ALLOCATE_ZEROED |
| 110 | |
| 111 | /* |
| 112 | * Overrides for in-kernel ACPICA |
| 113 | */ |
| 114 | #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_initialize |
| 115 | #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_terminate |
| 116 | #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_allocate |
| 117 | #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_allocate_zeroed |
| 118 | #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_free |
| 119 | #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_acquire_object |
| 120 | #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_get_thread_id |
| 121 | #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_create_lock |
Lv Zheng | d13bd5a | 2014-05-12 15:46:32 +0800 | [diff] [blame] | 122 | |
| 123 | /* |
| 124 | * OSL interfaces used by debugger/disassembler |
| 125 | */ |
| 126 | #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_readable |
| 127 | #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_writable |
Lv Zheng | 703ecd2 | 2016-12-28 15:28:07 +0800 | [diff] [blame] | 128 | #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_initialize_debugger |
| 129 | #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_terminate_debugger |
Lv Zheng | d13bd5a | 2014-05-12 15:46:32 +0800 | [diff] [blame] | 130 | |
| 131 | /* |
| 132 | * OSL interfaces used by utilities |
| 133 | */ |
| 134 | #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_redirect_output |
Lv Zheng | d13bd5a | 2014-05-12 15:46:32 +0800 | [diff] [blame] | 135 | #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_get_table_by_name |
| 136 | #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_get_table_by_index |
| 137 | #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_get_table_by_address |
| 138 | #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_open_directory |
| 139 | #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_get_next_filename |
| 140 | #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_close_directory |
| 141 | |
Lv Zheng | b5c0875 | 2016-08-04 16:42:49 +0800 | [diff] [blame] | 142 | #define ACPI_MSG_ERROR KERN_ERR "ACPI Error: " |
| 143 | #define ACPI_MSG_EXCEPTION KERN_ERR "ACPI Exception: " |
| 144 | #define ACPI_MSG_WARNING KERN_WARNING "ACPI Warning: " |
| 145 | #define ACPI_MSG_INFO KERN_INFO "ACPI: " |
| 146 | |
| 147 | #define ACPI_MSG_BIOS_ERROR KERN_ERR "ACPI BIOS Error (bug): " |
| 148 | #define ACPI_MSG_BIOS_WARNING KERN_WARNING "ACPI BIOS Warning (bug): " |
| 149 | |
Kees Cook | 99e597a | 2017-07-10 15:23:08 +0800 | [diff] [blame] | 150 | /* |
| 151 | * Linux wants to use designated initializers for function pointer structs. |
| 152 | */ |
Kees Cook | 3d867f6 | 2017-06-27 00:53:07 +0200 | [diff] [blame] | 153 | #define ACPI_STRUCT_INIT(field, value) .field = value |
| 154 | |
Lv Zheng | 839e928 | 2013-10-29 09:29:51 +0800 | [diff] [blame] | 155 | #else /* !__KERNEL__ */ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 156 | |
Lv Zheng | da24f31 | 2016-08-04 16:44:44 +0800 | [diff] [blame] | 157 | #define ACPI_USE_STANDARD_HEADERS |
| 158 | |
| 159 | #ifdef ACPI_USE_STANDARD_HEADERS |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 160 | #include <unistd.h> |
Lv Zheng | da24f31 | 2016-08-04 16:44:44 +0800 | [diff] [blame] | 161 | #endif |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 162 | |
Lv Zheng | a3a80da | 2014-04-04 12:37:59 +0800 | [diff] [blame] | 163 | /* Define/disable kernel-specific declarators */ |
Lv Zheng | 7e66b46 | 2014-02-11 10:51:33 +0800 | [diff] [blame] | 164 | |
| 165 | #ifndef __init |
| 166 | #define __init |
| 167 | #endif |
Lv Zheng | d5a4b1a | 2016-11-16 17:27:34 +0800 | [diff] [blame] | 168 | #ifndef __iomem |
| 169 | #define __iomem |
| 170 | #endif |
Lv Zheng | 7e66b46 | 2014-02-11 10:51:33 +0800 | [diff] [blame] | 171 | |
Bob Moore | e0c437b | 2009-04-22 13:39:47 +0800 | [diff] [blame] | 172 | /* Host-dependent types and defines for user-space ACPICA */ |
| 173 | |
| 174 | #define ACPI_FLUSH_CPU_CACHE() |
Lin Ming | 28eb3fc | 2010-09-15 13:55:13 +0800 | [diff] [blame] | 175 | #define ACPI_CAST_PTHREAD_T(pthread) ((acpi_thread_id) (pthread)) |
Bob Moore | e0c437b | 2009-04-22 13:39:47 +0800 | [diff] [blame] | 176 | |
Anuj Mittal | 0eedae8 | 2018-01-24 15:42:29 -0800 | [diff] [blame] | 177 | #if defined(__ia64__) || (defined(__x86_64__) && !defined(__ILP32__)) ||\ |
Colin Ian King | 2374156 | 2016-12-28 15:28:56 +0800 | [diff] [blame] | 178 | defined(__aarch64__) || defined(__PPC64__) ||\ |
| 179 | defined(__s390x__) |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 180 | #define ACPI_MACHINE_WIDTH 64 |
| 181 | #define COMPILER_DEPENDENT_INT64 long |
| 182 | #define COMPILER_DEPENDENT_UINT64 unsigned long |
| 183 | #else |
| 184 | #define ACPI_MACHINE_WIDTH 32 |
| 185 | #define COMPILER_DEPENDENT_INT64 long long |
| 186 | #define COMPILER_DEPENDENT_UINT64 unsigned long long |
| 187 | #define ACPI_USE_NATIVE_DIVIDE |
Lv Zheng | 65082bf | 2017-08-03 14:26:50 +0800 | [diff] [blame] | 188 | #define ACPI_USE_NATIVE_MATH64 |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 189 | #endif |
| 190 | |
Bob Moore | a0a3f6c | 2007-03-27 20:25:46 -0400 | [diff] [blame] | 191 | #ifndef __cdecl |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 192 | #define __cdecl |
Bob Moore | a0a3f6c | 2007-03-27 20:25:46 -0400 | [diff] [blame] | 193 | #endif |
| 194 | |
Lv Zheng | 839e928 | 2013-10-29 09:29:51 +0800 | [diff] [blame] | 195 | #endif /* __KERNEL__ */ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 196 | |
Lv Zheng | 839e928 | 2013-10-29 09:29:51 +0800 | [diff] [blame] | 197 | #endif /* __ACLINUX_H__ */ |