| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | #include <linux/init.h> | 
 | 2 | #include <linux/posix_acl.h> | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 3 |  | 
 | 4 | #define REISERFS_ACL_VERSION	0x0001 | 
 | 5 |  | 
 | 6 | typedef struct { | 
| Linus Torvalds | bd4c625 | 2005-07-12 20:21:28 -0700 | [diff] [blame] | 7 | 	__le16 e_tag; | 
 | 8 | 	__le16 e_perm; | 
 | 9 | 	__le32 e_id; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 10 | } reiserfs_acl_entry; | 
 | 11 |  | 
 | 12 | typedef struct { | 
| Linus Torvalds | bd4c625 | 2005-07-12 20:21:28 -0700 | [diff] [blame] | 13 | 	__le16 e_tag; | 
 | 14 | 	__le16 e_perm; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 15 | } reiserfs_acl_entry_short; | 
 | 16 |  | 
 | 17 | typedef struct { | 
| Linus Torvalds | bd4c625 | 2005-07-12 20:21:28 -0700 | [diff] [blame] | 18 | 	__le32 a_version; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 19 | } reiserfs_acl_header; | 
 | 20 |  | 
 | 21 | static inline size_t reiserfs_acl_size(int count) | 
 | 22 | { | 
 | 23 | 	if (count <= 4) { | 
 | 24 | 		return sizeof(reiserfs_acl_header) + | 
| Linus Torvalds | bd4c625 | 2005-07-12 20:21:28 -0700 | [diff] [blame] | 25 | 		    count * sizeof(reiserfs_acl_entry_short); | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 26 | 	} else { | 
 | 27 | 		return sizeof(reiserfs_acl_header) + | 
| Linus Torvalds | bd4c625 | 2005-07-12 20:21:28 -0700 | [diff] [blame] | 28 | 		    4 * sizeof(reiserfs_acl_entry_short) + | 
 | 29 | 		    (count - 4) * sizeof(reiserfs_acl_entry); | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 30 | 	} | 
 | 31 | } | 
 | 32 |  | 
 | 33 | static 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 Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 49 | #ifdef CONFIG_REISERFS_FS_POSIX_ACL | 
| Linus Torvalds | bd4c625 | 2005-07-12 20:21:28 -0700 | [diff] [blame] | 50 | struct posix_acl *reiserfs_get_acl(struct inode *inode, int type); | 
 | 51 | int reiserfs_acl_chmod(struct inode *inode); | 
| Jeff Mahoney | 0ab2621 | 2009-03-30 14:02:39 -0400 | [diff] [blame] | 52 | int reiserfs_inherit_default_acl(struct reiserfs_transaction_handle *th, | 
 | 53 | 				 struct inode *dir, struct dentry *dentry, | 
| Linus Torvalds | bd4c625 | 2005-07-12 20:21:28 -0700 | [diff] [blame] | 54 | 				 struct inode *inode); | 
 | 55 | int reiserfs_cache_default_acl(struct inode *dir); | 
| Jeff Mahoney | 48b32a3 | 2009-03-30 14:02:38 -0400 | [diff] [blame] | 56 | extern struct xattr_handler reiserfs_posix_acl_default_handler; | 
 | 57 | extern struct xattr_handler reiserfs_posix_acl_access_handler; | 
| Alexey Dobriyan | cfe1467 | 2006-09-29 02:00:00 -0700 | [diff] [blame] | 58 |  | 
 | 59 | static inline void reiserfs_init_acl_access(struct inode *inode) | 
 | 60 | { | 
 | 61 | 	REISERFS_I(inode)->i_acl_access = NULL; | 
 | 62 | } | 
 | 63 |  | 
 | 64 | static inline void reiserfs_init_acl_default(struct inode *inode) | 
 | 65 | { | 
 | 66 | 	REISERFS_I(inode)->i_acl_default = NULL; | 
 | 67 | } | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 68 | #else | 
 | 69 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 70 | #define reiserfs_cache_default_acl(inode) 0 | 
 | 71 |  | 
| Andrew Morton | bc5e483 | 2006-02-04 23:27:51 -0800 | [diff] [blame] | 72 | static inline struct posix_acl *reiserfs_get_acl(struct inode *inode, int type) | 
 | 73 | { | 
 | 74 | 	return NULL; | 
 | 75 | } | 
 | 76 |  | 
| Linus Torvalds | bd4c625 | 2005-07-12 20:21:28 -0700 | [diff] [blame] | 77 | static inline int reiserfs_acl_chmod(struct inode *inode) | 
 | 78 | { | 
 | 79 | 	return 0; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 80 | } | 
 | 81 |  | 
 | 82 | static inline int | 
| Alexander Beregalov | 77e4658 | 2009-03-31 00:32:40 +0400 | [diff] [blame] | 83 | reiserfs_inherit_default_acl(struct reiserfs_transaction_handle *th, | 
 | 84 | 			     const struct inode *dir, struct dentry *dentry, | 
| Linus Torvalds | bd4c625 | 2005-07-12 20:21:28 -0700 | [diff] [blame] | 85 | 			     struct inode *inode) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 86 | { | 
| Linus Torvalds | bd4c625 | 2005-07-12 20:21:28 -0700 | [diff] [blame] | 87 | 	return 0; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 88 | } | 
 | 89 |  | 
| Alexey Dobriyan | cfe1467 | 2006-09-29 02:00:00 -0700 | [diff] [blame] | 90 | static inline void reiserfs_init_acl_access(struct inode *inode) | 
 | 91 | { | 
 | 92 | } | 
 | 93 |  | 
 | 94 | static inline void reiserfs_init_acl_default(struct inode *inode) | 
 | 95 | { | 
 | 96 | } | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 97 | #endif |