diff options
| author | André Fabian Silva Delgado <emulatorman@parabola.nu> | 2016-10-20 00:10:27 -0300 | 
|---|---|---|
| committer | André Fabian Silva Delgado <emulatorman@parabola.nu> | 2016-10-20 00:10:27 -0300 | 
| commit | d0b2f91bede3bd5e3d24dd6803e56eee959c1797 (patch) | |
| tree | 7fee4ab0509879c373c4f2cbd5b8a5be5b4041ee /security/security.c | |
| parent | e914f8eb445e8f74b00303c19c2ffceaedd16a05 (diff) | |
Linux-libre 4.8.2-gnupck-4.8.2-gnu
Diffstat (limited to 'security/security.c')
| -rw-r--r-- | security/security.c | 31 | 
1 files changed, 26 insertions, 5 deletions
| diff --git a/security/security.c b/security/security.c index da7fe2c28..36c741e43 100644 --- a/security/security.c +++ b/security/security.c @@ -356,7 +356,7 @@ void security_inode_free(struct inode *inode)  }  int security_dentry_init_security(struct dentry *dentry, int mode, -					struct qstr *name, void **ctx, +					const struct qstr *name, void **ctx,  					u32 *ctxlen)  {  	return call_int_hook(dentry_init_security, -EOPNOTSUPP, dentry, mode, @@ -708,18 +708,39 @@ int security_inode_killpriv(struct dentry *dentry)  int security_inode_getsecurity(struct inode *inode, const char *name, void **buffer, bool alloc)  { +	struct security_hook_list *hp; +	int rc; +  	if (unlikely(IS_PRIVATE(inode)))  		return -EOPNOTSUPP; -	return call_int_hook(inode_getsecurity, -EOPNOTSUPP, inode, name, -				buffer, alloc); +	/* +	 * Only one module will provide an attribute with a given name. +	 */ +	list_for_each_entry(hp, &security_hook_heads.inode_getsecurity, list) { +		rc = hp->hook.inode_getsecurity(inode, name, buffer, alloc); +		if (rc != -EOPNOTSUPP) +			return rc; +	} +	return -EOPNOTSUPP;  }  int security_inode_setsecurity(struct inode *inode, const char *name, const void *value, size_t size, int flags)  { +	struct security_hook_list *hp; +	int rc; +  	if (unlikely(IS_PRIVATE(inode)))  		return -EOPNOTSUPP; -	return call_int_hook(inode_setsecurity, -EOPNOTSUPP, inode, name, -				value, size, flags); +	/* +	 * Only one module will provide an attribute with a given name. +	 */ +	list_for_each_entry(hp, &security_hook_heads.inode_setsecurity, list) { +		rc = hp->hook.inode_setsecurity(inode, name, value, size, +								flags); +		if (rc != -EOPNOTSUPP) +			return rc; +	} +	return -EOPNOTSUPP;  }  int security_inode_listsecurity(struct inode *inode, char *buffer, size_t buffer_size) | 
