blob: 103d4469532340b5cf0351c5fd67bc610b943f68 [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001/* SPDX-License-Identifier: GPL-2.0 */
Andreas Gruenbachera257cdd2005-06-22 17:16:26 +00002/*
3 * File: linux/nfsacl.h
4 *
5 * (C) 2003 Andreas Gruenbacher <agruen@suse.de>
6 */
7#ifndef __LINUX_NFSACL_H
8#define __LINUX_NFSACL_H
9
Andreas Gruenbachera257cdd2005-06-22 17:16:26 +000010
11#include <linux/posix_acl.h>
Boaz Harroshd7031582009-12-03 20:28:47 +020012#include <linux/sunrpc/xdr.h>
David Howells607ca462012-10-13 10:46:48 +010013#include <uapi/linux/nfsacl.h>
Andreas Gruenbachera257cdd2005-06-22 17:16:26 +000014
15/* Maximum number of ACL entries over NFS */
16#define NFS_ACL_MAX_ENTRIES 1024
17
18#define NFSACL_MAXWORDS (2*(2+3*NFS_ACL_MAX_ENTRIES))
19#define NFSACL_MAXPAGES ((2*(8+12*NFS_ACL_MAX_ENTRIES) + PAGE_SIZE-1) \
20 >> PAGE_SHIFT)
21
Trond Myklebustae46141f2009-03-10 20:33:18 -040022#define NFS_ACL_MAX_ENTRIES_INLINE (5)
23#define NFS_ACL_INLINE_BUFSIZE ((2*(2+3*NFS_ACL_MAX_ENTRIES_INLINE)) << 2)
24
Andreas Gruenbachera257cdd2005-06-22 17:16:26 +000025static inline unsigned int
26nfsacl_size(struct posix_acl *acl_access, struct posix_acl *acl_default)
27{
28 unsigned int w = 16;
29 w += max(acl_access ? (int)acl_access->a_count : 3, 4) * 12;
30 if (acl_default)
31 w += max((int)acl_default->a_count, 4) * 12;
32 return w;
33}
34
Chuck Lever731f3f42011-01-21 03:05:28 +000035extern int
Andreas Gruenbachera257cdd2005-06-22 17:16:26 +000036nfsacl_encode(struct xdr_buf *buf, unsigned int base, struct inode *inode,
37 struct posix_acl *acl, int encode_entries, int typeflag);
Chuck Lever731f3f42011-01-21 03:05:28 +000038extern int
Andreas Gruenbachera257cdd2005-06-22 17:16:26 +000039nfsacl_decode(struct xdr_buf *buf, unsigned int base, unsigned int *aclcnt,
40 struct posix_acl **pacl);
41
Andreas Gruenbachera257cdd2005-06-22 17:16:26 +000042#endif /* __LINUX_NFSACL_H */