blob: 8cc65757e47adfc476ed4b2ca2c1d020c06ab6bf [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#include <linux/init.h>
2#include <linux/posix_acl.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -07003
4#define REISERFS_ACL_VERSION 0x0001
5
6typedef struct {
Linus Torvaldsbd4c6252005-07-12 20:21:28 -07007 __le16 e_tag;
8 __le16 e_perm;
9 __le32 e_id;
Linus Torvalds1da177e2005-04-16 15:20:36 -070010} reiserfs_acl_entry;
11
12typedef struct {
Linus Torvaldsbd4c6252005-07-12 20:21:28 -070013 __le16 e_tag;
14 __le16 e_perm;
Linus Torvalds1da177e2005-04-16 15:20:36 -070015} reiserfs_acl_entry_short;
16
17typedef struct {
Linus Torvaldsbd4c6252005-07-12 20:21:28 -070018 __le32 a_version;
Linus Torvalds1da177e2005-04-16 15:20:36 -070019} reiserfs_acl_header;
20
21static inline size_t reiserfs_acl_size(int count)
22{
23 if (count <= 4) {
24 return sizeof(reiserfs_acl_header) +
Linus Torvaldsbd4c6252005-07-12 20:21:28 -070025 count * sizeof(reiserfs_acl_entry_short);
Linus Torvalds1da177e2005-04-16 15:20:36 -070026 } else {
27 return sizeof(reiserfs_acl_header) +
Linus Torvaldsbd4c6252005-07-12 20:21:28 -070028 4 * sizeof(reiserfs_acl_entry_short) +
29 (count - 4) * sizeof(reiserfs_acl_entry);
Linus Torvalds1da177e2005-04-16 15:20:36 -070030 }
31}
32
33static inline int reiserfs_acl_count(size_t size)
34{
35 ssize_t s;
36 size -= sizeof(reiserfs_acl_header);
37 s = size - 4 * sizeof(reiserfs_acl_entry_short);
38 if (s < 0) {
39 if (size % sizeof(reiserfs_acl_entry_short))
40 return -1;
41 return size / sizeof(reiserfs_acl_entry_short);
42 } else {
43 if (s % sizeof(reiserfs_acl_entry))
44 return -1;
45 return s / sizeof(reiserfs_acl_entry) + 4;
46 }
47}
48
Linus Torvalds1da177e2005-04-16 15:20:36 -070049#ifdef CONFIG_REISERFS_FS_POSIX_ACL
Linus Torvaldsbd4c6252005-07-12 20:21:28 -070050struct posix_acl *reiserfs_get_acl(struct inode *inode, int type);
51int reiserfs_acl_chmod(struct inode *inode);
Jeff Mahoney0ab26212009-03-30 14:02:39 -040052int reiserfs_inherit_default_acl(struct reiserfs_transaction_handle *th,
53 struct inode *dir, struct dentry *dentry,
Linus Torvaldsbd4c6252005-07-12 20:21:28 -070054 struct inode *inode);
55int reiserfs_cache_default_acl(struct inode *dir);
Jeff Mahoney48b32a32009-03-30 14:02:38 -040056extern struct xattr_handler reiserfs_posix_acl_default_handler;
57extern struct xattr_handler reiserfs_posix_acl_access_handler;
Alexey Dobriyancfe14672006-09-29 02:00:00 -070058
59static inline void reiserfs_init_acl_access(struct inode *inode)
60{
61 REISERFS_I(inode)->i_acl_access = NULL;
62}
63
64static inline void reiserfs_init_acl_default(struct inode *inode)
65{
66 REISERFS_I(inode)->i_acl_default = NULL;
67}
Linus Torvalds1da177e2005-04-16 15:20:36 -070068#else
69
Linus Torvalds1da177e2005-04-16 15:20:36 -070070#define reiserfs_cache_default_acl(inode) 0
71
Andrew Mortonbc5e4832006-02-04 23:27:51 -080072static inline struct posix_acl *reiserfs_get_acl(struct inode *inode, int type)
73{
74 return NULL;
75}
76
Linus Torvaldsbd4c6252005-07-12 20:21:28 -070077static inline int reiserfs_acl_chmod(struct inode *inode)
78{
79 return 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -070080}
81
82static inline int
Alexander Beregalov77e46582009-03-31 00:32:40 +040083reiserfs_inherit_default_acl(struct reiserfs_transaction_handle *th,
84 const struct inode *dir, struct dentry *dentry,
Linus Torvaldsbd4c6252005-07-12 20:21:28 -070085 struct inode *inode)
Linus Torvalds1da177e2005-04-16 15:20:36 -070086{
Linus Torvaldsbd4c6252005-07-12 20:21:28 -070087 return 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -070088}
89
Alexey Dobriyancfe14672006-09-29 02:00:00 -070090static inline void reiserfs_init_acl_access(struct inode *inode)
91{
92}
93
94static inline void reiserfs_init_acl_default(struct inode *inode)
95{
96}
Linus Torvalds1da177e2005-04-16 15:20:36 -070097#endif