diff options
| author | Thomas Gleixner <tglx@linutronix.de> | 2011-05-14 12:06:36 +0200 | 
|---|---|---|
| committer | Thomas Gleixner <tglx@linutronix.de> | 2011-05-14 12:06:36 +0200 | 
| commit | a18f22a968de17b29f2310cdb7ba69163e65ec15 (patch) | |
| tree | a7d56d88fad5e444d7661484109758a2f436129e /fs/btrfs/acl.c | |
| parent | a1c57e0fec53defe745e64417eacdbd3618c3e66 (diff) | |
| parent | 798778b8653f64b7b2162ac70eca10367cff6ce8 (diff) | |
Merge branch 'consolidate-clksrc-i8253' of master.kernel.org:~rmk/linux-2.6-arm into timers/clocksource
Conflicts:
	arch/ia64/kernel/cyclone.c
	arch/mips/kernel/i8253.c
	arch/x86/kernel/i8253.c
Reason: Resolve conflicts so further cleanups do not conflict further
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Diffstat (limited to 'fs/btrfs/acl.c')
| -rw-r--r-- | fs/btrfs/acl.c | 11 | 
1 files changed, 6 insertions, 5 deletions
diff --git a/fs/btrfs/acl.c b/fs/btrfs/acl.c index 9c949348510b..5d505aaa72fb 100644 --- a/fs/btrfs/acl.c +++ b/fs/btrfs/acl.c @@ -170,7 +170,7 @@ static int btrfs_xattr_acl_set(struct dentry *dentry, const char *name,  	int ret;  	struct posix_acl *acl = NULL; -	if (!is_owner_or_cap(dentry->d_inode)) +	if (!inode_owner_or_capable(dentry->d_inode))  		return -EPERM;  	if (!IS_POSIXACL(dentry->d_inode)) @@ -178,16 +178,17 @@ static int btrfs_xattr_acl_set(struct dentry *dentry, const char *name,  	if (value) {  		acl = posix_acl_from_xattr(value, size); -		if (acl == NULL) { -			value = NULL; -			size = 0; +		if (acl) { +			ret = posix_acl_valid(acl); +			if (ret) +				goto out;  		} else if (IS_ERR(acl)) {  			return PTR_ERR(acl);  		}  	}  	ret = btrfs_set_acl(NULL, dentry->d_inode, acl, type); - +out:  	posix_acl_release(acl);  	return ret;  | 
