xref: /aosp_15_r20/external/e2fsprogs/lib/ext2fs/ext2_ext_attr.h (revision 6a54128f25917bfc36a8a6e9d722c04a0b4641b6)
1*6a54128fSAndroid Build Coastguard Worker /*
2*6a54128fSAndroid Build Coastguard Worker   File: linux/ext2_ext_attr.h
3*6a54128fSAndroid Build Coastguard Worker 
4*6a54128fSAndroid Build Coastguard Worker   On-disk format of extended attributes for the ext2 filesystem.
5*6a54128fSAndroid Build Coastguard Worker 
6*6a54128fSAndroid Build Coastguard Worker   (C) 2000 Andreas Gruenbacher, <[email protected]>
7*6a54128fSAndroid Build Coastguard Worker */
8*6a54128fSAndroid Build Coastguard Worker 
9*6a54128fSAndroid Build Coastguard Worker #ifndef _EXT2_EXT_ATTR_H
10*6a54128fSAndroid Build Coastguard Worker #define _EXT2_EXT_ATTR_H
11*6a54128fSAndroid Build Coastguard Worker /* Magic value in attribute blocks */
12*6a54128fSAndroid Build Coastguard Worker #define EXT2_EXT_ATTR_MAGIC_v1		0xEA010000
13*6a54128fSAndroid Build Coastguard Worker #define EXT2_EXT_ATTR_MAGIC		0xEA020000
14*6a54128fSAndroid Build Coastguard Worker 
15*6a54128fSAndroid Build Coastguard Worker /* Maximum number of references to one attribute block */
16*6a54128fSAndroid Build Coastguard Worker #define EXT2_EXT_ATTR_REFCOUNT_MAX	1024
17*6a54128fSAndroid Build Coastguard Worker 
18*6a54128fSAndroid Build Coastguard Worker struct ext2_ext_attr_header {
19*6a54128fSAndroid Build Coastguard Worker 	__u32	h_magic;	/* magic number for identification */
20*6a54128fSAndroid Build Coastguard Worker 	__u32	h_refcount;	/* reference count */
21*6a54128fSAndroid Build Coastguard Worker 	__u32	h_blocks;	/* number of disk blocks used */
22*6a54128fSAndroid Build Coastguard Worker 	__u32	h_hash;		/* hash value of all attributes */
23*6a54128fSAndroid Build Coastguard Worker 	__u32	h_checksum;	/* crc32c(uuid+id+xattrs) */
24*6a54128fSAndroid Build Coastguard Worker 				/* id = inum if refcount = 1, else blknum */
25*6a54128fSAndroid Build Coastguard Worker 	__u32	h_reserved[3];	/* zero right now */
26*6a54128fSAndroid Build Coastguard Worker };
27*6a54128fSAndroid Build Coastguard Worker 
28*6a54128fSAndroid Build Coastguard Worker struct ext2_ext_attr_entry {
29*6a54128fSAndroid Build Coastguard Worker 	__u8	e_name_len;	/* length of name */
30*6a54128fSAndroid Build Coastguard Worker 	__u8	e_name_index;	/* attribute name index */
31*6a54128fSAndroid Build Coastguard Worker 	__u16	e_value_offs;	/* offset in disk block of value */
32*6a54128fSAndroid Build Coastguard Worker 	__u32	e_value_inum;	/* inode in which the value is stored */
33*6a54128fSAndroid Build Coastguard Worker 	__u32	e_value_size;	/* size of attribute value */
34*6a54128fSAndroid Build Coastguard Worker 	__u32	e_hash;		/* hash value of name and value */
35*6a54128fSAndroid Build Coastguard Worker #if 0
36*6a54128fSAndroid Build Coastguard Worker 	char	e_name[0];	/* attribute name */
37*6a54128fSAndroid Build Coastguard Worker #endif
38*6a54128fSAndroid Build Coastguard Worker };
39*6a54128fSAndroid Build Coastguard Worker 
40*6a54128fSAndroid Build Coastguard Worker #define EXT2_EXT_ATTR_PAD_BITS		2
41*6a54128fSAndroid Build Coastguard Worker #define EXT2_EXT_ATTR_PAD		((unsigned) 1<<EXT2_EXT_ATTR_PAD_BITS)
42*6a54128fSAndroid Build Coastguard Worker #define EXT2_EXT_ATTR_ROUND		(EXT2_EXT_ATTR_PAD-1)
43*6a54128fSAndroid Build Coastguard Worker #define EXT2_EXT_ATTR_LEN(name_len) \
44*6a54128fSAndroid Build Coastguard Worker 	(((name_len) + EXT2_EXT_ATTR_ROUND + \
45*6a54128fSAndroid Build Coastguard Worker 	sizeof(struct ext2_ext_attr_entry)) & ~EXT2_EXT_ATTR_ROUND)
46*6a54128fSAndroid Build Coastguard Worker #define EXT2_EXT_ATTR_NEXT(entry) \
47*6a54128fSAndroid Build Coastguard Worker 	( (struct ext2_ext_attr_entry *)( \
48*6a54128fSAndroid Build Coastguard Worker 	  (char *)(entry) + EXT2_EXT_ATTR_LEN((entry)->e_name_len)) )
49*6a54128fSAndroid Build Coastguard Worker #define EXT2_EXT_ATTR_SIZE(size) \
50*6a54128fSAndroid Build Coastguard Worker 	(((size) + EXT2_EXT_ATTR_ROUND) & ~EXT2_EXT_ATTR_ROUND)
51*6a54128fSAndroid Build Coastguard Worker #define EXT2_EXT_IS_LAST_ENTRY(entry) (*((__u32 *)(entry)) == 0UL)
52*6a54128fSAndroid Build Coastguard Worker #define EXT2_EXT_ATTR_NAME(entry) \
53*6a54128fSAndroid Build Coastguard Worker 	(((char *) (entry)) + sizeof(struct ext2_ext_attr_entry))
54*6a54128fSAndroid Build Coastguard Worker #define EXT2_XATTR_LEN(name_len) \
55*6a54128fSAndroid Build Coastguard Worker 	(((name_len) + EXT2_EXT_ATTR_ROUND + \
56*6a54128fSAndroid Build Coastguard Worker 	sizeof(struct ext2_xattr_entry)) & ~EXT2_EXT_ATTR_ROUND)
57*6a54128fSAndroid Build Coastguard Worker #define EXT2_XATTR_SIZE(size) \
58*6a54128fSAndroid Build Coastguard Worker 	(((size) + EXT2_EXT_ATTR_ROUND) & ~EXT2_EXT_ATTR_ROUND)
59*6a54128fSAndroid Build Coastguard Worker 
60*6a54128fSAndroid Build Coastguard Worker /*
61*6a54128fSAndroid Build Coastguard Worker  * XATTR_SIZE_MAX is currently 64k, but for the purposes of checking
62*6a54128fSAndroid Build Coastguard Worker  * for file system consistency errors, we use a somewhat bigger value.
63*6a54128fSAndroid Build Coastguard Worker  * This allows XATTR_SIZE_MAX to grow in the future, but by using this
64*6a54128fSAndroid Build Coastguard Worker  * instead of INT_MAX for certain consistency checks, we don't need to
65*6a54128fSAndroid Build Coastguard Worker  * worry about arithmetic overflows.  (Actually XATTR_SIZE_MAX is
66*6a54128fSAndroid Build Coastguard Worker  * defined in include/uapi/linux/limits.h, so changing it is going
67*6a54128fSAndroid Build Coastguard Worker  * not going to be trivial....)
68*6a54128fSAndroid Build Coastguard Worker  */
69*6a54128fSAndroid Build Coastguard Worker #define EXT2_XATTR_SIZE_MAX (1 << 24)
70*6a54128fSAndroid Build Coastguard Worker 
71*6a54128fSAndroid Build Coastguard Worker #ifdef __KERNEL__
72*6a54128fSAndroid Build Coastguard Worker # ifdef CONFIG_EXT2_FS_EXT_ATTR
73*6a54128fSAndroid Build Coastguard Worker extern int ext2_get_ext_attr(struct inode *, const char *, char *, size_t, int);
74*6a54128fSAndroid Build Coastguard Worker extern int ext2_set_ext_attr(struct inode *, const char *, char *, size_t, int);
75*6a54128fSAndroid Build Coastguard Worker extern void ext2_ext_attr_free_inode(struct inode *inode);
76*6a54128fSAndroid Build Coastguard Worker extern void ext2_ext_attr_put_super(struct super_block *sb);
77*6a54128fSAndroid Build Coastguard Worker extern int ext2_ext_attr_init(void);
78*6a54128fSAndroid Build Coastguard Worker extern void ext2_ext_attr_done(void);
79*6a54128fSAndroid Build Coastguard Worker # else
80*6a54128fSAndroid Build Coastguard Worker #  define ext2_get_ext_attr NULL
81*6a54128fSAndroid Build Coastguard Worker #  define ext2_set_ext_attr NULL
82*6a54128fSAndroid Build Coastguard Worker # endif
83*6a54128fSAndroid Build Coastguard Worker #endif  /* __KERNEL__ */
84*6a54128fSAndroid Build Coastguard Worker #endif  /* _EXT2_EXT_ATTR_H */
85