mirror of
				https://git.proxmox.com/git/mirror_zfs.git
				synced 2025-10-26 09:54:59 +03:00 
			
		
		
		
	Linux 4.7 compat: handler->get() takes both dentry and inode
Signed-off-by: Chunwei Chen <david.chen@osnexus.com> Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov> Issue #4665
This commit is contained in:
		
							parent
							
								
									278f223668
								
							
						
					
					
						commit
						fd4c7b7a73
					
				| @ -61,6 +61,28 @@ dnl # | |||||||
| dnl # Supported xattr handler get() interfaces checked newest to oldest. | dnl # Supported xattr handler get() interfaces checked newest to oldest. | ||||||
| dnl # | dnl # | ||||||
| AC_DEFUN([ZFS_AC_KERNEL_XATTR_HANDLER_GET], [ | AC_DEFUN([ZFS_AC_KERNEL_XATTR_HANDLER_GET], [ | ||||||
|  | 	dnl # | ||||||
|  | 	dnl # 4.7 API change, | ||||||
|  | 	dnl # The xattr_handler->get() callback was changed to take both | ||||||
|  | 	dnl # dentry and inode. | ||||||
|  | 	dnl # | ||||||
|  | 	AC_MSG_CHECKING([whether xattr_handler->get() wants both dentry and inode]) | ||||||
|  | 	ZFS_LINUX_TRY_COMPILE([ | ||||||
|  | 		#include <linux/xattr.h> | ||||||
|  | 
 | ||||||
|  | 		int get(const struct xattr_handler *handler, | ||||||
|  | 		    struct dentry *dentry, struct inode *inode, | ||||||
|  | 		    const char *name, void *buffer, size_t size) { return 0; } | ||||||
|  | 		static const struct xattr_handler | ||||||
|  | 		    xops __attribute__ ((unused)) = { | ||||||
|  | 			.get = get, | ||||||
|  | 		}; | ||||||
|  | 	],[ | ||||||
|  | 	],[ | ||||||
|  | 		AC_MSG_RESULT(yes) | ||||||
|  | 		AC_DEFINE(HAVE_XATTR_GET_DENTRY_INODE, 1, | ||||||
|  | 		    [xattr_handler->get() wants xattr_handler]) | ||||||
|  | 	],[ | ||||||
| 		dnl # | 		dnl # | ||||||
| 		dnl # 4.4 API change, | 		dnl # 4.4 API change, | ||||||
| 		dnl # The xattr_handler->get() callback was changed to take a | 		dnl # The xattr_handler->get() callback was changed to take a | ||||||
| @ -134,6 +156,7 @@ AC_DEFUN([ZFS_AC_KERNEL_XATTR_HANDLER_GET], [ | |||||||
| 			]) | 			]) | ||||||
| 		]) | 		]) | ||||||
| 	]) | 	]) | ||||||
|  | ]) | ||||||
| 
 | 
 | ||||||
| dnl # | dnl # | ||||||
| dnl # Supported xattr handler set() interfaces checked newest to oldest. | dnl # Supported xattr handler set() interfaces checked newest to oldest. | ||||||
|  | |||||||
| @ -101,13 +101,26 @@ fn(struct inode *ip, char *list, size_t list_size,			\ | |||||||
| } | } | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
|  | /*
 | ||||||
|  |  * 4.7 API change, | ||||||
|  |  * The xattr_handler->get() callback was changed to take a both dentry and | ||||||
|  |  * inode, because the dentry might not be attached to an inode yet. | ||||||
|  |  */ | ||||||
|  | #if defined(HAVE_XATTR_GET_DENTRY_INODE) | ||||||
|  | #define	ZPL_XATTR_GET_WRAPPER(fn)					\ | ||||||
|  | static int								\ | ||||||
|  | fn(const struct xattr_handler *handler, struct dentry *dentry,		\ | ||||||
|  |     struct inode *inode, const char *name, void *buffer, size_t size)	\ | ||||||
|  | {									\ | ||||||
|  | 	return (__ ## fn(inode, name, buffer, size));			\ | ||||||
|  | } | ||||||
| /*
 | /*
 | ||||||
|  * 4.4 API change, |  * 4.4 API change, | ||||||
|  * The xattr_handler->get() callback was changed to take a xattr_handler, |  * The xattr_handler->get() callback was changed to take a xattr_handler, | ||||||
|  * and handler_flags argument was removed and should be accessed by |  * and handler_flags argument was removed and should be accessed by | ||||||
|  * handler->flags. |  * handler->flags. | ||||||
|  */ |  */ | ||||||
| #if defined(HAVE_XATTR_GET_HANDLER) | #elif defined(HAVE_XATTR_GET_HANDLER) | ||||||
| #define	ZPL_XATTR_GET_WRAPPER(fn)					\ | #define	ZPL_XATTR_GET_WRAPPER(fn)					\ | ||||||
| static int								\ | static int								\ | ||||||
| fn(const struct xattr_handler *handler, struct dentry *dentry,		\ | fn(const struct xattr_handler *handler, struct dentry *dentry,		\ | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Chunwei Chen
						Chunwei Chen