2018-03-15 07:13:07 +08:00
|
|
|
/* SPDX-License-Identifier: BSD-3-Clause OR GPL-2.0 */
|
2014-05-12 15:46:32 +08:00
|
|
|
/******************************************************************************
|
|
|
|
*
|
|
|
|
* Name: aclinuxex.h - Extra OS specific defines, etc. for Linux
|
|
|
|
*
|
2019-01-15 01:55:25 +08:00
|
|
|
* Copyright (C) 2000 - 2019, Intel Corp.
|
2014-05-12 15:46:32 +08:00
|
|
|
*
|
2018-03-15 07:13:07 +08:00
|
|
|
*****************************************************************************/
|
2014-05-12 15:46:32 +08:00
|
|
|
|
|
|
|
#ifndef __ACLINUXEX_H__
|
|
|
|
#define __ACLINUXEX_H__
|
|
|
|
|
|
|
|
#ifdef __KERNEL__
|
|
|
|
|
ACPICA: Linux: Add stub implementation of ACPICA 64-bit mathematics.
This patch adds default 64-bit mathematics in aclinux.h using do_div(). As
do_div() can be used for all Linux architectures, this can also be used as
stub macros for ACPICA 64-bit mathematics.
These macros are required by drivers/acpi/utmath.c when ACPI_USE_NATIVE_DIVIDE
is not defined. It is used by ACPICA, so currently this is only meaningful to
CONFIG_ACPI builds. So the kernel will not use these macros unless CONFIG_ACPI
is defined and ACPI_USE_DIVIDE is not defined.
For 64-bit kernels:
In include/acpi/actypes.h, for ACPI_MACHINE_WIDTH=64,
ACPI_USE_NATIVE_DIVIDE will be defined, thus these macros are not used.
In include/acpi/platform/aclinux.h, for __KERNEL__ surrounded code,
ACPI_MACHINE_WIDTH is defined to be BITS_PER_LONG.
So all 64-bit kernels do not use these macros.
For 32-bit kernels:
As mentioned above, these macros will be used when BITS_PER_LONG is 32.
Thus currently the i328 kernels are the only users for these macros.
But they won't use this default implementation provided by this patch,
because in arch/x86/include/asm/acenv.h, there are already overrides
implemented. So these default macros are not used by 32-bit x86 (i386)
kernels.
These macros will only be used by future non x86 32-bit architectures
that try to support ACPI in Linux kernel.
During the period they do not have arch specific implementations of such
macros, we can avoid build errors for them.
And since they can see ACPICA functioning without implementing any arch
specific environment tunings, we can also avoid function errors for
them.
As this implementation is not performance friendly, those architectures
still need to implement real support in the end.
Signed-off-by: Lv Zheng <lv.zheng@intel.com>
[rjw: Changelog]
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
2014-07-16 16:58:00 +08:00
|
|
|
#ifndef ACPI_USE_NATIVE_DIVIDE
|
|
|
|
|
|
|
|
#ifndef ACPI_DIV_64_BY_32
|
|
|
|
#define ACPI_DIV_64_BY_32(n_hi, n_lo, d32, q32, r32) \
|
|
|
|
do { \
|
|
|
|
u64 (__n) = ((u64) n_hi) << 32 | (n_lo); \
|
|
|
|
(r32) = do_div ((__n), (d32)); \
|
|
|
|
(q32) = (u32) (__n); \
|
|
|
|
} while (0)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef ACPI_SHIFT_RIGHT_64
|
|
|
|
#define ACPI_SHIFT_RIGHT_64(n_hi, n_lo) \
|
|
|
|
do { \
|
|
|
|
(n_lo) >>= 1; \
|
|
|
|
(n_lo) |= (((n_hi) & 1) << 31); \
|
|
|
|
(n_hi) >>= 1; \
|
|
|
|
} while (0)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
2014-05-12 15:46:32 +08:00
|
|
|
/*
|
|
|
|
* Overrides for in-kernel ACPICA
|
|
|
|
*/
|
2016-08-04 16:43:19 +08:00
|
|
|
acpi_status ACPI_INIT_FUNCTION acpi_os_initialize(void);
|
2014-05-12 15:46:32 +08:00
|
|
|
|
|
|
|
acpi_status acpi_os_terminate(void);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* The irqs_disabled() check is for resume from RAM.
|
|
|
|
* Interrupts are off during resume, just like they are for boot.
|
|
|
|
* However, boot has (system_state != SYSTEM_RUNNING)
|
|
|
|
* to quiet __might_sleep() in kmalloc() and resume does not.
|
|
|
|
*/
|
|
|
|
static inline void *acpi_os_allocate(acpi_size size)
|
|
|
|
{
|
|
|
|
return kmalloc(size, irqs_disabled()? GFP_ATOMIC : GFP_KERNEL);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void *acpi_os_allocate_zeroed(acpi_size size)
|
|
|
|
{
|
|
|
|
return kzalloc(size, irqs_disabled()? GFP_ATOMIC : GFP_KERNEL);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void acpi_os_free(void *memory)
|
|
|
|
{
|
|
|
|
kfree(memory);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void *acpi_os_acquire_object(acpi_cache_t * cache)
|
|
|
|
{
|
|
|
|
return kmem_cache_zalloc(cache,
|
|
|
|
irqs_disabled()? GFP_ATOMIC : GFP_KERNEL);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline acpi_thread_id acpi_os_get_thread_id(void)
|
|
|
|
{
|
|
|
|
return (acpi_thread_id) (unsigned long)current;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* When lockdep is enabled, the spin_lock_init() macro stringifies it's
|
|
|
|
* argument and uses that as a name for the lock in debugging.
|
|
|
|
* By executing spin_lock_init() in a macro the key changes from "lock" for
|
|
|
|
* all locks to the name of the argument of acpi_os_create_lock(), which
|
|
|
|
* prevents lockdep from reporting false positives for ACPICA locks.
|
|
|
|
*/
|
|
|
|
#define acpi_os_create_lock(__handle) \
|
|
|
|
({ \
|
|
|
|
spinlock_t *lock = ACPI_ALLOCATE(sizeof(*lock)); \
|
|
|
|
if (lock) { \
|
|
|
|
*(__handle) = lock; \
|
|
|
|
spin_lock_init(*(__handle)); \
|
|
|
|
} \
|
|
|
|
lock ? AE_OK : AE_NO_MEMORY; \
|
|
|
|
})
|
|
|
|
|
2018-04-25 22:28:26 +08:00
|
|
|
|
|
|
|
#define acpi_os_create_raw_lock(__handle) \
|
|
|
|
({ \
|
|
|
|
raw_spinlock_t *lock = ACPI_ALLOCATE(sizeof(*lock)); \
|
|
|
|
if (lock) { \
|
|
|
|
*(__handle) = lock; \
|
|
|
|
raw_spin_lock_init(*(__handle)); \
|
|
|
|
} \
|
|
|
|
lock ? AE_OK : AE_NO_MEMORY; \
|
|
|
|
})
|
|
|
|
|
|
|
|
static inline acpi_cpu_flags acpi_os_acquire_raw_lock(acpi_raw_spinlock lockp)
|
|
|
|
{
|
|
|
|
acpi_cpu_flags flags;
|
|
|
|
|
|
|
|
raw_spin_lock_irqsave(lockp, flags);
|
|
|
|
return flags;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void acpi_os_release_raw_lock(acpi_raw_spinlock lockp,
|
|
|
|
acpi_cpu_flags flags)
|
|
|
|
{
|
|
|
|
raw_spin_unlock_irqrestore(lockp, flags);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void acpi_os_delete_raw_lock(acpi_raw_spinlock handle)
|
|
|
|
{
|
|
|
|
ACPI_FREE(handle);
|
|
|
|
}
|
|
|
|
|
2015-10-19 10:25:56 +08:00
|
|
|
static inline u8 acpi_os_readable(void *pointer, acpi_size length)
|
|
|
|
{
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
2016-12-28 15:28:07 +08:00
|
|
|
static inline acpi_status acpi_os_initialize_debugger(void)
|
2015-12-03 10:42:46 +08:00
|
|
|
{
|
|
|
|
return AE_OK;
|
|
|
|
}
|
|
|
|
|
2016-12-28 15:28:07 +08:00
|
|
|
static inline void acpi_os_terminate_debugger(void)
|
2015-12-03 10:42:46 +08:00
|
|
|
{
|
2015-12-29 13:52:32 +08:00
|
|
|
return;
|
2015-12-03 10:42:46 +08:00
|
|
|
}
|
|
|
|
|
2014-05-12 15:46:32 +08:00
|
|
|
/*
|
|
|
|
* OSL interfaces added by Linux
|
|
|
|
*/
|
|
|
|
|
|
|
|
#endif /* __KERNEL__ */
|
|
|
|
|
|
|
|
#endif /* __ACLINUXEX_H__ */
|