| #ifndef _REISER_FS_I | 
 | #define _REISER_FS_I | 
 |  | 
 | #include <linux/list.h> | 
 |  | 
 | struct reiserfs_journal_list; | 
 |  | 
 | /** bitmasks for i_flags field in reiserfs-specific part of inode */ | 
 | typedef enum { | 
 |     /** this says what format of key do all items (but stat data) of | 
 |       an object have.  If this is set, that format is 3.6 otherwise | 
 |       - 3.5 */ | 
 | 	i_item_key_version_mask = 0x0001, | 
 |     /** If this is unset, object has 3.5 stat data, otherwise, it has | 
 |       3.6 stat data with 64bit size, 32bit nlink etc. */ | 
 | 	i_stat_data_version_mask = 0x0002, | 
 |     /** file might need tail packing on close */ | 
 | 	i_pack_on_close_mask = 0x0004, | 
 |     /** don't pack tail of file */ | 
 | 	i_nopack_mask = 0x0008, | 
 |     /** If those is set, "safe link" was created for this file during | 
 |       truncate or unlink. Safe link is used to avoid leakage of disk | 
 |       space on crash with some files open, but unlinked. */ | 
 | 	i_link_saved_unlink_mask = 0x0010, | 
 | 	i_link_saved_truncate_mask = 0x0020, | 
 | 	i_has_xattr_dir = 0x0040, | 
 | 	i_data_log = 0x0080, | 
 | } reiserfs_inode_flags; | 
 |  | 
 | struct reiserfs_inode_info { | 
 | 	__u32 i_key[4];		/* key is still 4 32 bit integers */ | 
 |     /** transient inode flags that are never stored on disk. Bitmasks | 
 |       for this field are defined above. */ | 
 | 	__u32 i_flags; | 
 |  | 
 | 	__u32 i_first_direct_byte;	// offset of first byte stored in direct item. | 
 |  | 
 | 	/* copy of persistent inode flags read from sd_attrs. */ | 
 | 	__u32 i_attrs; | 
 |  | 
 | 	int i_prealloc_block;	/* first unused block of a sequence of unused blocks */ | 
 | 	int i_prealloc_count;	/* length of that sequence */ | 
 | 	struct list_head i_prealloc_list;	/* per-transaction list of inodes which | 
 | 						 * have preallocated blocks */ | 
 |  | 
 | 	unsigned new_packing_locality:1;	/* new_packig_locality is created; new blocks | 
 | 						 * for the contents of this directory should be | 
 | 						 * displaced */ | 
 |  | 
 | 	/* we use these for fsync or O_SYNC to decide which transaction | 
 | 	 ** needs to be committed in order for this inode to be properly | 
 | 	 ** flushed */ | 
 | 	unsigned long i_trans_id; | 
 | 	struct reiserfs_journal_list *i_jl; | 
 |  | 
 | 	struct posix_acl *i_acl_access; | 
 | 	struct posix_acl *i_acl_default; | 
 | 	struct rw_semaphore xattr_sem; | 
 | 	struct inode vfs_inode; | 
 | }; | 
 |  | 
 | #endif |