ext4_fs.h

来自「linux 内核源代码」· C头文件 代码 · 共 1,075 行 · 第 1/3 页

H
1,075
字号
/* *  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/* * 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		65000/* * 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#define EXT4_BLOCK_ALIGN(size, blkbits)		ALIGN((size), (1 << (blkbits)))/* * Structure of a blocks group descriptor */struct ext4_group_desc{	__le32	bg_block_bitmap_lo;	/* Blocks bitmap block */	__le32	bg_inode_bitmap_lo;	/* Inodes bitmap block */	__le32	bg_inode_table_lo;	/* 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 */	__le16	bg_flags;		/* EXT4_BG_flags (INODE_UNINIT, etc) */	__u32	bg_reserved[2];		/* Likely block/inode bitmap checksum */	__le16  bg_itable_unused;	/* Unused inodes count */	__le16  bg_checksum;		/* crc16(sb_uuid+group+desc) */	__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 */};#define EXT4_BG_INODE_UNINIT	0x0001 /* Inode table/bitmap not in use */#define EXT4_BG_BLOCK_UNINIT	0x0002 /* Block bitmap not in use */#define EXT4_BG_INODE_ZEROED	0x0004 /* On-disk itable initialized to zero */#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 */#define EXT4_STATE_NO_EXPAND		0x00000008 /* No space for expansion *//* 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;};/* * Following is used by preallocation code to tell get_blocks() that we * want uninitialzed extents. */#define EXT4_CREATE_UNINITIALIZED_EXT		2/* * 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_JBD2_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_JBD2_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;	/* Inode Change 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_obso_faddr;	/* Obsoleted fragment address */	union {		struct {			__le16	l_i_reserved1;	/* Obsoleted fragment number/size which are removed in ext4 */			__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 {			__le16	h_i_reserved1;	/* Obsoleted fragment number/size which are removed in ext4 */			__u16	h_i_mode_high;			__u16	h_i_uid_high;			__u16	h_i_gid_high;			__u32	h_i_author;		} hurd2;		struct {			__le16	h_i_reserved1;	/* Obsoleted fragment number/size which are removed in ext4 */			__le16	m_i_file_acl_high;			__u32	m_i_reserved2[2];		} masix2;	} osd2;				/* OS dependent 2 */	__le16	i_extra_isize;	__le16	i_pad1;	__le32  i_ctime_extra;  /* extra Change time      (nsec << 2 | epoch) */	__le32  i_mtime_extra;  /* extra Modification time(nsec << 2 | epoch) */	__le32  i_atime_extra;  /* extra Access time      (nsec << 2 | epoch) */	__le32  i_crtime;       /* File Creation time */	__le32  i_crtime_extra; /* extra FileCreationtime (nsec << 2 | epoch) */};#define i_size_high	i_dir_acl#define EXT4_EPOCH_BITS 2#define EXT4_EPOCH_MASK ((1 << EXT4_EPOCH_BITS) - 1)#define EXT4_NSEC_MASK  (~0UL << EXT4_EPOCH_BITS)/* * Extended fields will fit into an inode if the filesystem was formatted * with large inodes (-I 256 or larger) and there are not currently any EAs * consuming all of the available space. For new inodes we always reserve * enough space for the kernel's known extended fields, but for inodes * created with an old kernel this might not have been the case. None of * the extended inode fields is critical for correct filesystem operation. * This macro checks if a certain field fits in the inode. Note that * inode-size = GOOD_OLD_INODE_SIZE + i_extra_isize */#define EXT4_FITS_IN_INODE(ext4_inode, einode, field)	\	((offsetof(typeof(*ext4_inode), field) +	\	  sizeof((ext4_inode)->field))			\	<= (EXT4_GOOD_OLD_INODE_SIZE +			\	    (einode)->i_extra_isize))			\static inline __le32 ext4_encode_extra_time(struct timespec *time){       return cpu_to_le32((sizeof(time->tv_sec) > 4 ?			   time->tv_sec >> 32 : 0) |			   ((time->tv_nsec << 2) & EXT4_NSEC_MASK));

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?