diff options
Diffstat (limited to 'fs/f2fs/acl.c')
| -rw-r--r-- | fs/f2fs/acl.c | 23 | 
1 files changed, 13 insertions, 10 deletions
| diff --git a/fs/f2fs/acl.c b/fs/f2fs/acl.c index 83dcf7bfd7b8..a45d1f4b7b0f 100644 --- a/fs/f2fs/acl.c +++ b/fs/f2fs/acl.c @@ -109,14 +109,16 @@ fail:  	return ERR_PTR(-EINVAL);  } -static void *f2fs_acl_to_disk(const struct posix_acl *acl, size_t *size) +static void *f2fs_acl_to_disk(struct f2fs_sb_info *sbi, +				const struct posix_acl *acl, size_t *size)  {  	struct f2fs_acl_header *f2fs_acl;  	struct f2fs_acl_entry *entry;  	int i; -	f2fs_acl = kmalloc(sizeof(struct f2fs_acl_header) + acl->a_count * -			sizeof(struct f2fs_acl_entry), GFP_NOFS); +	f2fs_acl = f2fs_kmalloc(sbi, sizeof(struct f2fs_acl_header) + +			acl->a_count * sizeof(struct f2fs_acl_entry), +			GFP_NOFS);  	if (!f2fs_acl)  		return ERR_PTR(-ENOMEM); @@ -175,7 +177,7 @@ static struct posix_acl *__f2fs_get_acl(struct inode *inode, int type,  	retval = f2fs_getxattr(inode, name_index, "", NULL, 0, dpage);  	if (retval > 0) { -		value = kmalloc(retval, GFP_F2FS_ZERO); +		value = f2fs_kmalloc(F2FS_I_SB(inode), retval, GFP_F2FS_ZERO);  		if (!value)  			return ERR_PTR(-ENOMEM);  		retval = f2fs_getxattr(inode, name_index, "", value, @@ -204,7 +206,6 @@ struct posix_acl *f2fs_get_acl(struct inode *inode, int type)  static int __f2fs_set_acl(struct inode *inode, int type,  			struct posix_acl *acl, struct page *ipage)  { -	struct f2fs_inode_info *fi = F2FS_I(inode);  	int name_index;  	void *value = NULL;  	size_t size = 0; @@ -213,11 +214,11 @@ static int __f2fs_set_acl(struct inode *inode, int type,  	switch (type) {  	case ACL_TYPE_ACCESS:  		name_index = F2FS_XATTR_INDEX_POSIX_ACL_ACCESS; -		if (acl && !ipage) { +		if (acl) {  			error = posix_acl_update_mode(inode, &inode->i_mode, &acl);  			if (error)  				return error; -			set_acl_inode(fi, inode->i_mode); +			set_acl_inode(inode, inode->i_mode);  		}  		break; @@ -232,9 +233,9 @@ static int __f2fs_set_acl(struct inode *inode, int type,  	}  	if (acl) { -		value = f2fs_acl_to_disk(acl, &size); +		value = f2fs_acl_to_disk(F2FS_I_SB(inode), acl, &size);  		if (IS_ERR(value)) { -			clear_inode_flag(fi, FI_ACL_MODE); +			clear_inode_flag(inode, FI_ACL_MODE);  			return (int)PTR_ERR(value);  		}  	} @@ -245,7 +246,7 @@ static int __f2fs_set_acl(struct inode *inode, int type,  	if (!error)  		set_cached_acl(inode, type, acl); -	clear_inode_flag(fi, FI_ACL_MODE); +	clear_inode_flag(inode, FI_ACL_MODE);  	return error;  } @@ -386,6 +387,8 @@ int f2fs_init_acl(struct inode *inode, struct inode *dir, struct page *ipage,  	if (error)  		return error; +	f2fs_mark_inode_dirty_sync(inode, true); +  	if (default_acl) {  		error = __f2fs_set_acl(inode, ACL_TYPE_DEFAULT, default_acl,  				       ipage); | 
