diff options
author | Brian Behlendorf <[email protected]> | 2012-01-12 13:59:44 -0800 |
---|---|---|
committer | Brian Behlendorf <[email protected]> | 2012-01-12 15:06:39 -0800 |
commit | 166dd49de0272e6f179e5fd6a41eebb4880a1154 (patch) | |
tree | 6edeade75ae3a8613b4cdfd2fef9b358041638d2 /module | |
parent | 2932b6a8004df8417036894d7d2e7e151cc95434 (diff) |
Linux 3.2 compat, security_inode_init_security()
The security_inode_init_security() API has been changed to include
a filesystem specific callback to write security extended attributes.
This was done to support the initialization of multiple LSM xattrs
and the EVM xattr.
This change updates the code to use the new API when it's available.
Otherwise it falls back to the previous implementation.
In addition, the ZFS_AC_KERNEL_6ARGS_SECURITY_INODE_INIT_SECURITY
autoconf test has been made more rigerous by passing the expected
types. This is done to ensure we always properly the detect the
correct form for the security_inode_init_security() API.
Signed-off-by: Brian Behlendorf <[email protected]>
Closes #516
Diffstat (limited to 'module')
-rw-r--r-- | module/zfs/zpl_xattr.c | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/module/zfs/zpl_xattr.c b/module/zfs/zpl_xattr.c index 9117b7bc1..51c81ed0c 100644 --- a/module/zfs/zpl_xattr.c +++ b/module/zfs/zpl_xattr.c @@ -606,6 +606,34 @@ __zpl_xattr_security_set(struct inode *ip, const char *name, } ZPL_XATTR_SET_WRAPPER(zpl_xattr_security_set); +#ifdef HAVE_CALLBACK_SECURITY_INODE_INIT_SECURITY +static int +__zpl_xattr_security_init(struct inode *ip, const struct xattr *xattrs, + void *fs_info) +{ + const struct xattr *xattr; + int error = 0; + + for (xattr = xattrs; xattr->name != NULL; xattr++) { + error = __zpl_xattr_security_set(ip, + xattr->name, xattr->value, xattr->value_len, 0); + + if (error < 0) + break; + } + + return (error); +} + +int +zpl_xattr_security_init(struct inode *ip, struct inode *dip, + const struct qstr *qstr) +{ + return security_inode_init_security(ip, dip, qstr, + &__zpl_xattr_security_init, NULL); +} + +#else int zpl_xattr_security_init(struct inode *ip, struct inode *dip, const struct qstr *qstr) @@ -631,6 +659,7 @@ zpl_xattr_security_init(struct inode *ip, struct inode *dip, return (error); } +#endif /* HAVE_CALLBACK_SECURITY_INODE_INIT_SECURITY */ xattr_handler_t zpl_xattr_security_handler = { .prefix = XATTR_SECURITY_PREFIX, |