mirror of
https://git.proxmox.com/git/mirror_zfs.git
synced 2025-01-15 20:50:30 +03:00
1c4e6a312c
As of the Linux 5.19 kernel the asm/fpu/internal.h header was entirely removed. It has been effectively empty since the 5.16 kernel and provides no required functionality. Reviewed-by: Tony Hutter <hutter2@llnl.gov> Reviewed-by: Attila Fülöp <attila@fueloep.org> Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov> Closes #13529
205 lines
5.2 KiB
Plaintext
205 lines
5.2 KiB
Plaintext
dnl #
|
|
dnl # Handle differences in kernel FPU code.
|
|
dnl #
|
|
dnl # Kernel
|
|
dnl # 5.19: The asm/fpu/internal.h header was removed, it has been
|
|
dnl # effectively empty since the 5.16 kernel.
|
|
dnl #
|
|
dnl # 5.16: XCR code put into asm/fpu/xcr.h
|
|
dnl # HAVE_KERNEL_FPU_XCR_HEADER
|
|
dnl #
|
|
dnl # XSTATE_XSAVE and XSTATE_XRESTORE aren't accessible any more
|
|
dnl # HAVE_KERNEL_FPU_XSAVE_INTERNAL
|
|
dnl #
|
|
dnl # 5.11: kernel_fpu_begin() is an inlined function now, so don't check
|
|
dnl # for it inside the kernel symbols.
|
|
dnl #
|
|
dnl # 5.0: Wrappers have been introduced to save/restore the FPU state.
|
|
dnl # This change was made to the 4.19.38 and 4.14.120 LTS kernels.
|
|
dnl # HAVE_KERNEL_FPU_INTERNAL
|
|
dnl #
|
|
dnl # 4.2: Use __kernel_fpu_{begin,end}()
|
|
dnl # HAVE_UNDERSCORE_KERNEL_FPU & KERNEL_EXPORTS_X86_FPU
|
|
dnl #
|
|
dnl # Pre-4.2: Use kernel_fpu_{begin,end}()
|
|
dnl # HAVE_KERNEL_FPU & KERNEL_EXPORTS_X86_FPU
|
|
dnl #
|
|
dnl # N.B. The header check is performed before all other checks since it
|
|
dnl # depends on HAVE_KERNEL_FPU_API_HEADER being set in confdefs.h.
|
|
dnl #
|
|
AC_DEFUN([ZFS_AC_KERNEL_FPU_HEADER], [
|
|
AC_MSG_CHECKING([whether fpu headers are available])
|
|
ZFS_LINUX_TRY_COMPILE([
|
|
#include <linux/module.h>
|
|
#include <asm/fpu/api.h>
|
|
],[
|
|
],[
|
|
AC_DEFINE(HAVE_KERNEL_FPU_API_HEADER, 1,
|
|
[kernel has asm/fpu/api.h])
|
|
fpu_headers="asm/fpu/api.h"
|
|
|
|
ZFS_LINUX_TRY_COMPILE([
|
|
#include <linux/module.h>
|
|
#include <asm/fpu/xcr.h>
|
|
],[
|
|
],[
|
|
AC_DEFINE(HAVE_KERNEL_FPU_XCR_HEADER, 1,
|
|
[kernel has asm/fpu/xcr.h])
|
|
fpu_headers="$fpu_headers asm/fpu/xcr.h"
|
|
])
|
|
|
|
ZFS_LINUX_TRY_COMPILE([
|
|
#include <linux/module.h>
|
|
#include <asm/fpu/internal.h>
|
|
],[
|
|
],[
|
|
AC_DEFINE(HAVE_KERNEL_FPU_INTERNAL_HEADER, 1,
|
|
[kernel has asm/fpu/internal.h])
|
|
fpu_headers="$fpu_headers asm/fpu/internal.h"
|
|
])
|
|
|
|
AC_MSG_RESULT([$fpu_headers])
|
|
],[
|
|
AC_MSG_RESULT([i387.h & xcr.h])
|
|
])
|
|
])
|
|
|
|
AC_DEFUN([ZFS_AC_KERNEL_SRC_FPU], [
|
|
ZFS_LINUX_TEST_SRC([kernel_fpu], [
|
|
#include <linux/types.h>
|
|
#ifdef HAVE_KERNEL_FPU_API_HEADER
|
|
#include <asm/fpu/api.h>
|
|
#else
|
|
#include <asm/i387.h>
|
|
#include <asm/xcr.h>
|
|
#endif
|
|
], [
|
|
kernel_fpu_begin();
|
|
kernel_fpu_end();
|
|
], [], [ZFS_META_LICENSE])
|
|
|
|
ZFS_LINUX_TEST_SRC([__kernel_fpu], [
|
|
#include <linux/types.h>
|
|
#ifdef HAVE_KERNEL_FPU_API_HEADER
|
|
#include <asm/fpu/api.h>
|
|
#else
|
|
#include <asm/i387.h>
|
|
#include <asm/xcr.h>
|
|
#endif
|
|
], [
|
|
__kernel_fpu_begin();
|
|
__kernel_fpu_end();
|
|
], [], [ZFS_META_LICENSE])
|
|
|
|
ZFS_LINUX_TEST_SRC([fpu_internal], [
|
|
#if defined(__x86_64) || defined(__x86_64__) || \
|
|
defined(__i386) || defined(__i386__)
|
|
#if !defined(__x86)
|
|
#define __x86
|
|
#endif
|
|
#endif
|
|
|
|
#if !defined(__x86)
|
|
#error Unsupported architecture
|
|
#endif
|
|
|
|
#include <linux/types.h>
|
|
#ifdef HAVE_KERNEL_FPU_API_HEADER
|
|
#include <asm/fpu/api.h>
|
|
#ifdef HAVE_KERNEL_FPU_INTERNAL_HEADER
|
|
#include <asm/fpu/internal.h>
|
|
#endif
|
|
#else
|
|
#include <asm/i387.h>
|
|
#include <asm/xcr.h>
|
|
#endif
|
|
|
|
#if !defined(XSTATE_XSAVE)
|
|
#error XSTATE_XSAVE not defined
|
|
#endif
|
|
|
|
#if !defined(XSTATE_XRESTORE)
|
|
#error XSTATE_XRESTORE not defined
|
|
#endif
|
|
],[
|
|
struct fpu *fpu = ¤t->thread.fpu;
|
|
union fpregs_state *st = &fpu->state;
|
|
struct fregs_state *fr __attribute__ ((unused)) = &st->fsave;
|
|
struct fxregs_state *fxr __attribute__ ((unused)) = &st->fxsave;
|
|
struct xregs_state *xr __attribute__ ((unused)) = &st->xsave;
|
|
])
|
|
|
|
ZFS_LINUX_TEST_SRC([fpu_xsave_internal], [
|
|
#include <linux/sched.h>
|
|
#if defined(__x86_64) || defined(__x86_64__) || \
|
|
defined(__i386) || defined(__i386__)
|
|
#if !defined(__x86)
|
|
#define __x86
|
|
#endif
|
|
#endif
|
|
|
|
#if !defined(__x86)
|
|
#error Unsupported architecture
|
|
#endif
|
|
|
|
#include <linux/types.h>
|
|
#ifdef HAVE_KERNEL_FPU_API_HEADER
|
|
#include <asm/fpu/api.h>
|
|
#ifdef HAVE_KERNEL_FPU_INTERNAL_HEADER
|
|
#include <asm/fpu/internal.h>
|
|
#endif
|
|
#else
|
|
#include <asm/i387.h>
|
|
#include <asm/xcr.h>
|
|
#endif
|
|
|
|
],[
|
|
struct fpu *fpu = ¤t->thread.fpu;
|
|
union fpregs_state *st = &fpu->fpstate->regs;
|
|
struct fregs_state *fr __attribute__ ((unused)) = &st->fsave;
|
|
struct fxregs_state *fxr __attribute__ ((unused)) = &st->fxsave;
|
|
struct xregs_state *xr __attribute__ ((unused)) = &st->xsave;
|
|
])
|
|
])
|
|
|
|
AC_DEFUN([ZFS_AC_KERNEL_FPU], [
|
|
dnl #
|
|
dnl # Legacy kernel
|
|
dnl #
|
|
AC_MSG_CHECKING([whether kernel fpu is available])
|
|
ZFS_LINUX_TEST_RESULT([kernel_fpu_license], [
|
|
AC_MSG_RESULT(kernel_fpu_*)
|
|
AC_DEFINE(HAVE_KERNEL_FPU, 1,
|
|
[kernel has kernel_fpu_* functions])
|
|
AC_DEFINE(KERNEL_EXPORTS_X86_FPU, 1,
|
|
[kernel exports FPU functions])
|
|
],[
|
|
dnl #
|
|
dnl # Linux 4.2 kernel
|
|
dnl #
|
|
ZFS_LINUX_TEST_RESULT_SYMBOL([__kernel_fpu_license],
|
|
[__kernel_fpu_begin],
|
|
[arch/x86/kernel/fpu/core.c arch/x86/kernel/i387.c], [
|
|
AC_MSG_RESULT(__kernel_fpu_*)
|
|
AC_DEFINE(HAVE_UNDERSCORE_KERNEL_FPU, 1,
|
|
[kernel has __kernel_fpu_* functions])
|
|
AC_DEFINE(KERNEL_EXPORTS_X86_FPU, 1,
|
|
[kernel exports FPU functions])
|
|
],[
|
|
ZFS_LINUX_TEST_RESULT([fpu_internal], [
|
|
AC_MSG_RESULT(internal)
|
|
AC_DEFINE(HAVE_KERNEL_FPU_INTERNAL, 1,
|
|
[kernel fpu internal])
|
|
],[
|
|
ZFS_LINUX_TEST_RESULT([fpu_xsave_internal], [
|
|
AC_MSG_RESULT(internal with internal XSAVE)
|
|
AC_DEFINE(HAVE_KERNEL_FPU_XSAVE_INTERNAL, 1,
|
|
[kernel fpu and XSAVE internal])
|
|
],[
|
|
AC_MSG_RESULT(unavailable)
|
|
])
|
|
])
|
|
])
|
|
])
|
|
])
|