mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2026-05-10 22:22:51 -04:00
staging: lustre: llite: allow cached acls
Move the freeing of all cached acls from ll_get_acl() to the function ll_clear_inode(). This way we free all cached acls for the inode just before clearing it. This allow us to take advantage of cached acls and correctly free them before free. Signed-off-by: Dmitry Eremin <dmitry.eremin@intel.com> Reviewed-on: https://review.whamcloud.com/25965 Intel-bug-id: https://jira.hpdd.intel.com/browse/LU-9183 Reviewed-by: Bob Glossman <bob.glossman@intel.com> Reviewed-by: James Simmons <uja.ornl@yahoo.com> Reviewed-by: Oleg Drokin <oleg.drokin@intel.com> Signed-off-by: James Simmons <jsimmons@infradead.org> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
62cbe860c5
commit
24972f1e72
@@ -3035,9 +3035,6 @@ struct posix_acl *ll_get_acl(struct inode *inode, int type)
|
||||
spin_lock(&lli->lli_lock);
|
||||
/* VFS' acl_permission_check->check_acl will release the refcount */
|
||||
acl = posix_acl_dup(lli->lli_posix_acl);
|
||||
#ifdef CONFIG_FS_POSIX_ACL
|
||||
forget_cached_acl(inode, type);
|
||||
#endif
|
||||
spin_unlock(&lli->lli_lock);
|
||||
|
||||
return acl;
|
||||
|
||||
@@ -1316,6 +1316,7 @@ void ll_clear_inode(struct inode *inode)
|
||||
ll_xattr_cache_destroy(inode);
|
||||
|
||||
#ifdef CONFIG_FS_POSIX_ACL
|
||||
forget_all_cached_acls(inode);
|
||||
if (lli->lli_posix_acl) {
|
||||
posix_acl_release(lli->lli_posix_acl);
|
||||
lli->lli_posix_acl = NULL;
|
||||
|
||||
Reference in New Issue
Block a user