switch reiserfs to usual conventions for caching ACLs
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
diff --git a/fs/reiserfs/super.c b/fs/reiserfs/super.c
index 2969773..b194451 100644
--- a/fs/reiserfs/super.c
+++ b/fs/reiserfs/super.c
@@ -530,8 +530,8 @@
INIT_LIST_HEAD(&ei->i_prealloc_list);
inode_init_once(&ei->vfs_inode);
#ifdef CONFIG_REISERFS_FS_POSIX_ACL
- ei->i_acl_access = NULL;
- ei->i_acl_default = NULL;
+ ei->i_acl_access = ACL_NOT_CACHED;
+ ei->i_acl_default = ACL_NOT_CACHED;
#endif
}
@@ -586,14 +586,14 @@
struct posix_acl *acl;
acl = REISERFS_I(inode)->i_acl_access;
- if (acl && !IS_ERR(acl))
+ if (acl && acl != ACL_NOT_CACHED)
posix_acl_release(acl);
- REISERFS_I(inode)->i_acl_access = NULL;
+ REISERFS_I(inode)->i_acl_access = ACL_NOT_CACHED;
acl = REISERFS_I(inode)->i_acl_default;
- if (acl && !IS_ERR(acl))
+ if (acl && acl != ACL_NOT_CACHED)
posix_acl_release(acl);
- REISERFS_I(inode)->i_acl_default = NULL;
+ REISERFS_I(inode)->i_acl_default = ACL_NOT_CACHED;
}
#else
#define reiserfs_clear_inode NULL
diff --git a/fs/reiserfs/xattr_acl.c b/fs/reiserfs/xattr_acl.c
index a1a7e35..7b3aeb9 100644
--- a/fs/reiserfs/xattr_acl.c
+++ b/fs/reiserfs/xattr_acl.c
@@ -192,19 +192,19 @@
struct posix_acl *acl)
{
spin_lock(&inode->i_lock);
- if (*i_acl != ERR_PTR(-ENODATA))
+ if (*i_acl != ACL_NOT_CACHED)
posix_acl_release(*i_acl);
- *i_acl = acl ? posix_acl_dup(acl) : ERR_PTR(-ENODATA);
+ *i_acl = posix_acl_dup(acl);
spin_unlock(&inode->i_lock);
}
static inline struct posix_acl *iget_acl(struct inode *inode,
struct posix_acl **i_acl)
{
- struct posix_acl *acl = ERR_PTR(-ENODATA);
+ struct posix_acl *acl = ACL_NOT_CACHED;
spin_lock(&inode->i_lock);
- if (*i_acl != ERR_PTR(-ENODATA))
+ if (*i_acl != ACL_NOT_CACHED)
acl = posix_acl_dup(*i_acl);
spin_unlock(&inode->i_lock);
@@ -239,15 +239,13 @@
}
acl = iget_acl(inode, p_acl);
- if (acl && !IS_ERR(acl))
+ if (acl != ACL_NOT_CACHED)
return acl;
- else if (PTR_ERR(acl) == -ENODATA)
- return NULL;
size = reiserfs_xattr_get(inode, name, NULL, 0);
if (size < 0) {
if (size == -ENODATA || size == -ENOSYS) {
- *p_acl = ERR_PTR(-ENODATA);
+ *p_acl = NULL;
return NULL;
}
return ERR_PTR(size);
@@ -262,7 +260,7 @@
/* This shouldn't actually happen as it should have
been caught above.. but just in case */
acl = NULL;
- *p_acl = ERR_PTR(-ENODATA);
+ *p_acl = acl;
} else if (retval < 0) {
acl = ERR_PTR(retval);
} else {
@@ -379,11 +377,8 @@
}
acl = reiserfs_get_acl(dir, ACL_TYPE_DEFAULT);
- if (IS_ERR(acl)) {
- if (PTR_ERR(acl) == -ENODATA)
- goto apply_umask;
+ if (IS_ERR(acl))
return PTR_ERR(acl);
- }
if (acl) {
struct posix_acl *acl_copy;
diff --git a/include/linux/reiserfs_acl.h b/include/linux/reiserfs_acl.h
index 8cc6575..8f4d8d7 100644
--- a/include/linux/reiserfs_acl.h
+++ b/include/linux/reiserfs_acl.h
@@ -58,12 +58,12 @@
static inline void reiserfs_init_acl_access(struct inode *inode)
{
- REISERFS_I(inode)->i_acl_access = NULL;
+ REISERFS_I(inode)->i_acl_access = ACL_NOT_CACHED;
}
static inline void reiserfs_init_acl_default(struct inode *inode)
{
- REISERFS_I(inode)->i_acl_default = NULL;
+ REISERFS_I(inode)->i_acl_default = ACL_NOT_CACHED;
}
#else