mirror of
				https://git.proxmox.com/git/mirror_zfs.git
				synced 2025-10-25 09:25:00 +03:00 
			
		
		
		
	Remove compat includes from sys/types.h
Don't include the compatibility code in linux/*_compat.h in the public header sys/types.h. This causes problems when an external code base includes the ZFS headers and has its own conflicting compatibility code. Lustre, in particular, defined SHRINK_STOP for compatibility with pre-3.12 kernels in a way that conflicted with the SPL's definition. Because Lustre ZFS OSD includes ZFS headers it fails to build due to a '"SHRINK_STOP" redefined' compiler warning. To avoid such conflicts only include the compat headers from .c files or private headers. Also, for consistency, include sys/*.h before linux/*.h then sort by header name. Signed-off-by: Ned Bass <bass6@llnl.gov> Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov> Closes #411
This commit is contained in:
		
							parent
							
								
									8d9a23e82c
								
							
						
					
					
						commit
						52479ecf58
					
				| @ -25,6 +25,7 @@ | |||||||
| #ifndef _SPL_WAIT_COMPAT_H | #ifndef _SPL_WAIT_COMPAT_H | ||||||
| #define _SPL_WAIT_COMPAT_H | #define _SPL_WAIT_COMPAT_H | ||||||
| 
 | 
 | ||||||
|  | #include <linux/sched.h> | ||||||
| 
 | 
 | ||||||
| #ifndef HAVE_WAIT_ON_BIT_ACTION | #ifndef HAVE_WAIT_ON_BIT_ACTION | ||||||
| #  define spl_wait_on_bit(word, bit, mode) wait_on_bit(word, bit, mode) | #  define spl_wait_on_bit(word, bit, mode) wait_on_bit(word, bit, mode) | ||||||
|  | |||||||
| @ -28,18 +28,6 @@ | |||||||
| #include <linux/types.h> | #include <linux/types.h> | ||||||
| #include <sys/sysmacros.h> | #include <sys/sysmacros.h> | ||||||
| 
 | 
 | ||||||
| #include <linux/file_compat.h> |  | ||||||
| #include <linux/list_compat.h> |  | ||||||
| #include <linux/bitops_compat.h> |  | ||||||
| #include <linux/module_compat.h> |  | ||||||
| #include <linux/proc_compat.h> |  | ||||||
| #include <linux/math64_compat.h> |  | ||||||
| #include <linux/zlib_compat.h> |  | ||||||
| #include <linux/mm_compat.h> |  | ||||||
| #include <linux/delay.h> |  | ||||||
| #include <linux/wait_compat.h> |  | ||||||
| #include <linux/uaccess.h> |  | ||||||
| 
 |  | ||||||
| #ifndef ULLONG_MAX | #ifndef ULLONG_MAX | ||||||
| #define ULLONG_MAX			(~0ULL) | #define ULLONG_MAX			(~0ULL) | ||||||
| #endif | #endif | ||||||
|  | |||||||
| @ -39,6 +39,7 @@ | |||||||
| #include <sys/kstat.h> | #include <sys/kstat.h> | ||||||
| #include <sys/file.h> | #include <sys/file.h> | ||||||
| #include <linux/kmod.h> | #include <linux/kmod.h> | ||||||
|  | #include <linux/math64_compat.h> | ||||||
| #include <linux/proc_compat.h> | #include <linux/proc_compat.h> | ||||||
| 
 | 
 | ||||||
| char spl_version[32] = "SPL v" SPL_META_VERSION "-" SPL_META_RELEASE; | char spl_version[32] = "SPL v" SPL_META_VERSION "-" SPL_META_RELEASE; | ||||||
|  | |||||||
| @ -25,6 +25,8 @@ | |||||||
| \*****************************************************************************/ | \*****************************************************************************/ | ||||||
| 
 | 
 | ||||||
| #include <sys/kmem.h> | #include <sys/kmem.h> | ||||||
|  | #include <linux/mm_compat.h> | ||||||
|  | #include <linux/wait_compat.h> | ||||||
| 
 | 
 | ||||||
| /*
 | /*
 | ||||||
|  * Within the scope of spl-kmem.c file the kmem_cache_* definitions |  * Within the scope of spl-kmem.c file the kmem_cache_* definitions | ||||||
|  | |||||||
| @ -27,6 +27,7 @@ | |||||||
| #include <sys/cred.h> | #include <sys/cred.h> | ||||||
| #include <sys/vnode.h> | #include <sys/vnode.h> | ||||||
| #include <linux/falloc.h> | #include <linux/falloc.h> | ||||||
|  | #include <linux/file_compat.h> | ||||||
| 
 | 
 | ||||||
| vnode_t *rootdir = (vnode_t *)0xabcd1234; | vnode_t *rootdir = (vnode_t *)0xabcd1234; | ||||||
| EXPORT_SYMBOL(rootdir); | EXPORT_SYMBOL(rootdir); | ||||||
|  | |||||||
| @ -55,6 +55,7 @@ | |||||||
| 
 | 
 | ||||||
| #include <sys/kmem.h> | #include <sys/kmem.h> | ||||||
| #include <sys/zmod.h> | #include <sys/zmod.h> | ||||||
|  | #include <linux/zlib_compat.h> | ||||||
| 
 | 
 | ||||||
| static spl_kmem_cache_t *zlib_workspace_cache; | static spl_kmem_cache_t *zlib_workspace_cache; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -27,6 +27,7 @@ | |||||||
| #include <sys/atomic.h> | #include <sys/atomic.h> | ||||||
| #include <sys/thread.h> | #include <sys/thread.h> | ||||||
| #include <sys/mutex.h> | #include <sys/mutex.h> | ||||||
|  | #include <linux/mm_compat.h> | ||||||
| #include <linux/slab.h> | #include <linux/slab.h> | ||||||
| #include "splat-internal.h" | #include "splat-internal.h" | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -43,16 +43,17 @@ | |||||||
|  *  of regression tests or particular tests. |  *  of regression tests or particular tests. | ||||||
| \*****************************************************************************/ | \*****************************************************************************/ | ||||||
| 
 | 
 | ||||||
| #include <linux/module.h> |  | ||||||
| #include <linux/slab.h> |  | ||||||
| #include <linux/vmalloc.h> |  | ||||||
| #include <linux/cdev.h> |  | ||||||
| #include <linux/fs.h> |  | ||||||
| #include <linux/uaccess.h> |  | ||||||
| #include <linux/miscdevice.h> |  | ||||||
| #include <sys/types.h> |  | ||||||
| #include <sys/debug.h> | #include <sys/debug.h> | ||||||
| #include <sys/mutex.h> | #include <sys/mutex.h> | ||||||
|  | #include <sys/types.h> | ||||||
|  | #include <linux/cdev.h> | ||||||
|  | #include <linux/fs.h> | ||||||
|  | #include <linux/miscdevice.h> | ||||||
|  | #include <linux/module.h> | ||||||
|  | #include <linux/module_compat.h> | ||||||
|  | #include <linux/slab.h> | ||||||
|  | #include <linux/uaccess.h> | ||||||
|  | #include <linux/vmalloc.h> | ||||||
| #include "splat-internal.h" | #include "splat-internal.h" | ||||||
| 
 | 
 | ||||||
| static struct list_head splat_module_list; | static struct list_head splat_module_list; | ||||||
|  | |||||||
| @ -25,6 +25,7 @@ | |||||||
| \*****************************************************************************/ | \*****************************************************************************/ | ||||||
| 
 | 
 | ||||||
| #include <sys/sunddi.h> | #include <sys/sunddi.h> | ||||||
|  | #include <linux/math64_compat.h> | ||||||
| #include "splat-internal.h" | #include "splat-internal.h" | ||||||
| 
 | 
 | ||||||
| #define SPLAT_GENERIC_NAME		"generic" | #define SPLAT_GENERIC_NAME		"generic" | ||||||
|  | |||||||
| @ -24,6 +24,7 @@ | |||||||
| \*****************************************************************************/ | \*****************************************************************************/ | ||||||
| 
 | 
 | ||||||
| #include <sys/kmem.h> | #include <sys/kmem.h> | ||||||
|  | #include <linux/mm_compat.h> | ||||||
| #include "splat-internal.h" | #include "splat-internal.h" | ||||||
| 
 | 
 | ||||||
| #define SPLAT_LINUX_NAME		"linux" | #define SPLAT_LINUX_NAME		"linux" | ||||||
|  | |||||||
| @ -26,6 +26,8 @@ | |||||||
| 
 | 
 | ||||||
| #include <sys/mutex.h> | #include <sys/mutex.h> | ||||||
| #include <sys/taskq.h> | #include <sys/taskq.h> | ||||||
|  | #include <linux/delay.h> | ||||||
|  | #include <linux/mm_compat.h> | ||||||
| #include "splat-internal.h" | #include "splat-internal.h" | ||||||
| 
 | 
 | ||||||
| #define SPLAT_MUTEX_NAME                "mutex" | #define SPLAT_MUTEX_NAME                "mutex" | ||||||
|  | |||||||
| @ -24,9 +24,11 @@ | |||||||
|  *  Solaris Porting LAyer Tests (SPLAT) Read/Writer Lock Tests. |  *  Solaris Porting LAyer Tests (SPLAT) Read/Writer Lock Tests. | ||||||
| \*****************************************************************************/ | \*****************************************************************************/ | ||||||
| 
 | 
 | ||||||
|  | #include <sys/random.h> | ||||||
| #include <sys/rwlock.h> | #include <sys/rwlock.h> | ||||||
| #include <sys/taskq.h> | #include <sys/taskq.h> | ||||||
| #include <sys/random.h> | #include <linux/delay.h> | ||||||
|  | #include <linux/mm_compat.h> | ||||||
| #include "splat-internal.h" | #include "splat-internal.h" | ||||||
| 
 | 
 | ||||||
| #define SPLAT_RWLOCK_NAME		"rwlock" | #define SPLAT_RWLOCK_NAME		"rwlock" | ||||||
|  | |||||||
| @ -24,9 +24,10 @@ | |||||||
|  *  Solaris Porting LAyer Tests (SPLAT) Task Queue Tests. |  *  Solaris Porting LAyer Tests (SPLAT) Task Queue Tests. | ||||||
| \*****************************************************************************/ | \*****************************************************************************/ | ||||||
| 
 | 
 | ||||||
| #include <sys/taskq.h> |  | ||||||
| #include <sys/random.h> |  | ||||||
| #include <sys/kmem.h> | #include <sys/kmem.h> | ||||||
|  | #include <sys/random.h> | ||||||
|  | #include <sys/taskq.h> | ||||||
|  | #include <linux/delay.h> | ||||||
| #include "splat-internal.h" | #include "splat-internal.h" | ||||||
| 
 | 
 | ||||||
| #define SPLAT_TASKQ_NAME		"taskq" | #define SPLAT_TASKQ_NAME		"taskq" | ||||||
|  | |||||||
| @ -26,6 +26,8 @@ | |||||||
| 
 | 
 | ||||||
| #include <sys/thread.h> | #include <sys/thread.h> | ||||||
| #include <sys/random.h> | #include <sys/random.h> | ||||||
|  | #include <linux/delay.h> | ||||||
|  | #include <linux/mm_compat.h> | ||||||
| #include <linux/slab.h> | #include <linux/slab.h> | ||||||
| #include "splat-internal.h" | #include "splat-internal.h" | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -25,6 +25,7 @@ | |||||||
| \*****************************************************************************/ | \*****************************************************************************/ | ||||||
| 
 | 
 | ||||||
| #include <sys/time.h> | #include <sys/time.h> | ||||||
|  | #include <linux/mm_compat.h> | ||||||
| #include <linux/slab.h> | #include <linux/slab.h> | ||||||
| #include "splat-internal.h" | #include "splat-internal.h" | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Ned Bass
						Ned Bass