📄 ext4_fs.h
字号:
/* * linux/include/linux/ext4_fs.h * * Copyright (C) 1992, 1993, 1994, 1995 * Remy Card (card@masi.ibp.fr) * Laboratoire MASI - Institut Blaise Pascal * Universite Pierre et Marie Curie (Paris VI) * * from * * linux/include/linux/minix_fs.h * * Copyright (C) 1991, 1992 Linus Torvalds */#ifndef _LINUX_EXT4_FS_H#define _LINUX_EXT4_FS_H#include <linux/types.h>#include <linux/blkdev.h>#include <linux/magic.h>/* * The second extended filesystem constants/structures *//* * Define EXT4FS_DEBUG to produce debug messages */#undef EXT4FS_DEBUG/* * Define EXT4_RESERVATION to reserve data blocks for expanding files */#define EXT4_DEFAULT_RESERVE_BLOCKS 8/*max window size: 1024(direct blocks) + 3([t,d]indirect blocks) */#define EXT4_MAX_RESERVE_BLOCKS 1027#define EXT4_RESERVE_WINDOW_NOT_ALLOCATED 0/* * Always enable hashed directories */#define CONFIG_EXT4_INDEX/* * Debug code */#ifdef EXT4FS_DEBUG#define ext4_debug(f, a...) \ do { \ printk (KERN_DEBUG "EXT4-fs DEBUG (%s, %d): %s:", \ __FILE__, __LINE__, __FUNCTION__); \ printk (KERN_DEBUG f, ## a); \ } while (0)#else#define ext4_debug(f, a...) do {} while (0)#endif/* * Special inodes numbers */#define EXT4_BAD_INO 1 /* Bad blocks inode */#define EXT4_ROOT_INO 2 /* Root inode */#define EXT4_BOOT_LOADER_INO 5 /* Boot loader inode */#define EXT4_UNDEL_DIR_INO 6 /* Undelete directory inode */#define EXT4_RESIZE_INO 7 /* Reserved group descriptors inode */#define EXT4_JOURNAL_INO 8 /* Journal inode *//* First non-reserved inode for old ext4 filesystems */#define EXT4_GOOD_OLD_FIRST_INO 11/* * Maximal count of links to a file */#define EXT4_LINK_MAX 32000/* * Macro-instructions used to manage several block sizes */#define EXT4_MIN_BLOCK_SIZE 1024#define EXT4_MAX_BLOCK_SIZE 4096#define EXT4_MIN_BLOCK_LOG_SIZE 10#ifdef __KERNEL__# define EXT4_BLOCK_SIZE(s) ((s)->s_blocksize)#else# define EXT4_BLOCK_SIZE(s) (EXT4_MIN_BLOCK_SIZE << (s)->s_log_block_size)#endif#define EXT4_ADDR_PER_BLOCK(s) (EXT4_BLOCK_SIZE(s) / sizeof (__u32))#ifdef __KERNEL__# define EXT4_BLOCK_SIZE_BITS(s) ((s)->s_blocksize_bits)#else# define EXT4_BLOCK_SIZE_BITS(s) ((s)->s_log_block_size + 10)#endif#ifdef __KERNEL__#define EXT4_ADDR_PER_BLOCK_BITS(s) (EXT4_SB(s)->s_addr_per_block_bits)#define EXT4_INODE_SIZE(s) (EXT4_SB(s)->s_inode_size)#define EXT4_FIRST_INO(s) (EXT4_SB(s)->s_first_ino)#else#define EXT4_INODE_SIZE(s) (((s)->s_rev_level == EXT4_GOOD_OLD_REV) ? \ EXT4_GOOD_OLD_INODE_SIZE : \ (s)->s_inode_size)#define EXT4_FIRST_INO(s) (((s)->s_rev_level == EXT4_GOOD_OLD_REV) ? \ EXT4_GOOD_OLD_FIRST_INO : \ (s)->s_first_ino)#endif/* * Macro-instructions used to manage fragments */#define EXT4_MIN_FRAG_SIZE 1024#define EXT4_MAX_FRAG_SIZE 4096#define EXT4_MIN_FRAG_LOG_SIZE 10#ifdef __KERNEL__# define EXT4_FRAG_SIZE(s) (EXT4_SB(s)->s_frag_size)# define EXT4_FRAGS_PER_BLOCK(s) (EXT4_SB(s)->s_frags_per_block)#else# define EXT4_FRAG_SIZE(s) (EXT4_MIN_FRAG_SIZE << (s)->s_log_frag_size)# define EXT4_FRAGS_PER_BLOCK(s) (EXT4_BLOCK_SIZE(s) / EXT4_FRAG_SIZE(s))#endif/* * Structure of a blocks group descriptor */struct ext4_group_desc{ __le32 bg_block_bitmap; /* Blocks bitmap block */ __le32 bg_inode_bitmap; /* Inodes bitmap block */ __le32 bg_inode_table; /* Inodes table block */ __le16 bg_free_blocks_count; /* Free blocks count */ __le16 bg_free_inodes_count; /* Free inodes count */ __le16 bg_used_dirs_count; /* Directories count */ __u16 bg_flags; __u32 bg_reserved[3]; __le32 bg_block_bitmap_hi; /* Blocks bitmap block MSB */ __le32 bg_inode_bitmap_hi; /* Inodes bitmap block MSB */ __le32 bg_inode_table_hi; /* Inodes table block MSB */};#ifdef __KERNEL__#include <linux/ext4_fs_i.h>#include <linux/ext4_fs_sb.h>#endif/* * Macro-instructions used to manage group descriptors */#define EXT4_MIN_DESC_SIZE 32#define EXT4_MIN_DESC_SIZE_64BIT 64#define EXT4_MAX_DESC_SIZE EXT4_MIN_BLOCK_SIZE#define EXT4_DESC_SIZE(s) (EXT4_SB(s)->s_desc_size)#ifdef __KERNEL__# define EXT4_BLOCKS_PER_GROUP(s) (EXT4_SB(s)->s_blocks_per_group)# define EXT4_DESC_PER_BLOCK(s) (EXT4_SB(s)->s_desc_per_block)# define EXT4_INODES_PER_GROUP(s) (EXT4_SB(s)->s_inodes_per_group)# define EXT4_DESC_PER_BLOCK_BITS(s) (EXT4_SB(s)->s_desc_per_block_bits)#else# define EXT4_BLOCKS_PER_GROUP(s) ((s)->s_blocks_per_group)# define EXT4_DESC_PER_BLOCK(s) (EXT4_BLOCK_SIZE(s) / EXT4_DESC_SIZE(s))# define EXT4_INODES_PER_GROUP(s) ((s)->s_inodes_per_group)#endif/* * Constants relative to the data blocks */#define EXT4_NDIR_BLOCKS 12#define EXT4_IND_BLOCK EXT4_NDIR_BLOCKS#define EXT4_DIND_BLOCK (EXT4_IND_BLOCK + 1)#define EXT4_TIND_BLOCK (EXT4_DIND_BLOCK + 1)#define EXT4_N_BLOCKS (EXT4_TIND_BLOCK + 1)/* * Inode flags */#define EXT4_SECRM_FL 0x00000001 /* Secure deletion */#define EXT4_UNRM_FL 0x00000002 /* Undelete */#define EXT4_COMPR_FL 0x00000004 /* Compress file */#define EXT4_SYNC_FL 0x00000008 /* Synchronous updates */#define EXT4_IMMUTABLE_FL 0x00000010 /* Immutable file */#define EXT4_APPEND_FL 0x00000020 /* writes to file may only append */#define EXT4_NODUMP_FL 0x00000040 /* do not dump file */#define EXT4_NOATIME_FL 0x00000080 /* do not update atime *//* Reserved for compression usage... */#define EXT4_DIRTY_FL 0x00000100#define EXT4_COMPRBLK_FL 0x00000200 /* One or more compressed clusters */#define EXT4_NOCOMPR_FL 0x00000400 /* Don't compress */#define EXT4_ECOMPR_FL 0x00000800 /* Compression error *//* End compression flags --- maybe not all used */#define EXT4_INDEX_FL 0x00001000 /* hash-indexed directory */#define EXT4_IMAGIC_FL 0x00002000 /* AFS directory */#define EXT4_JOURNAL_DATA_FL 0x00004000 /* file data should be journaled */#define EXT4_NOTAIL_FL 0x00008000 /* file tail should not be merged */#define EXT4_DIRSYNC_FL 0x00010000 /* dirsync behaviour (directories only) */#define EXT4_TOPDIR_FL 0x00020000 /* Top of directory hierarchies*/#define EXT4_RESERVED_FL 0x80000000 /* reserved for ext4 lib */#define EXT4_EXTENTS_FL 0x00080000 /* Inode uses extents */#define EXT4_FL_USER_VISIBLE 0x000BDFFF /* User visible flags */#define EXT4_FL_USER_MODIFIABLE 0x000380FF /* User modifiable flags *//* * Inode dynamic state flags */#define EXT4_STATE_JDATA 0x00000001 /* journaled data exists */#define EXT4_STATE_NEW 0x00000002 /* inode is newly created */#define EXT4_STATE_XATTR 0x00000004 /* has in-inode xattrs *//* Used to pass group descriptor data when online resize is done */struct ext4_new_group_input { __u32 group; /* Group number for this data */ __u64 block_bitmap; /* Absolute block number of block bitmap */ __u64 inode_bitmap; /* Absolute block number of inode bitmap */ __u64 inode_table; /* Absolute block number of inode table start */ __u32 blocks_count; /* Total number of blocks in this group */ __u16 reserved_blocks; /* Number of reserved blocks in this group */ __u16 unused;};/* The struct ext4_new_group_input in kernel space, with free_blocks_count */struct ext4_new_group_data { __u32 group; __u64 block_bitmap; __u64 inode_bitmap; __u64 inode_table; __u32 blocks_count; __u16 reserved_blocks; __u16 unused; __u32 free_blocks_count;};/* * ioctl commands */#define EXT4_IOC_GETFLAGS FS_IOC_GETFLAGS#define EXT4_IOC_SETFLAGS FS_IOC_SETFLAGS#define EXT4_IOC_GETVERSION _IOR('f', 3, long)#define EXT4_IOC_SETVERSION _IOW('f', 4, long)#define EXT4_IOC_GROUP_EXTEND _IOW('f', 7, unsigned long)#define EXT4_IOC_GROUP_ADD _IOW('f', 8,struct ext4_new_group_input)#define EXT4_IOC_GETVERSION_OLD FS_IOC_GETVERSION#define EXT4_IOC_SETVERSION_OLD FS_IOC_SETVERSION#ifdef CONFIG_JBD_DEBUG#define EXT4_IOC_WAIT_FOR_READONLY _IOR('f', 99, long)#endif#define EXT4_IOC_GETRSVSZ _IOR('f', 5, long)#define EXT4_IOC_SETRSVSZ _IOW('f', 6, long)/* * ioctl commands in 32 bit emulation */#define EXT4_IOC32_GETFLAGS FS_IOC32_GETFLAGS#define EXT4_IOC32_SETFLAGS FS_IOC32_SETFLAGS#define EXT4_IOC32_GETVERSION _IOR('f', 3, int)#define EXT4_IOC32_SETVERSION _IOW('f', 4, int)#define EXT4_IOC32_GETRSVSZ _IOR('f', 5, int)#define EXT4_IOC32_SETRSVSZ _IOW('f', 6, int)#define EXT4_IOC32_GROUP_EXTEND _IOW('f', 7, unsigned int)#ifdef CONFIG_JBD_DEBUG#define EXT4_IOC32_WAIT_FOR_READONLY _IOR('f', 99, int)#endif#define EXT4_IOC32_GETVERSION_OLD FS_IOC32_GETVERSION#define EXT4_IOC32_SETVERSION_OLD FS_IOC32_SETVERSION/* * Mount options */struct ext4_mount_options { unsigned long s_mount_opt; uid_t s_resuid; gid_t s_resgid; unsigned long s_commit_interval;#ifdef CONFIG_QUOTA int s_jquota_fmt; char *s_qf_names[MAXQUOTAS];#endif};/* * Structure of an inode on the disk */struct ext4_inode { __le16 i_mode; /* File mode */ __le16 i_uid; /* Low 16 bits of Owner Uid */ __le32 i_size; /* Size in bytes */ __le32 i_atime; /* Access time */ __le32 i_ctime; /* Creation time */ __le32 i_mtime; /* Modification time */ __le32 i_dtime; /* Deletion Time */ __le16 i_gid; /* Low 16 bits of Group Id */ __le16 i_links_count; /* Links count */ __le32 i_blocks; /* Blocks count */ __le32 i_flags; /* File flags */ union { struct { __u32 l_i_reserved1; } linux1; struct { __u32 h_i_translator; } hurd1; struct { __u32 m_i_reserved1; } masix1; } osd1; /* OS dependent 1 */ __le32 i_block[EXT4_N_BLOCKS];/* Pointers to blocks */ __le32 i_generation; /* File version (for NFS) */ __le32 i_file_acl; /* File ACL */ __le32 i_dir_acl; /* Directory ACL */ __le32 i_faddr; /* Fragment address */ union { struct { __u8 l_i_frag; /* Fragment number */ __u8 l_i_fsize; /* Fragment size */ __le16 l_i_file_acl_high; __le16 l_i_uid_high; /* these 2 fields */ __le16 l_i_gid_high; /* were reserved2[0] */ __u32 l_i_reserved2; } linux2; struct { __u8 h_i_frag; /* Fragment number */ __u8 h_i_fsize; /* Fragment size */ __u16 h_i_mode_high; __u16 h_i_uid_high; __u16 h_i_gid_high; __u32 h_i_author; } hurd2; struct { __u8 m_i_frag; /* Fragment number */ __u8 m_i_fsize; /* Fragment size */ __le16 m_i_file_acl_high; __u32 m_i_reserved2[2]; } masix2; } osd2; /* OS dependent 2 */ __le16 i_extra_isize;
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -