[PATCH 12/13] xfs: add version 3 inode format with CRCs

Eric Sandeen sandeen at sandeen.net
Thu Feb 12 12:42:02 CST 2009


Josef 'Jeff' Sipek wrote:
> On Tue, Feb 10, 2009 at 03:22:53PM -0500, Christoph Hellwig wrote:
> ...
>> Index: xfs/fs/xfs/xfs_dinode.h
>> ===================================================================
>> --- xfs.orig/fs/xfs/xfs_dinode.h	2009-02-10 19:45:51.939069576 +0100
>> +++ xfs/fs/xfs/xfs_dinode.h	2009-02-10 19:45:59.195068745 +0100
>> @@ -69,11 +69,32 @@ typedef struct xfs_dinode {
>>  
>>  	/* di_next_unlinked is the only non-core field in the old dinode */
>>  	__be32		di_next_unlinked;/* agi unlinked list ptr */
>> -} __attribute__((packed)) xfs_dinode_t;
>> +
>> +	/* start of the extended dinode, writable fields */
>> +	__be32		di_crc;		/* CRC of the inode */
>> +	__be64		di_changecount;	/* number of attribute changes */
>> +	__u8		di_pad2[16];	/* more padding for future expansion */
>> +
>> +	/* fields only written to during inode creation */
>> +	xfs_timestamp_t	di_crtime;	/* time created */
>> +	__be64		di_ino;		/* inode number */
>> +	uuid_t		di_uuid;	/* UUID of the filesystem */
>> +} xfs_dinode_t;
> 
> Hrm...removing the packed attribute... Eric, do you remember the ARM ABI
> alignment rules? Regardless of ARM, are those fields aligned nicely? (From a
> quick glance at the code looks ok.)

I'll just have to just test it again I suppose.  Removing packed is
good, as long as the padding makes it all come out right.

-=Eric




More information about the xfs mailing list