xref: /openbmc/linux/fs/ext4/acl.h (revision 03010a3350301baac2154fa66de925ae2981b7e3)
1ac27a0ecSDave Kleikamp /*
2617ba13bSMingming Cao   File: fs/ext4/acl.h
3ac27a0ecSDave Kleikamp 
4ac27a0ecSDave Kleikamp   (C) 2001 Andreas Gruenbacher, <a.gruenbacher@computer.org>
5ac27a0ecSDave Kleikamp */
6ac27a0ecSDave Kleikamp 
7ac27a0ecSDave Kleikamp #include <linux/posix_acl_xattr.h>
8ac27a0ecSDave Kleikamp 
9617ba13bSMingming Cao #define EXT4_ACL_VERSION	0x0001
10ac27a0ecSDave Kleikamp 
11ac27a0ecSDave Kleikamp typedef struct {
12ac27a0ecSDave Kleikamp 	__le16		e_tag;
13ac27a0ecSDave Kleikamp 	__le16		e_perm;
14ac27a0ecSDave Kleikamp 	__le32		e_id;
15617ba13bSMingming Cao } ext4_acl_entry;
16ac27a0ecSDave Kleikamp 
17ac27a0ecSDave Kleikamp typedef struct {
18ac27a0ecSDave Kleikamp 	__le16		e_tag;
19ac27a0ecSDave Kleikamp 	__le16		e_perm;
20617ba13bSMingming Cao } ext4_acl_entry_short;
21ac27a0ecSDave Kleikamp 
22ac27a0ecSDave Kleikamp typedef struct {
23ac27a0ecSDave Kleikamp 	__le32		a_version;
24617ba13bSMingming Cao } ext4_acl_header;
25ac27a0ecSDave Kleikamp 
26617ba13bSMingming Cao static inline size_t ext4_acl_size(int count)
27ac27a0ecSDave Kleikamp {
28ac27a0ecSDave Kleikamp 	if (count <= 4) {
29617ba13bSMingming Cao 		return sizeof(ext4_acl_header) +
30617ba13bSMingming Cao 		       count * sizeof(ext4_acl_entry_short);
31ac27a0ecSDave Kleikamp 	} else {
32617ba13bSMingming Cao 		return sizeof(ext4_acl_header) +
33617ba13bSMingming Cao 		       4 * sizeof(ext4_acl_entry_short) +
34617ba13bSMingming Cao 		       (count - 4) * sizeof(ext4_acl_entry);
35ac27a0ecSDave Kleikamp 	}
36ac27a0ecSDave Kleikamp }
37ac27a0ecSDave Kleikamp 
38617ba13bSMingming Cao static inline int ext4_acl_count(size_t size)
39ac27a0ecSDave Kleikamp {
40ac27a0ecSDave Kleikamp 	ssize_t s;
41617ba13bSMingming Cao 	size -= sizeof(ext4_acl_header);
42617ba13bSMingming Cao 	s = size - 4 * sizeof(ext4_acl_entry_short);
43ac27a0ecSDave Kleikamp 	if (s < 0) {
44617ba13bSMingming Cao 		if (size % sizeof(ext4_acl_entry_short))
45ac27a0ecSDave Kleikamp 			return -1;
46617ba13bSMingming Cao 		return size / sizeof(ext4_acl_entry_short);
47ac27a0ecSDave Kleikamp 	} else {
48617ba13bSMingming Cao 		if (s % sizeof(ext4_acl_entry))
49ac27a0ecSDave Kleikamp 			return -1;
50617ba13bSMingming Cao 		return s / sizeof(ext4_acl_entry) + 4;
51ac27a0ecSDave Kleikamp 	}
52ac27a0ecSDave Kleikamp }
53ac27a0ecSDave Kleikamp 
54*03010a33STheodore Ts'o #ifdef CONFIG_EXT4_FS_POSIX_ACL
55ac27a0ecSDave Kleikamp 
56617ba13bSMingming Cao /* Value for inode->u.ext4_i.i_acl and inode->u.ext4_i.i_default_acl
57ac27a0ecSDave Kleikamp    if the ACL has not been cached */
58617ba13bSMingming Cao #define EXT4_ACL_NOT_CACHED ((void *)-1)
59ac27a0ecSDave Kleikamp 
60ac27a0ecSDave Kleikamp /* acl.c */
61e6305c43SAl Viro extern int ext4_permission(struct inode *, int);
62617ba13bSMingming Cao extern int ext4_acl_chmod(struct inode *);
63617ba13bSMingming Cao extern int ext4_init_acl(handle_t *, struct inode *, struct inode *);
64ac27a0ecSDave Kleikamp 
65*03010a33STheodore Ts'o #else  /* CONFIG_EXT4_FS_POSIX_ACL */
66ac27a0ecSDave Kleikamp #include <linux/sched.h>
67617ba13bSMingming Cao #define ext4_permission NULL
68ac27a0ecSDave Kleikamp 
69ac27a0ecSDave Kleikamp static inline int
70617ba13bSMingming Cao ext4_acl_chmod(struct inode *inode)
71ac27a0ecSDave Kleikamp {
72ac27a0ecSDave Kleikamp 	return 0;
73ac27a0ecSDave Kleikamp }
74ac27a0ecSDave Kleikamp 
75ac27a0ecSDave Kleikamp static inline int
76617ba13bSMingming Cao ext4_init_acl(handle_t *handle, struct inode *inode, struct inode *dir)
77ac27a0ecSDave Kleikamp {
78ac27a0ecSDave Kleikamp 	return 0;
79ac27a0ecSDave Kleikamp }
80*03010a33STheodore Ts'o #endif  /* CONFIG_EXT4_FS_POSIX_ACL */
81ac27a0ecSDave Kleikamp 
82