diff options
Diffstat (limited to 'fs/xfs/xfs_inode.h')
| -rw-r--r-- | fs/xfs/xfs_inode.h | 31 | 
1 files changed, 29 insertions, 2 deletions
| diff --git a/fs/xfs/xfs_inode.h b/fs/xfs/xfs_inode.h index 237e7f6f2ab..91129794aae 100644 --- a/fs/xfs/xfs_inode.h +++ b/fs/xfs/xfs_inode.h @@ -150,13 +150,38 @@ typedef struct xfs_icdinode {  	__uint16_t	di_dmstate;	/* DMIG state info */  	__uint16_t	di_flags;	/* random flags, XFS_DIFLAG_... */  	__uint32_t	di_gen;		/* generation number */ + +	/* di_next_unlinked is the only non-core field in the old dinode */ +	xfs_agino_t	di_next_unlinked;/* agi unlinked list ptr */ + +	/* start of the extended dinode, writable fields */ +	__uint32_t	di_crc;		/* CRC of the inode */ +	__uint64_t	di_changecount;	/* number of attribute changes */ +	xfs_lsn_t	di_lsn;		/* flush sequence */ +	__uint64_t	di_flags2;	/* more random flags */ +	__uint8_t	di_pad2[16];	/* more padding for future expansion */ + +	/* fields only written to during inode creation */ +	xfs_ictimestamp_t di_crtime;	/* time created */ +	xfs_ino_t	di_ino;		/* inode number */ +	uuid_t		di_uuid;	/* UUID of the filesystem */ + +	/* structure must be padded to 64 bit alignment */  } xfs_icdinode_t; +static inline uint xfs_icdinode_size(int version) +{ +	if (version == 3) +		return sizeof(struct xfs_icdinode); +	return offsetof(struct xfs_icdinode, di_next_unlinked); +} +  /*   * Flags for xfs_ichgtime().   */  #define	XFS_ICHGTIME_MOD	0x1	/* data fork modification timestamp */  #define	XFS_ICHGTIME_CHG	0x2	/* inode field change timestamp */ +#define	XFS_ICHGTIME_CREATE	0x4	/* inode create timestamp */  /*   * Per-fork incore inode flags. @@ -180,10 +205,11 @@ typedef struct xfs_icdinode {  #define XFS_IFORK_DSIZE(ip) \  	(XFS_IFORK_Q(ip) ? \  		XFS_IFORK_BOFF(ip) : \ -		XFS_LITINO((ip)->i_mount)) +		XFS_LITINO((ip)->i_mount, (ip)->i_d.di_version))  #define XFS_IFORK_ASIZE(ip) \  	(XFS_IFORK_Q(ip) ? \ -		XFS_LITINO((ip)->i_mount) - XFS_IFORK_BOFF(ip) : \ +		XFS_LITINO((ip)->i_mount, (ip)->i_d.di_version) - \ +			XFS_IFORK_BOFF(ip) : \  		0)  #define XFS_IFORK_SIZE(ip,w) \  	((w) == XFS_DATA_FORK ? \ @@ -555,6 +581,7 @@ int		xfs_imap_to_bp(struct xfs_mount *, struct xfs_trans *,  			       struct xfs_buf **, uint, uint);  int		xfs_iread(struct xfs_mount *, struct xfs_trans *,  			  struct xfs_inode *, uint); +void		xfs_dinode_calc_crc(struct xfs_mount *, struct xfs_dinode *);  void		xfs_dinode_to_disk(struct xfs_dinode *,  				   struct xfs_icdinode *);  void		xfs_idestroy_fork(struct xfs_inode *, int); | 
