2006-10-11 01:20:50 -07:00
/*
2006-10-11 01:20:53 -07:00
File : fs / ext4 / xattr . h
2006-10-11 01:20:50 -07:00
2006-10-11 01:20:53 -07:00
On - disk format of extended attributes for the ext4 filesystem .
2006-10-11 01:20:50 -07:00
( C ) 2001 Andreas Gruenbacher , < a . gruenbacher @ computer . org >
*/
# include <linux/xattr.h>
/* Magic value in attribute blocks */
2006-10-11 01:20:53 -07:00
# define EXT4_XATTR_MAGIC 0xEA020000
2006-10-11 01:20:50 -07:00
/* Maximum number of references to one attribute block */
2006-10-11 01:20:53 -07:00
# define EXT4_XATTR_REFCOUNT_MAX 1024
2006-10-11 01:20:50 -07:00
/* Name indexes */
2006-10-11 01:20:53 -07:00
# 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
struct ext4_xattr_header {
2006-10-11 01:20:50 -07:00
__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 */
__u32 h_reserved [ 4 ] ; /* zero right now */
} ;
2006-10-11 01:20:53 -07:00
struct ext4_xattr_ibody_header {
2006-10-11 01:20:50 -07:00
__le32 h_magic ; /* magic number for identification */
} ;
2006-10-11 01:20:53 -07:00
struct ext4_xattr_entry {
2006-10-11 01:20:50 -07:00
__u8 e_name_len ; /* length of name */
__u8 e_name_index ; /* attribute name index */
__le16 e_value_offs ; /* offset in disk block of value */
__le32 e_value_block ; /* disk block attribute is stored on (n/i) */
__le32 e_value_size ; /* size of attribute value */
__le32 e_hash ; /* hash value of name and value */
char e_name [ 0 ] ; /* attribute name */
} ;
2006-10-11 01:20:53 -07:00
# 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) \
( ( struct ext4_xattr_entry * ) ( \
( char * ) ( entry ) + EXT4_XATTR_LEN ( ( entry ) - > e_name_len ) ) )
# define EXT4_XATTR_SIZE(size) \
( ( ( size ) + EXT4_XATTR_ROUND ) & ~ EXT4_XATTR_ROUND )
2006-10-11 01:20:50 -07:00
2007-07-18 09:19:57 -04:00
# 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))
2006-10-11 01:20:53 -07:00
# ifdef CONFIG_EXT4DEV_FS_XATTR
2006-10-11 01:20:50 -07:00
2006-10-11 01:20:53 -07:00
extern struct xattr_handler ext4_xattr_user_handler ;
extern struct xattr_handler ext4_xattr_trusted_handler ;
extern struct xattr_handler ext4_xattr_acl_access_handler ;
extern struct xattr_handler ext4_xattr_acl_default_handler ;
extern struct xattr_handler ext4_xattr_security_handler ;
2006-10-11 01:20:50 -07:00
2006-10-11 01:20:53 -07:00
extern ssize_t ext4_listxattr ( struct dentry * , char * , size_t ) ;
2006-10-11 01:20:50 -07:00
2006-10-11 01:20:53 -07:00
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 ) ;
2006-10-11 01:20:50 -07:00
2006-10-11 01:20:53 -07:00
extern void ext4_xattr_delete_inode ( handle_t * , struct inode * ) ;
extern void ext4_xattr_put_super ( struct super_block * ) ;
2006-10-11 01:20:50 -07:00
2007-07-18 09:19:57 -04:00
extern int ext4_expand_extra_isize_ea ( struct inode * inode , int new_extra_isize ,
struct ext4_inode * raw_inode , handle_t * handle ) ;
2006-10-11 01:20:53 -07:00
extern int init_ext4_xattr ( void ) ;
extern void exit_ext4_xattr ( void ) ;
2006-10-11 01:20:50 -07:00
2006-10-11 01:20:53 -07:00
extern struct xattr_handler * ext4_xattr_handlers [ ] ;
2006-10-11 01:20:50 -07:00
2006-10-11 01:20:53 -07:00
# else /* CONFIG_EXT4DEV_FS_XATTR */
2006-10-11 01:20:50 -07:00
static inline int
2006-10-11 01:20:53 -07:00
ext4_xattr_get ( struct inode * inode , int name_index , const char * name ,
2006-10-11 01:20:50 -07:00
void * buffer , size_t size , int flags )
{
return - EOPNOTSUPP ;
}
static inline int
2006-10-11 01:20:53 -07:00
ext4_xattr_set ( struct inode * inode , int name_index , const char * name ,
2006-10-11 01:20:50 -07:00
const void * value , size_t size , int flags )
{
return - EOPNOTSUPP ;
}
static inline int
2006-10-11 01:20:53 -07:00
ext4_xattr_set_handle ( handle_t * handle , struct inode * inode , int name_index ,
2006-10-11 01:20:50 -07:00
const char * name , const void * value , size_t size , int flags )
{
return - EOPNOTSUPP ;
}
static inline void
2006-10-11 01:20:53 -07:00
ext4_xattr_delete_inode ( handle_t * handle , struct inode * inode )
2006-10-11 01:20:50 -07:00
{
}
static inline void
2006-10-11 01:20:53 -07:00
ext4_xattr_put_super ( struct super_block * sb )
2006-10-11 01:20:50 -07:00
{
}
static inline int
2006-10-11 01:20:53 -07:00
init_ext4_xattr ( void )
2006-10-11 01:20:50 -07:00
{
return 0 ;
}
static inline void
2006-10-11 01:20:53 -07:00
exit_ext4_xattr ( void )
2006-10-11 01:20:50 -07:00
{
}
2007-07-18 09:19:57 -04:00
static inline int
ext4_expand_extra_isize_ea ( struct inode * inode , int new_extra_isize ,
struct ext4_inode * raw_inode , handle_t * handle )
{
return - EOPNOTSUPP ;
}
2006-10-11 01:20:53 -07:00
# define ext4_xattr_handlers NULL
2006-10-11 01:20:50 -07:00
2006-10-11 01:20:53 -07:00
# endif /* CONFIG_EXT4DEV_FS_XATTR */
2006-10-11 01:20:50 -07:00
2006-10-11 01:20:53 -07:00
# ifdef CONFIG_EXT4DEV_FS_SECURITY
extern int ext4_init_security ( handle_t * handle , struct inode * inode ,
2006-10-11 01:20:50 -07:00
struct inode * dir ) ;
# else
2006-10-11 01:20:53 -07:00
static inline int ext4_init_security ( handle_t * handle , struct inode * inode ,
2006-10-11 01:20:50 -07:00
struct inode * dir )
{
return 0 ;
}
# endif