xattr.h 6.6 KB
Newer Older
1
/*
2
  File: fs/ext4/xattr.h
3

4
  On-disk format of extended attributes for the ext4 filesystem.
5 6 7 8 9 10 11

  (C) 2001 Andreas Gruenbacher, <a.gruenbacher@computer.org>
*/

#include <linux/xattr.h>

/* Magic value in attribute blocks */
12
#define EXT4_XATTR_MAGIC		0xEA020000
13 14

/* Maximum number of references to one attribute block */
15
#define EXT4_XATTR_REFCOUNT_MAX		1024
16 17

/* Name indexes */
18 19 20 21 22 23
#define EXT4_XATTR_INDEX_USER			1
#define EXT4_XATTR_INDEX_POSIX_ACL_ACCESS	2
#define EXT4_XATTR_INDEX_POSIX_ACL_DEFAULT	3
#define EXT4_XATTR_INDEX_TRUSTED		4
#define	EXT4_XATTR_INDEX_LUSTRE			5
#define EXT4_XATTR_INDEX_SECURITY	        6
24
#define EXT4_XATTR_INDEX_SYSTEM			7
25
#define EXT4_XATTR_INDEX_RICHACL		8
26
#define EXT4_XATTR_INDEX_ENCRYPTION		9
27
#define EXT4_XATTR_INDEX_HURD			10 /* Reserved for Hurd */
28 29

struct ext4_xattr_header {
30 31 32 33
	__le32	h_magic;	/* magic number for identification */
	__le32	h_refcount;	/* reference count */
	__le32	h_blocks;	/* number of disk blocks used */
	__le32	h_hash;		/* hash value of all attributes */
34 35 36
	__le32	h_checksum;	/* crc32c(uuid+id+xattrblock) */
				/* id = inum if refcount=1, blknum otherwise */
	__u32	h_reserved[3];	/* zero right now */
37 38
};

39
struct ext4_xattr_ibody_header {
40 41 42
	__le32	h_magic;	/* magic number for identification */
};

43
struct ext4_xattr_entry {
44 45 46
	__u8	e_name_len;	/* length of name */
	__u8	e_name_index;	/* attribute name index */
	__le16	e_value_offs;	/* offset in disk block of value */
A
Andreas Dilger 已提交
47
	__le32	e_value_inum;	/* inode in which the value is stored */
48 49 50 51 52
	__le32	e_value_size;	/* size of attribute value */
	__le32	e_hash;		/* hash value of name and value */
	char	e_name[0];	/* attribute name */
};

53 54 55 56 57 58 59
#define EXT4_XATTR_PAD_BITS		2
#define EXT4_XATTR_PAD		(1<<EXT4_XATTR_PAD_BITS)
#define EXT4_XATTR_ROUND		(EXT4_XATTR_PAD-1)
#define EXT4_XATTR_LEN(name_len) \
	(((name_len) + EXT4_XATTR_ROUND + \
	sizeof(struct ext4_xattr_entry)) & ~EXT4_XATTR_ROUND)
#define EXT4_XATTR_NEXT(entry) \
60 61
	((struct ext4_xattr_entry *)( \
	 (char *)(entry) + EXT4_XATTR_LEN((entry)->e_name_len)))
62 63
#define EXT4_XATTR_SIZE(size) \
	(((size) + EXT4_XATTR_ROUND) & ~EXT4_XATTR_ROUND)
64

65 66 67 68 69 70 71
#define IHDR(inode, raw_inode) \
	((struct ext4_xattr_ibody_header *) \
		((void *)raw_inode + \
		EXT4_GOOD_OLD_INODE_SIZE + \
		EXT4_I(inode)->i_extra_isize))
#define IFIRST(hdr) ((struct ext4_xattr_entry *)((hdr)+1))

A
Andreas Dilger 已提交
72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91
/*
 * Link EA inode back to parent one using i_mtime field.
 * Extra integer type conversion added to ignore higher
 * bits in i_mtime.tv_sec which might be set by ext4_get()
 */
#define EXT4_XATTR_INODE_SET_PARENT(inode, inum)      \
do {                                                  \
      (inode)->i_mtime.tv_sec = inum;                 \
} while(0)

#define EXT4_XATTR_INODE_GET_PARENT(inode)            \
((__u32)(inode)->i_mtime.tv_sec)

/*
 * The minimum size of EA value when you start storing it in an external inode
 * size of block - size of header - size of 1 entry - 4 null bytes
*/
#define EXT4_XATTR_MIN_LARGE_EA_SIZE(b)					\
	((b) - EXT4_XATTR_LEN(3) - sizeof(struct ext4_xattr_header) - 4)

T
Tao Ma 已提交
92 93 94 95 96
#define BHDR(bh) ((struct ext4_xattr_header *)((bh)->b_data))
#define ENTRY(ptr) ((struct ext4_xattr_entry *)(ptr))
#define BFIRST(bh) ENTRY(BHDR(bh)+1)
#define IS_LAST_ENTRY(entry) (*(__u32 *)(entry) == 0)

97
#define EXT4_ZERO_XATTR_VALUE ((void *)-1)
T
Tao Ma 已提交
98 99 100 101 102

struct ext4_xattr_info {
	const char *name;
	const void *value;
	size_t value_len;
A
Andreas Dilger 已提交
103 104
	int name_index;
	int in_inode;
T
Tao Ma 已提交
105 106 107 108 109 110 111 112 113 114 115 116 117 118 119
};

struct ext4_xattr_search {
	struct ext4_xattr_entry *first;
	void *base;
	void *end;
	struct ext4_xattr_entry *here;
	int not_found;
};

struct ext4_xattr_ibody_find {
	struct ext4_xattr_search s;
	struct ext4_iloc iloc;
};

S
Stephen Hemminger 已提交
120 121 122
extern const struct xattr_handler ext4_xattr_user_handler;
extern const struct xattr_handler ext4_xattr_trusted_handler;
extern const struct xattr_handler ext4_xattr_security_handler;
123

124 125
#define EXT4_XATTR_NAME_ENCRYPTION_CONTEXT "c"

126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157
/*
 * The EXT4_STATE_NO_EXPAND is overloaded and used for two purposes.
 * The first is to signal that there the inline xattrs and data are
 * taking up so much space that we might as well not keep trying to
 * expand it.  The second is that xattr_sem is taken for writing, so
 * we shouldn't try to recurse into the inode expansion.  For this
 * second case, we need to make sure that we take save and restore the
 * NO_EXPAND state flag appropriately.
 */
static inline void ext4_write_lock_xattr(struct inode *inode, int *save)
{
	down_write(&EXT4_I(inode)->xattr_sem);
	*save = ext4_test_inode_state(inode, EXT4_STATE_NO_EXPAND);
	ext4_set_inode_state(inode, EXT4_STATE_NO_EXPAND);
}

static inline int ext4_write_trylock_xattr(struct inode *inode, int *save)
{
	if (down_write_trylock(&EXT4_I(inode)->xattr_sem) == 0)
		return 0;
	*save = ext4_test_inode_state(inode, EXT4_STATE_NO_EXPAND);
	ext4_set_inode_state(inode, EXT4_STATE_NO_EXPAND);
	return 1;
}

static inline void ext4_write_unlock_xattr(struct inode *inode, int *save)
{
	if (*save == 0)
		ext4_clear_inode_state(inode, EXT4_STATE_NO_EXPAND);
	up_write(&EXT4_I(inode)->xattr_sem);
}

158
extern ssize_t ext4_listxattr(struct dentry *, char *, size_t);
159

160 161 162
extern int ext4_xattr_get(struct inode *, int, const char *, void *, size_t);
extern int ext4_xattr_set(struct inode *, int, const char *, const void *, size_t, int);
extern int ext4_xattr_set_handle(handle_t *, struct inode *, int, const char *, const void *, size_t, int);
163

A
Andreas Dilger 已提交
164 165 166 167 168 169 170
extern struct inode *ext4_xattr_inode_iget(struct inode *parent, unsigned long ea_ino,
					   int *err);
extern int ext4_xattr_inode_unlink(struct inode *inode, unsigned long ea_ino);
extern int ext4_xattr_delete_inode(handle_t *handle, struct inode *inode,
				   struct ext4_xattr_ino_array **array);
extern void ext4_xattr_inode_array_free(struct inode *inode,
					struct ext4_xattr_ino_array *array);
171

172 173 174
extern int ext4_expand_extra_isize_ea(struct inode *inode, int new_extra_isize,
			    struct ext4_inode *raw_inode, handle_t *handle);

S
Stephen Hemminger 已提交
175
extern const struct xattr_handler *ext4_xattr_handlers[];
176

T
Tao Ma 已提交
177 178 179 180 181
extern int ext4_xattr_ibody_find(struct inode *inode, struct ext4_xattr_info *i,
				 struct ext4_xattr_ibody_find *is);
extern int ext4_xattr_ibody_get(struct inode *inode, int name_index,
				const char *name,
				void *buffer, size_t buffer_size);
182 183 184
extern int ext4_xattr_ibody_inline_set(handle_t *handle, struct inode *inode,
				       struct ext4_xattr_info *i,
				       struct ext4_xattr_ibody_find *is);
T
Tao Ma 已提交
185

J
Jan Kara 已提交
186 187
extern struct mb_cache *ext4_xattr_create_cache(void);
extern void ext4_xattr_destroy_cache(struct mb_cache *);
188

T
Theodore Ts'o 已提交
189
#ifdef CONFIG_EXT4_FS_SECURITY
190
extern int ext4_init_security(handle_t *handle, struct inode *inode,
191
			      struct inode *dir, const struct qstr *qstr);
192
#else
193
static inline int ext4_init_security(handle_t *handle, struct inode *inode,
194
				     struct inode *dir, const struct qstr *qstr)
195 196 197 198
{
	return 0;
}
#endif