1*4882a593Smuzhiyun /* SPDX-License-Identifier: BSD-3-Clause OR GPL-2.0 */ 2*4882a593Smuzhiyun /****************************************************************************** 3*4882a593Smuzhiyun * 4*4882a593Smuzhiyun * Name: aclinux.h - OS specific defines, etc. for Linux 5*4882a593Smuzhiyun * 6*4882a593Smuzhiyun * Copyright (C) 2000 - 2020, Intel Corp. 7*4882a593Smuzhiyun * 8*4882a593Smuzhiyun *****************************************************************************/ 9*4882a593Smuzhiyun 10*4882a593Smuzhiyun #ifndef __ACLINUX_H__ 11*4882a593Smuzhiyun #define __ACLINUX_H__ 12*4882a593Smuzhiyun 13*4882a593Smuzhiyun #ifdef __KERNEL__ 14*4882a593Smuzhiyun 15*4882a593Smuzhiyun /* ACPICA external files should not include ACPICA headers directly. */ 16*4882a593Smuzhiyun 17*4882a593Smuzhiyun #if !defined(BUILDING_ACPICA) && !defined(_LINUX_ACPI_H) 18*4882a593Smuzhiyun #error "Please don't include <acpi/acpi.h> directly, include <linux/acpi.h> instead." 19*4882a593Smuzhiyun #endif 20*4882a593Smuzhiyun 21*4882a593Smuzhiyun #endif 22*4882a593Smuzhiyun 23*4882a593Smuzhiyun /* Common (in-kernel/user-space) ACPICA configuration */ 24*4882a593Smuzhiyun 25*4882a593Smuzhiyun #define ACPI_USE_SYSTEM_CLIBRARY 26*4882a593Smuzhiyun #define ACPI_USE_DO_WHILE_0 27*4882a593Smuzhiyun #define ACPI_IGNORE_PACKAGE_RESOLUTION_ERRORS 28*4882a593Smuzhiyun 29*4882a593Smuzhiyun #ifdef __KERNEL__ 30*4882a593Smuzhiyun 31*4882a593Smuzhiyun #define ACPI_USE_SYSTEM_INTTYPES 32*4882a593Smuzhiyun #define ACPI_USE_GPE_POLLING 33*4882a593Smuzhiyun 34*4882a593Smuzhiyun /* Kernel specific ACPICA configuration */ 35*4882a593Smuzhiyun 36*4882a593Smuzhiyun #ifdef CONFIG_PCI 37*4882a593Smuzhiyun #define ACPI_PCI_CONFIGURED 38*4882a593Smuzhiyun #endif 39*4882a593Smuzhiyun 40*4882a593Smuzhiyun #ifdef CONFIG_ACPI_REDUCED_HARDWARE_ONLY 41*4882a593Smuzhiyun #define ACPI_REDUCED_HARDWARE 1 42*4882a593Smuzhiyun #endif 43*4882a593Smuzhiyun 44*4882a593Smuzhiyun #ifdef CONFIG_ACPI_DEBUGGER 45*4882a593Smuzhiyun #define ACPI_DEBUGGER 46*4882a593Smuzhiyun #endif 47*4882a593Smuzhiyun 48*4882a593Smuzhiyun #ifdef CONFIG_ACPI_DEBUG 49*4882a593Smuzhiyun #define ACPI_MUTEX_DEBUG 50*4882a593Smuzhiyun #endif 51*4882a593Smuzhiyun 52*4882a593Smuzhiyun #include <linux/string.h> 53*4882a593Smuzhiyun #include <linux/kernel.h> 54*4882a593Smuzhiyun #include <linux/ctype.h> 55*4882a593Smuzhiyun #include <linux/sched.h> 56*4882a593Smuzhiyun #include <linux/atomic.h> 57*4882a593Smuzhiyun #include <linux/math64.h> 58*4882a593Smuzhiyun #include <linux/slab.h> 59*4882a593Smuzhiyun #include <linux/spinlock_types.h> 60*4882a593Smuzhiyun #ifdef EXPORT_ACPI_INTERFACES 61*4882a593Smuzhiyun #include <linux/export.h> 62*4882a593Smuzhiyun #endif 63*4882a593Smuzhiyun #ifdef CONFIG_ACPI 64*4882a593Smuzhiyun #include <asm/acenv.h> 65*4882a593Smuzhiyun #endif 66*4882a593Smuzhiyun 67*4882a593Smuzhiyun #define ACPI_INIT_FUNCTION __init 68*4882a593Smuzhiyun 69*4882a593Smuzhiyun /* Use a specific bugging default separate from ACPICA */ 70*4882a593Smuzhiyun 71*4882a593Smuzhiyun #undef ACPI_DEBUG_DEFAULT 72*4882a593Smuzhiyun #define ACPI_DEBUG_DEFAULT (ACPI_LV_INFO | ACPI_LV_REPAIR) 73*4882a593Smuzhiyun 74*4882a593Smuzhiyun #ifndef CONFIG_ACPI 75*4882a593Smuzhiyun 76*4882a593Smuzhiyun /* External globals for __KERNEL__, stubs is needed */ 77*4882a593Smuzhiyun 78*4882a593Smuzhiyun #define ACPI_GLOBAL(t,a) 79*4882a593Smuzhiyun #define ACPI_INIT_GLOBAL(t,a,b) 80*4882a593Smuzhiyun 81*4882a593Smuzhiyun /* Generating stubs for configurable ACPICA macros */ 82*4882a593Smuzhiyun 83*4882a593Smuzhiyun #define ACPI_NO_MEM_ALLOCATIONS 84*4882a593Smuzhiyun 85*4882a593Smuzhiyun /* Generating stubs for configurable ACPICA functions */ 86*4882a593Smuzhiyun 87*4882a593Smuzhiyun #define ACPI_NO_ERROR_MESSAGES 88*4882a593Smuzhiyun #undef ACPI_DEBUG_OUTPUT 89*4882a593Smuzhiyun 90*4882a593Smuzhiyun /* External interface for __KERNEL__, stub is needed */ 91*4882a593Smuzhiyun 92*4882a593Smuzhiyun #define ACPI_EXTERNAL_RETURN_STATUS(prototype) \ 93*4882a593Smuzhiyun static ACPI_INLINE prototype {return(AE_NOT_CONFIGURED);} 94*4882a593Smuzhiyun #define ACPI_EXTERNAL_RETURN_OK(prototype) \ 95*4882a593Smuzhiyun static ACPI_INLINE prototype {return(AE_OK);} 96*4882a593Smuzhiyun #define ACPI_EXTERNAL_RETURN_VOID(prototype) \ 97*4882a593Smuzhiyun static ACPI_INLINE prototype {return;} 98*4882a593Smuzhiyun #define ACPI_EXTERNAL_RETURN_UINT32(prototype) \ 99*4882a593Smuzhiyun static ACPI_INLINE prototype {return(0);} 100*4882a593Smuzhiyun #define ACPI_EXTERNAL_RETURN_PTR(prototype) \ 101*4882a593Smuzhiyun static ACPI_INLINE prototype {return(NULL);} 102*4882a593Smuzhiyun 103*4882a593Smuzhiyun #endif /* CONFIG_ACPI */ 104*4882a593Smuzhiyun 105*4882a593Smuzhiyun /* Host-dependent types and defines for in-kernel ACPICA */ 106*4882a593Smuzhiyun 107*4882a593Smuzhiyun #define ACPI_MACHINE_WIDTH BITS_PER_LONG 108*4882a593Smuzhiyun #define ACPI_USE_NATIVE_MATH64 109*4882a593Smuzhiyun #define ACPI_EXPORT_SYMBOL(symbol) EXPORT_SYMBOL(symbol); 110*4882a593Smuzhiyun #define strtoul simple_strtoul 111*4882a593Smuzhiyun 112*4882a593Smuzhiyun #define acpi_cache_t struct kmem_cache 113*4882a593Smuzhiyun #define acpi_spinlock spinlock_t * 114*4882a593Smuzhiyun #define acpi_raw_spinlock raw_spinlock_t * 115*4882a593Smuzhiyun #define acpi_cpu_flags unsigned long 116*4882a593Smuzhiyun 117*4882a593Smuzhiyun /* Use native linux version of acpi_os_allocate_zeroed */ 118*4882a593Smuzhiyun 119*4882a593Smuzhiyun #define USE_NATIVE_ALLOCATE_ZEROED 120*4882a593Smuzhiyun 121*4882a593Smuzhiyun /* Use logical addresses for accessing GPE registers in system memory */ 122*4882a593Smuzhiyun 123*4882a593Smuzhiyun #define ACPI_GPE_USE_LOGICAL_ADDRESSES 124*4882a593Smuzhiyun 125*4882a593Smuzhiyun /* 126*4882a593Smuzhiyun * Overrides for in-kernel ACPICA 127*4882a593Smuzhiyun */ 128*4882a593Smuzhiyun #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_initialize 129*4882a593Smuzhiyun #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_terminate 130*4882a593Smuzhiyun #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_allocate 131*4882a593Smuzhiyun #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_allocate_zeroed 132*4882a593Smuzhiyun #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_free 133*4882a593Smuzhiyun #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_acquire_object 134*4882a593Smuzhiyun #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_get_thread_id 135*4882a593Smuzhiyun #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_create_lock 136*4882a593Smuzhiyun #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_create_raw_lock 137*4882a593Smuzhiyun #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_delete_raw_lock 138*4882a593Smuzhiyun #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_acquire_raw_lock 139*4882a593Smuzhiyun #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_release_raw_lock 140*4882a593Smuzhiyun 141*4882a593Smuzhiyun /* 142*4882a593Smuzhiyun * OSL interfaces used by debugger/disassembler 143*4882a593Smuzhiyun */ 144*4882a593Smuzhiyun #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_readable 145*4882a593Smuzhiyun #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_writable 146*4882a593Smuzhiyun #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_initialize_debugger 147*4882a593Smuzhiyun #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_terminate_debugger 148*4882a593Smuzhiyun 149*4882a593Smuzhiyun /* 150*4882a593Smuzhiyun * OSL interfaces used by utilities 151*4882a593Smuzhiyun */ 152*4882a593Smuzhiyun #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_redirect_output 153*4882a593Smuzhiyun #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_get_table_by_name 154*4882a593Smuzhiyun #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_get_table_by_index 155*4882a593Smuzhiyun #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_get_table_by_address 156*4882a593Smuzhiyun #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_open_directory 157*4882a593Smuzhiyun #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_get_next_filename 158*4882a593Smuzhiyun #define ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_close_directory 159*4882a593Smuzhiyun 160*4882a593Smuzhiyun #define ACPI_MSG_ERROR KERN_ERR "ACPI Error: " 161*4882a593Smuzhiyun #define ACPI_MSG_EXCEPTION KERN_ERR "ACPI Exception: " 162*4882a593Smuzhiyun #define ACPI_MSG_WARNING KERN_WARNING "ACPI Warning: " 163*4882a593Smuzhiyun #define ACPI_MSG_INFO KERN_INFO "ACPI: " 164*4882a593Smuzhiyun 165*4882a593Smuzhiyun #define ACPI_MSG_BIOS_ERROR KERN_ERR "ACPI BIOS Error (bug): " 166*4882a593Smuzhiyun #define ACPI_MSG_BIOS_WARNING KERN_WARNING "ACPI BIOS Warning (bug): " 167*4882a593Smuzhiyun 168*4882a593Smuzhiyun /* 169*4882a593Smuzhiyun * Linux wants to use designated initializers for function pointer structs. 170*4882a593Smuzhiyun */ 171*4882a593Smuzhiyun #define ACPI_STRUCT_INIT(field, value) .field = value 172*4882a593Smuzhiyun 173*4882a593Smuzhiyun #else /* !__KERNEL__ */ 174*4882a593Smuzhiyun 175*4882a593Smuzhiyun #define ACPI_USE_STANDARD_HEADERS 176*4882a593Smuzhiyun 177*4882a593Smuzhiyun #ifdef ACPI_USE_STANDARD_HEADERS 178*4882a593Smuzhiyun #include <unistd.h> 179*4882a593Smuzhiyun #endif 180*4882a593Smuzhiyun 181*4882a593Smuzhiyun /* Define/disable kernel-specific declarators */ 182*4882a593Smuzhiyun 183*4882a593Smuzhiyun #ifndef __init 184*4882a593Smuzhiyun #define __init 185*4882a593Smuzhiyun #endif 186*4882a593Smuzhiyun #ifndef __iomem 187*4882a593Smuzhiyun #define __iomem 188*4882a593Smuzhiyun #endif 189*4882a593Smuzhiyun 190*4882a593Smuzhiyun /* Host-dependent types and defines for user-space ACPICA */ 191*4882a593Smuzhiyun 192*4882a593Smuzhiyun #define ACPI_FLUSH_CPU_CACHE() 193*4882a593Smuzhiyun #define ACPI_CAST_PTHREAD_T(pthread) ((acpi_thread_id) (pthread)) 194*4882a593Smuzhiyun 195*4882a593Smuzhiyun #if defined(__ia64__) || (defined(__x86_64__) && !defined(__ILP32__)) ||\ 196*4882a593Smuzhiyun defined(__aarch64__) || defined(__PPC64__) ||\ 197*4882a593Smuzhiyun defined(__s390x__) ||\ 198*4882a593Smuzhiyun (defined(__riscv) && (defined(__LP64__) || defined(_LP64))) 199*4882a593Smuzhiyun #define ACPI_MACHINE_WIDTH 64 200*4882a593Smuzhiyun #define COMPILER_DEPENDENT_INT64 long 201*4882a593Smuzhiyun #define COMPILER_DEPENDENT_UINT64 unsigned long 202*4882a593Smuzhiyun #else 203*4882a593Smuzhiyun #define ACPI_MACHINE_WIDTH 32 204*4882a593Smuzhiyun #define COMPILER_DEPENDENT_INT64 long long 205*4882a593Smuzhiyun #define COMPILER_DEPENDENT_UINT64 unsigned long long 206*4882a593Smuzhiyun #define ACPI_USE_NATIVE_DIVIDE 207*4882a593Smuzhiyun #define ACPI_USE_NATIVE_MATH64 208*4882a593Smuzhiyun #endif 209*4882a593Smuzhiyun 210*4882a593Smuzhiyun #ifndef __cdecl 211*4882a593Smuzhiyun #define __cdecl 212*4882a593Smuzhiyun #endif 213*4882a593Smuzhiyun 214*4882a593Smuzhiyun #endif /* __KERNEL__ */ 215*4882a593Smuzhiyun 216*4882a593Smuzhiyun #endif /* __ACLINUX_H__ */ 217