X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;ds=sidebyside;f=fs%2Fjfs%2Fjfs_dmap.h;h=32e25884e7e84ca44113192b52bf4691c5c2c6e4;hb=6a77f38946aaee1cd85eeec6cf4229b204c15071;hp=9599b9ff109d0cebffb010e1519adb44ca2d982b;hpb=5273a3df6485dc2ad6aa7ddd441b9a21970f003b;p=linux-2.6.git diff --git a/fs/jfs/jfs_dmap.h b/fs/jfs/jfs_dmap.h index 9599b9ff1..32e25884e 100644 --- a/fs/jfs/jfs_dmap.h +++ b/fs/jfs/jfs_dmap.h @@ -145,10 +145,10 @@ static __inline signed char TREEMAX(signed char *cp) * dmaptree must be consistent with dmapctl. */ struct dmaptree { - s32 nleafs; /* 4: number of tree leafs */ - s32 l2nleafs; /* 4: l2 number of tree leafs */ - s32 leafidx; /* 4: index of first tree leaf */ - s32 height; /* 4: height of the tree */ + __le32 nleafs; /* 4: number of tree leafs */ + __le32 l2nleafs; /* 4: l2 number of tree leafs */ + __le32 leafidx; /* 4: index of first tree leaf */ + __le32 height; /* 4: height of the tree */ s8 budmin; /* 1: min l2 tree leaf value to combine */ s8 stree[TREESIZE]; /* TREESIZE: tree */ u8 pad[2]; /* 2: pad to word boundary */ @@ -158,13 +158,13 @@ struct dmaptree { * dmap page per 8K blocks bitmap */ struct dmap { - s32 nblocks; /* 4: num blks covered by this dmap */ - s32 nfree; /* 4: num of free blks in this dmap */ - s64 start; /* 8: starting blkno for this dmap */ + __le32 nblocks; /* 4: num blks covered by this dmap */ + __le32 nfree; /* 4: num of free blks in this dmap */ + __le64 start; /* 8: starting blkno for this dmap */ struct dmaptree tree; /* 360: dmap tree */ u8 pad[1672]; /* 1672: pad to 2048 bytes */ - u32 wmap[LPERDMAP]; /* 1024: bits of the working map */ - u32 pmap[LPERDMAP]; /* 1024: bits of the persistent map */ + __le32 wmap[LPERDMAP]; /* 1024: bits of the working map */ + __le32 pmap[LPERDMAP]; /* 1024: bits of the persistent map */ }; /* - 4096 - */ /* @@ -173,10 +173,10 @@ struct dmap { * dmapctl must be consistent with dmaptree. */ struct dmapctl { - s32 nleafs; /* 4: number of tree leafs */ - s32 l2nleafs; /* 4: l2 number of tree leafs */ - s32 leafidx; /* 4: index of the first tree leaf */ - s32 height; /* 4: height of tree */ + __le32 nleafs; /* 4: number of tree leafs */ + __le32 l2nleafs; /* 4: l2 number of tree leafs */ + __le32 leafidx; /* 4: index of the first tree leaf */ + __le32 height; /* 4: height of tree */ s8 budmin; /* 1: minimum l2 tree leaf value */ s8 stree[CTLTREESIZE]; /* CTLTREESIZE: dmapctl tree */ u8 pad[2714]; /* 2714: pad to 4096 */ @@ -201,30 +201,47 @@ typedef union dmtree { /* * on-disk aggregate disk allocation map descriptor. */ -struct dbmap { - s64 dn_mapsize; /* 8: number of blocks in aggregate */ - s64 dn_nfree; /* 8: num free blks in aggregate map */ - s32 dn_l2nbperpage; /* 4: number of blks per page */ - s32 dn_numag; /* 4: total number of ags */ - s32 dn_maxlevel; /* 4: number of active ags */ - s32 dn_maxag; /* 4: max active alloc group number */ - s32 dn_agpref; /* 4: preferred alloc group (hint) */ - s32 dn_aglevel; /* 4: dmapctl level holding the AG */ - s32 dn_agheigth; /* 4: height in dmapctl of the AG */ - s32 dn_agwidth; /* 4: width in dmapctl of the AG */ - s32 dn_agstart; /* 4: start tree index at AG height */ - s32 dn_agl2size; /* 4: l2 num of blks per alloc group */ - s64 dn_agfree[MAXAG]; /* 8*MAXAG: per AG free count */ - s64 dn_agsize; /* 8: num of blks per alloc group */ +struct dbmap_disk { + __le64 dn_mapsize; /* 8: number of blocks in aggregate */ + __le64 dn_nfree; /* 8: num free blks in aggregate map */ + __le32 dn_l2nbperpage; /* 4: number of blks per page */ + __le32 dn_numag; /* 4: total number of ags */ + __le32 dn_maxlevel; /* 4: number of active ags */ + __le32 dn_maxag; /* 4: max active alloc group number */ + __le32 dn_agpref; /* 4: preferred alloc group (hint) */ + __le32 dn_aglevel; /* 4: dmapctl level holding the AG */ + __le32 dn_agheigth; /* 4: height in dmapctl of the AG */ + __le32 dn_agwidth; /* 4: width in dmapctl of the AG */ + __le32 dn_agstart; /* 4: start tree index at AG height */ + __le32 dn_agl2size; /* 4: l2 num of blks per alloc group */ + __le64 dn_agfree[MAXAG];/* 8*MAXAG: per AG free count */ + __le64 dn_agsize; /* 8: num of blks per alloc group */ s8 dn_maxfreebud; /* 1: max free buddy system */ u8 pad[3007]; /* 3007: pad to 4096 */ }; /* - 4096 - */ +struct dbmap { + s64 dn_mapsize; /* number of blocks in aggregate */ + s64 dn_nfree; /* num free blks in aggregate map */ + int dn_l2nbperpage; /* number of blks per page */ + int dn_numag; /* total number of ags */ + int dn_maxlevel; /* number of active ags */ + int dn_maxag; /* max active alloc group number */ + int dn_agpref; /* preferred alloc group (hint) */ + int dn_aglevel; /* dmapctl level holding the AG */ + int dn_agheigth; /* height in dmapctl of the AG */ + int dn_agwidth; /* width in dmapctl of the AG */ + int dn_agstart; /* start tree index at AG height */ + int dn_agl2size; /* l2 num of blks per alloc group */ + s64 dn_agfree[MAXAG]; /* per AG free count */ + s64 dn_agsize; /* num of blks per alloc group */ + signed char dn_maxfreebud; /* max free buddy system */ +}; /* - 4096 - */ /* * in-memory aggregate disk allocation map descriptor. */ struct bmap { - struct dbmap db_bmap; /* on-disk aggregate map descriptor */ + struct dbmap db_bmap; /* on-disk aggregate map descriptor */ struct inode *db_ipbmap; /* ptr to aggregate map incore inode */ struct semaphore db_bmaplock; /* aggregate map lock */ atomic_t db_active[MAXAG]; /* count of active, open files in AG */