Commit 15d4b73a authored by Trond Myklebust's avatar Trond Myklebust Committed by Anna Schumaker

NFS: Refactor NFS access to kernel access mask calculation

Signed-off-by: default avatarTrond Myklebust <trond.myklebust@primarydata.com>
Signed-off-by: default avatarAnna Schumaker <Anna.Schumaker@Netapp.com>
parent 3ffbc1d6
...@@ -2375,16 +2375,31 @@ void nfs_access_add_cache(struct inode *inode, struct nfs_access_entry *set) ...@@ -2375,16 +2375,31 @@ void nfs_access_add_cache(struct inode *inode, struct nfs_access_entry *set)
} }
EXPORT_SYMBOL_GPL(nfs_access_add_cache); EXPORT_SYMBOL_GPL(nfs_access_add_cache);
#define NFS_MAY_READ (NFS4_ACCESS_READ)
#define NFS_MAY_WRITE (NFS4_ACCESS_MODIFY | \
NFS4_ACCESS_EXTEND | \
NFS4_ACCESS_DELETE)
#define NFS_MAY_LOOKUP (NFS4_ACCESS_LOOKUP)
#define NFS_MAY_EXECUTE (NFS4_ACCESS_EXECUTE)
static int
nfs_access_calc_mask(u32 access_result)
{
int mask = 0;
if (access_result & NFS_MAY_READ)
mask |= MAY_READ;
if (access_result & NFS_MAY_WRITE)
mask |= MAY_WRITE;
if (access_result & NFS_MAY_LOOKUP)
mask |= MAY_EXEC;
if (access_result & NFS_MAY_EXECUTE)
mask |= MAY_EXEC;
return mask;
}
void nfs_access_set_mask(struct nfs_access_entry *entry, u32 access_result) void nfs_access_set_mask(struct nfs_access_entry *entry, u32 access_result)
{ {
entry->mask = 0; entry->mask = nfs_access_calc_mask(access_result);
if (access_result & NFS4_ACCESS_READ)
entry->mask |= MAY_READ;
if (access_result &
(NFS4_ACCESS_MODIFY | NFS4_ACCESS_EXTEND | NFS4_ACCESS_DELETE))
entry->mask |= MAY_WRITE;
if (access_result & (NFS4_ACCESS_LOOKUP|NFS4_ACCESS_EXECUTE))
entry->mask |= MAY_EXEC;
} }
EXPORT_SYMBOL_GPL(nfs_access_set_mask); EXPORT_SYMBOL_GPL(nfs_access_set_mask);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment