mirror of
				https://git.proxmox.com/git/mirror_zfs.git
				synced 2025-10-25 09:25:00 +03:00 
			
		
		
		
	kernel_fpu fixes
This patch fixes a few issues when detecting which kernel_fpu functions are available. - Use kernel_fpu_begin() if it's exported on newer kernels. - Use ZFS_LINUX_TRY_COMPILE_SYMBOL() to choose the right kernel_fpu function when using --enable-linux-builtin. Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Signed-off-by: Tony Hutter <hutter2@llnl.gov> Closes #8259 Closes #8363
This commit is contained in:
		
							parent
							
								
									a73e8fdb93
								
							
						
					
					
						commit
						becdcec7b9
					
				| @ -12,25 +12,49 @@ dnl # Pre-4.2:	Use kernel_fpu_{begin,end}() | |||||||
| dnl #		HAVE_KERNEL_FPU & KERNEL_EXPORTS_X86_FPU | dnl #		HAVE_KERNEL_FPU & KERNEL_EXPORTS_X86_FPU | ||||||
| dnl # | dnl # | ||||||
| AC_DEFUN([ZFS_AC_KERNEL_FPU], [ | AC_DEFUN([ZFS_AC_KERNEL_FPU], [ | ||||||
| 	AC_MSG_CHECKING([which kernel_fpu function to use]) | 	AC_MSG_CHECKING([which kernel_fpu header to use]) | ||||||
| 	ZFS_LINUX_TRY_COMPILE([ | 	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]) | ||||||
|  | 		AC_MSG_RESULT(asm/fpu/api.h) | ||||||
|  | 	],[ | ||||||
|  | 		AC_MSG_RESULT(i387.h & xcr.h) | ||||||
|  | 	]) | ||||||
|  | 
 | ||||||
|  | 	AC_MSG_CHECKING([which kernel_fpu function to use]) | ||||||
|  | 	ZFS_LINUX_TRY_COMPILE_SYMBOL([ | ||||||
|  | 		#include <linux/module.h> | ||||||
|  | 		#ifdef HAVE_KERNEL_FPU_API_HEADER | ||||||
|  | 		#include <asm/fpu/api.h> | ||||||
|  | 		#else | ||||||
| 		#include <asm/i387.h> | 		#include <asm/i387.h> | ||||||
| 		#include <asm/xcr.h> | 		#include <asm/xcr.h> | ||||||
|  | 		#endif | ||||||
|  | 		MODULE_LICENSE("$ZFS_META_LICENSE"); | ||||||
| 	],[ | 	],[ | ||||||
| 		kernel_fpu_begin(); | 		kernel_fpu_begin(); | ||||||
| 		kernel_fpu_end(); | 		kernel_fpu_end(); | ||||||
| 	],[ | 	], [kernel_fpu_begin], [arch/x86/kernel/fpu/core.c], [ | ||||||
| 		AC_MSG_RESULT(kernel_fpu_*) | 		AC_MSG_RESULT(kernel_fpu_*) | ||||||
| 		AC_DEFINE(HAVE_KERNEL_FPU, 1, [kernel has kernel_fpu_* functions]) | 		AC_DEFINE(HAVE_KERNEL_FPU, 1, [kernel has kernel_fpu_* functions]) | ||||||
| 		AC_DEFINE(KERNEL_EXPORTS_X86_FPU, 1, [kernel exports FPU functions]) | 		AC_DEFINE(KERNEL_EXPORTS_X86_FPU, 1, [kernel exports FPU functions]) | ||||||
| 	],[ | 	],[ | ||||||
| 		ZFS_LINUX_TRY_COMPILE([ | 		ZFS_LINUX_TRY_COMPILE_SYMBOL([ | ||||||
| 			#include <linux/kernel.h> | 			#include <linux/module.h> | ||||||
|  | 			#ifdef HAVE_KERNEL_FPU_API_HEADER | ||||||
| 			#include <asm/fpu/api.h> | 			#include <asm/fpu/api.h> | ||||||
|  | 			#else | ||||||
|  | 			#include <asm/i387.h> | ||||||
|  | 			#include <asm/xcr.h> | ||||||
|  | 			#endif | ||||||
|  | 			MODULE_LICENSE("$ZFS_META_LICENSE"); | ||||||
| 		],[ | 		],[ | ||||||
| 			__kernel_fpu_begin(); | 			__kernel_fpu_begin(); | ||||||
| 			__kernel_fpu_end(); | 			__kernel_fpu_end(); | ||||||
| 		],[ | 		], [__kernel_fpu_begin], [arch/x86/kernel/fpu/core.c arch/x86/kernel/i387.c], [ | ||||||
| 			AC_MSG_RESULT(__kernel_fpu_*) | 			AC_MSG_RESULT(__kernel_fpu_*) | ||||||
| 			AC_DEFINE(HAVE_UNDERSCORE_KERNEL_FPU, 1, [kernel has __kernel_fpu_* functions]) | 			AC_DEFINE(HAVE_UNDERSCORE_KERNEL_FPU, 1, [kernel has __kernel_fpu_* functions]) | ||||||
| 			AC_DEFINE(KERNEL_EXPORTS_X86_FPU, 1, [kernel exports FPU functions]) | 			AC_DEFINE(KERNEL_EXPORTS_X86_FPU, 1, [kernel exports FPU functions]) | ||||||
|  | |||||||
| @ -81,9 +81,16 @@ | |||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
| #if defined(_KERNEL) | #if defined(_KERNEL) | ||||||
| #if defined(HAVE_UNDERSCORE_KERNEL_FPU) | 
 | ||||||
|  | #if defined(HAVE_KERNEL_FPU_API_HEADER) | ||||||
| #include <asm/fpu/api.h> | #include <asm/fpu/api.h> | ||||||
| #include <asm/fpu/internal.h> | #include <asm/fpu/internal.h> | ||||||
|  | #else | ||||||
|  | #include <asm/i387.h> | ||||||
|  | #include <asm/xcr.h> | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  | #if defined(HAVE_UNDERSCORE_KERNEL_FPU) | ||||||
| #define	kfpu_begin()		\ | #define	kfpu_begin()		\ | ||||||
| {							\ | {							\ | ||||||
| 	preempt_disable();		\ | 	preempt_disable();		\ | ||||||
| @ -95,8 +102,6 @@ | |||||||
| 	preempt_enable();		\ | 	preempt_enable();		\ | ||||||
| } | } | ||||||
| #elif defined(HAVE_KERNEL_FPU) | #elif defined(HAVE_KERNEL_FPU) | ||||||
| #include <asm/i387.h> |  | ||||||
| #include <asm/xcr.h> |  | ||||||
| #define	kfpu_begin()	kernel_fpu_begin() | #define	kfpu_begin()	kernel_fpu_begin() | ||||||
| #define	kfpu_end()		kernel_fpu_end() | #define	kfpu_end()		kernel_fpu_end() | ||||||
| #else | #else | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Tony Hutter
						Tony Hutter