1f5166768STheodore Ts'o // SPDX-License-Identifier: GPL-2.0
2ac27a0ecSDave Kleikamp /*
3617ba13bSMingming Cao File: fs/ext4/acl.h
4ac27a0ecSDave Kleikamp
5ac27a0ecSDave Kleikamp (C) 2001 Andreas Gruenbacher, <a.gruenbacher@computer.org>
6ac27a0ecSDave Kleikamp */
7ac27a0ecSDave Kleikamp
8ac27a0ecSDave Kleikamp #include <linux/posix_acl_xattr.h>
9ac27a0ecSDave Kleikamp
10617ba13bSMingming Cao #define EXT4_ACL_VERSION 0x0001
11ac27a0ecSDave Kleikamp
12ac27a0ecSDave Kleikamp typedef struct {
13ac27a0ecSDave Kleikamp __le16 e_tag;
14ac27a0ecSDave Kleikamp __le16 e_perm;
15ac27a0ecSDave Kleikamp __le32 e_id;
16617ba13bSMingming Cao } ext4_acl_entry;
17ac27a0ecSDave Kleikamp
18ac27a0ecSDave Kleikamp typedef struct {
19ac27a0ecSDave Kleikamp __le16 e_tag;
20ac27a0ecSDave Kleikamp __le16 e_perm;
21617ba13bSMingming Cao } ext4_acl_entry_short;
22ac27a0ecSDave Kleikamp
23ac27a0ecSDave Kleikamp typedef struct {
24ac27a0ecSDave Kleikamp __le32 a_version;
25617ba13bSMingming Cao } ext4_acl_header;
26ac27a0ecSDave Kleikamp
ext4_acl_size(int count)27617ba13bSMingming Cao static inline size_t ext4_acl_size(int count)
28ac27a0ecSDave Kleikamp {
29ac27a0ecSDave Kleikamp if (count <= 4) {
30617ba13bSMingming Cao return sizeof(ext4_acl_header) +
31617ba13bSMingming Cao count * sizeof(ext4_acl_entry_short);
32ac27a0ecSDave Kleikamp } else {
33617ba13bSMingming Cao return sizeof(ext4_acl_header) +
34617ba13bSMingming Cao 4 * sizeof(ext4_acl_entry_short) +
35617ba13bSMingming Cao (count - 4) * sizeof(ext4_acl_entry);
36ac27a0ecSDave Kleikamp }
37ac27a0ecSDave Kleikamp }
38ac27a0ecSDave Kleikamp
ext4_acl_count(size_t size)39617ba13bSMingming Cao static inline int ext4_acl_count(size_t size)
40ac27a0ecSDave Kleikamp {
41ac27a0ecSDave Kleikamp ssize_t s;
42617ba13bSMingming Cao size -= sizeof(ext4_acl_header);
43617ba13bSMingming Cao s = size - 4 * sizeof(ext4_acl_entry_short);
44ac27a0ecSDave Kleikamp if (s < 0) {
45617ba13bSMingming Cao if (size % sizeof(ext4_acl_entry_short))
46ac27a0ecSDave Kleikamp return -1;
47617ba13bSMingming Cao return size / sizeof(ext4_acl_entry_short);
48ac27a0ecSDave Kleikamp } else {
49617ba13bSMingming Cao if (s % sizeof(ext4_acl_entry))
50ac27a0ecSDave Kleikamp return -1;
51617ba13bSMingming Cao return s / sizeof(ext4_acl_entry) + 4;
52ac27a0ecSDave Kleikamp }
53ac27a0ecSDave Kleikamp }
54ac27a0ecSDave Kleikamp
5503010a33STheodore Ts'o #ifdef CONFIG_EXT4_FS_POSIX_ACL
56ac27a0ecSDave Kleikamp
57ac27a0ecSDave Kleikamp /* acl.c */
580cad6246SMiklos Szeredi struct posix_acl *ext4_get_acl(struct inode *inode, int type, bool rcu);
5913e83a49SChristian Brauner int ext4_set_acl(struct mnt_idmap *idmap, struct dentry *dentry,
60549c7297SChristian Brauner struct posix_acl *acl, int type);
61617ba13bSMingming Cao extern int ext4_init_acl(handle_t *, struct inode *, struct inode *);
62ac27a0ecSDave Kleikamp
6303010a33STheodore Ts'o #else /* CONFIG_EXT4_FS_POSIX_ACL */
64ac27a0ecSDave Kleikamp #include <linux/sched.h>
654e34e719SChristoph Hellwig #define ext4_get_acl NULL
6664e178a7SChristoph Hellwig #define ext4_set_acl NULL
67ac27a0ecSDave Kleikamp
68ac27a0ecSDave Kleikamp static inline int
ext4_init_acl(handle_t * handle,struct inode * inode,struct inode * dir)69617ba13bSMingming Cao ext4_init_acl(handle_t *handle, struct inode *inode, struct inode *dir)
70ac27a0ecSDave Kleikamp {
71*df562e04SMax Kellermann /* usually, the umask is applied by posix_acl_create(), but if
72*df562e04SMax Kellermann ext4 ACL support is disabled at compile time, we need to do
73*df562e04SMax Kellermann it here, because posix_acl_create() will never be called */
74*df562e04SMax Kellermann inode->i_mode &= ~current_umask();
75*df562e04SMax Kellermann
76ac27a0ecSDave Kleikamp return 0;
77ac27a0ecSDave Kleikamp }
7803010a33STheodore Ts'o #endif /* CONFIG_EXT4_FS_POSIX_ACL */
79ac27a0ecSDave Kleikamp
80