]> git.ipfire.org Git - thirdparty/xfsprogs-dev.git/commitdiff
xfs_db: convert directory parsing to use libxfs structure
authorDave Chinner <dchinner@redhat.com>
Fri, 7 Jun 2013 00:25:55 +0000 (10:25 +1000)
committerBen Myers <bpm@sgi.com>
Tue, 6 Aug 2013 20:36:39 +0000 (15:36 -0500)
xfs_db rolls it's own "opaque" directory types for the different
block formats. All it cares about is where the headers end and the
data starts, and none of the other details in the structures. Rather
than duplicate this for the dir3 format, we already have perfectly
good headers and abstraction functions for finding this information
in libxfs.  Using these means that the dir2 code used for printing
fields, metadump and check need to be modified to use libxfs
definitions.

Signed-off-by: Dave Chinner <dchinner@redhat.com>
Reviewed-by: Ben Myers <bpm@sgi.com>
Signed-off-by: Ben Myers <bpm@sgi.com>
db/check.c
db/dir2.c
db/dir2.h
db/dir2sf.c
db/metadump.c

index dadfa972714b84600fa7a740c74c29cd029b1b56..d490f81843bc1889d1ce15b770b7da71e5efc15c 100644 (file)
@@ -278,9 +278,9 @@ static xfs_ino_t    process_data_dir_v2(int *dot, int *dotdot,
                                            inodata_t *id, int v,
                                            xfs_dablk_t dabno,
                                            freetab_t **freetabp);
-static xfs_dir2_data_free_t
-                       *process_data_dir_v2_freefind(xfs_dir2_data_t *data,
-                                                  xfs_dir2_data_unused_t *dup);
+static xfs_dir2_data_free_t *process_data_dir_v2_freefind(
+                                       struct xfs_dir2_data_hdr *data,
+                                       struct xfs_dir2_data_unused *dup);
 static void            process_dir(xfs_dinode_t *dip, blkmap_t *blkmap,
                                    inodata_t *id);
 static int             process_dir_v2(xfs_dinode_t *dip, blkmap_t *blkmap,
@@ -2188,11 +2188,11 @@ process_data_dir_v2(
        xfs_dir2_dataptr_t      addr;
        xfs_dir2_data_free_t    *bf;
        int                     bf_err;
-       xfs_dir2_block_t        *block;
+       struct xfs_dir2_data_hdr *block;
        xfs_dir2_block_tail_t   *btp = NULL;
        inodata_t               *cid;
        int                     count;
-       xfs_dir2_data_t         *data;
+       struct xfs_dir2_data_hdr *data;
        xfs_dir2_db_t           db;
        xfs_dir2_data_entry_t   *dep;
        xfs_dir2_data_free_t    *dfp;
@@ -2214,20 +2214,20 @@ process_data_dir_v2(
 
        data = iocur_top->data;
        block = iocur_top->data;
-       if (be32_to_cpu(block->hdr.magic) != XFS_DIR2_BLOCK_MAGIC &&
-                       be32_to_cpu(data->hdr.magic) != XFS_DIR2_DATA_MAGIC) {
+       if (be32_to_cpu(block->magic) != XFS_DIR2_BLOCK_MAGIC &&
+                       be32_to_cpu(data->magic) != XFS_DIR2_DATA_MAGIC) {
                if (!sflag || v)
                        dbprintf(_("bad directory data magic # %#x for dir ino "
                                 "%lld block %d\n"),
-                               be32_to_cpu(data->hdr.magic), id->ino, dabno);
+                               be32_to_cpu(data->magic), id->ino, dabno);
                error++;
                return NULLFSINO;
        }
        db = xfs_dir2_da_to_db(mp, dabno);
-       bf = data->hdr.bestfree;
-       ptr = (char *)data->u;
-       if (be32_to_cpu(block->hdr.magic) == XFS_DIR2_BLOCK_MAGIC) {
-               btp = xfs_dir2_block_tail_p(mp, &block->hdr);
+       bf = xfs_dir3_data_bestfree_p(data);
+       ptr = (char *)xfs_dir3_data_unused_p(data);
+       if (be32_to_cpu(block->magic) == XFS_DIR2_BLOCK_MAGIC) {
+               btp = xfs_dir2_block_tail_p(mp, block);
                lep = xfs_dir2_block_leaf_p(btp);
                endptr = (char *)lep;
                if (endptr <= ptr || endptr > (char *)btp) {
@@ -2372,7 +2372,7 @@ process_data_dir_v2(
                        (*dot)++;
                }
        }
-       if (be32_to_cpu(data->hdr.magic) == XFS_DIR2_BLOCK_MAGIC) {
+       if (be32_to_cpu(data->magic) == XFS_DIR2_BLOCK_MAGIC) {
                endptr = (char *)data + mp->m_dirblksize;
                for (i = stale = 0; lep && i < be32_to_cpu(btp->count); i++) {
                        if ((char *)&lep[i] >= endptr) {
@@ -2404,9 +2404,8 @@ process_data_dir_v2(
                                id->ino, dabno);
                error++;
        }
-       if (be32_to_cpu(data->hdr.magic) == XFS_DIR2_BLOCK_MAGIC &&
-                               count != be32_to_cpu(btp->count) - 
-                                               be32_to_cpu(btp->stale)) {
+       if (be32_to_cpu(data->magic) == XFS_DIR2_BLOCK_MAGIC &&
+           count != be32_to_cpu(btp->count) - be32_to_cpu(btp->stale)) {
                if (!sflag || v)
                        dbprintf(_("dir %lld block %d bad block tail count %d "
                                 "(stale %d)\n"), 
@@ -2414,7 +2413,7 @@ process_data_dir_v2(
                                be32_to_cpu(btp->stale));
                error++;
        }
-       if (be32_to_cpu(data->hdr.magic) == XFS_DIR2_BLOCK_MAGIC && 
+       if (be32_to_cpu(data->magic) == XFS_DIR2_BLOCK_MAGIC && 
                                        stale != be32_to_cpu(btp->stale)) {
                if (!sflag || v)
                        dbprintf(_("dir %lld block %d bad stale tail count %d\n"),
@@ -2439,18 +2438,19 @@ process_data_dir_v2(
 
 static xfs_dir2_data_free_t *
 process_data_dir_v2_freefind(
-       xfs_dir2_data_t         *data,
+       struct xfs_dir2_data_hdr *data,
        xfs_dir2_data_unused_t  *dup)
 {
-       xfs_dir2_data_free_t    *dfp;
+       struct xfs_dir2_data_free *bf;
+       struct xfs_dir2_data_free *dfp;
        xfs_dir2_data_aoff_t    off;
 
        off = (xfs_dir2_data_aoff_t)((char *)dup - (char *)data);
-       if (be16_to_cpu(dup->length) < be16_to_cpu(data->hdr.
-                               bestfree[XFS_DIR2_DATA_FD_COUNT - 1].length))
+       bf = xfs_dir3_data_bestfree_p(data);
+       if (be16_to_cpu(dup->length) <
+                       be16_to_cpu(bf[XFS_DIR2_DATA_FD_COUNT - 1].length))
                return NULL;
-       for (dfp = &data->hdr.bestfree[0]; dfp < &data->hdr.
-                               bestfree[XFS_DIR2_DATA_FD_COUNT]; dfp++) {
+       for (dfp = bf; dfp < &bf[XFS_DIR2_DATA_FD_COUNT]; dfp++) {
                if (be16_to_cpu(dfp->offset) == 0)
                        return NULL;
                if (be16_to_cpu(dfp->offset) == off)
@@ -3421,20 +3421,20 @@ process_sf_dir_v2(
        int                     i8;
        xfs_ino_t               lino;
        int                     offset;
-       xfs_dir2_sf_t           *sf;
+       struct xfs_dir2_sf_hdr  *sf;
        xfs_dir2_sf_entry_t     *sfe;
        int                     v;
 
-       sf = (xfs_dir2_sf_t *)XFS_DFORK_DPTR(dip);
+       sf = (struct xfs_dir2_sf_hdr *)XFS_DFORK_DPTR(dip);
        addlink_inode(id);
        v = verbose || id->ilist;
        if (v)
                dbprintf(_("dir %lld entry . %lld\n"), id->ino, id->ino);
        (*dot)++;
-       sfe = xfs_dir2_sf_firstentry(&sf->hdr);
+       sfe = xfs_dir2_sf_firstentry(sf);
        offset = XFS_DIR3_DATA_FIRST_OFFSET(mp);
-       for (i = sf->hdr.count - 1, i8 = 0; i >= 0; i--) {
-               if ((__psint_t)sfe + xfs_dir2_sf_entsize(&sf->hdr,sfe->namelen) -
+       for (i = sf->count - 1, i8 = 0; i >= 0; i--) {
+               if ((__psint_t)sfe + xfs_dir2_sf_entsize(sf, sfe->namelen) -
                    (__psint_t)sf > be64_to_cpu(dip->di_size)) {
                        if (!sflag)
                                dbprintf(_("dir %llu bad size in entry at %d\n"),
@@ -3443,7 +3443,7 @@ process_sf_dir_v2(
                        error++;
                        break;
                }
-               lino = xfs_dir2_sfe_get_ino(&sf->hdr, sfe);
+               lino = xfs_dir2_sfe_get_ino(sf, sfe);
                if (lino > XFS_DIR2_MAX_SHORT_INUM)
                        i8++;
                cid = find_inode(lino, 1);
@@ -3473,8 +3473,8 @@ process_sf_dir_v2(
                }
                offset =
                        xfs_dir2_sf_get_offset(sfe) +
-                       xfs_dir2_sf_entsize(&sf->hdr, sfe->namelen);
-               sfe = xfs_dir2_sf_nextentry(&sf->hdr, sfe);
+                       xfs_dir2_sf_entsize(sf, sfe->namelen);
+               sfe = xfs_dir2_sf_nextentry(sf, sfe);
        }
        if (i < 0 && (__psint_t)sfe - (__psint_t)sf != 
                                        be64_to_cpu(dip->di_size)) {
@@ -3484,13 +3484,13 @@ process_sf_dir_v2(
                                (uint)((char *)sfe - (char *)sf));
                error++;
        }
-       if (offset + (sf->hdr.count + 2) * sizeof(xfs_dir2_leaf_entry_t) +
+       if (offset + (sf->count + 2) * sizeof(xfs_dir2_leaf_entry_t) +
            sizeof(xfs_dir2_block_tail_t) > mp->m_dirblksize) {
                if (!sflag)
                        dbprintf(_("dir %llu offsets too high\n"), id->ino);
                error++;
        }
-       lino = xfs_dir2_sf_get_parent_ino(&sf->hdr);
+       lino = xfs_dir2_sf_get_parent_ino(sf);
        if (lino > XFS_DIR2_MAX_SHORT_INUM)
                i8++;
        cid = find_inode(lino, 1);
@@ -3504,11 +3504,11 @@ process_sf_dir_v2(
        }
        if (v)
                dbprintf(_("dir %lld entry .. %lld\n"), id->ino, lino);
-       if (i8 != sf->hdr.i8count) {
+       if (i8 != sf->i8count) {
                if (!sflag)
                        dbprintf(_("dir %lld i8count mismatch is %d should be "
                                 "%d\n"),
-                               id->ino, sf->hdr.i8count, i8);
+                               id->ino, sf->i8count, i8);
                error++;
        }
        (*dotdot)++;
index 7094a837800ec95009e91dfc13d459ab5b0cc406..90378e6448365ea8235315dc9eb1c3aa36654fe1 100644 (file)
--- a/db/dir2.c
+++ b/db/dir2.c
@@ -58,13 +58,13 @@ const field_t       dir2_hfld[] = {
        { NULL }
 };
 
-#define        BOFF(f) bitize(offsetof(xfs_dir2_block_t, f))
-#define        DOFF(f) bitize(offsetof(xfs_dir2_data_t, f))
-#define        FOFF(f) bitize(offsetof(xfs_dir2_free_t, f))
-#define        LOFF(f) bitize(offsetof(xfs_dir2_leaf_t, f))
-#define        NOFF(f) bitize(offsetof(xfs_da_intnode_t, f))
+#define        BOFF(f) bitize(offsetof(struct xfs_dir2_data_hdr, f))
+#define        DOFF(f) bitize(offsetof(struct xfs_dir2_data_hdr, f))
+#define        FOFF(f) bitize(offsetof(struct xfs_dir2_free, f))
+#define        LOFF(f) bitize(offsetof(struct xfs_dir2_leaf, f))
+#define        NOFF(f) bitize(offsetof(struct xfs_da_intnode, f))
 const field_t  dir2_flds[] = {
-       { "bhdr", FLDT_DIR2_DATA_HDR, OI(BOFF(hdr)), dir2_block_hdr_count,
+       { "bhdr", FLDT_DIR2_DATA_HDR, OI(BOFF(magic)), dir2_block_hdr_count,
          FLD_COUNT, TYP_NONE },
        { "bu", FLDT_DIR2_DATA_UNION, dir2_block_u_offset, dir2_block_u_count,
          FLD_ARRAY|FLD_OFFSET|FLD_COUNT, TYP_NONE },
@@ -72,7 +72,7 @@ const field_t dir2_flds[] = {
          dir2_block_leaf_count, FLD_ARRAY|FLD_OFFSET|FLD_COUNT, TYP_NONE },
        { "btail", FLDT_DIR2_BLOCK_TAIL, dir2_block_tail_offset,
          dir2_block_tail_count, FLD_OFFSET|FLD_COUNT, TYP_NONE },
-       { "dhdr", FLDT_DIR2_DATA_HDR, OI(DOFF(hdr)), dir2_data_hdr_count,
+       { "dhdr", FLDT_DIR2_DATA_HDR, OI(DOFF(magic)), dir2_data_hdr_count,
          FLD_COUNT, TYP_NONE },
        { "du", FLDT_DIR2_DATA_UNION, dir2_data_u_offset, dir2_data_u_count,
          FLD_ARRAY|FLD_OFFSET|FLD_COUNT, TYP_NONE },
@@ -189,66 +189,62 @@ const field_t     da_node_hdr_flds[] = {
        { NULL }
 };
 
-/*ARGSUSED*/
 static int
 dir2_block_hdr_count(
        void                    *obj,
        int                     startoff)
 {
-       xfs_dir2_block_t        *block;
+       struct xfs_dir2_data_hdr *block;
 
        ASSERT(startoff == 0);
        block = obj;
-       return be32_to_cpu(block->hdr.magic) == XFS_DIR2_BLOCK_MAGIC;
+       return be32_to_cpu(block->magic) == XFS_DIR2_BLOCK_MAGIC;
 }
 
-/*ARGSUSED*/
 static int
 dir2_block_leaf_count(
        void                    *obj,
        int                     startoff)
 {
-       xfs_dir2_block_t        *block;
-       xfs_dir2_block_tail_t   *btp;
+       struct xfs_dir2_data_hdr *block;
+       struct xfs_dir2_block_tail *btp;
 
        ASSERT(startoff == 0);
        block = obj;
-       if (be32_to_cpu(block->hdr.magic) != XFS_DIR2_BLOCK_MAGIC)
+       if (be32_to_cpu(block->magic) != XFS_DIR2_BLOCK_MAGIC)
                return 0;
-       btp = xfs_dir2_block_tail_p(mp, &block->hdr);
+       btp = xfs_dir2_block_tail_p(mp, block);
        return be32_to_cpu(btp->count);
 }
 
-/*ARGSUSED*/
 static int
 dir2_block_leaf_offset(
        void                    *obj,
        int                     startoff,
        int                     idx)
 {
-       xfs_dir2_block_t        *block;
-       xfs_dir2_block_tail_t   *btp;
-       xfs_dir2_leaf_entry_t   *lep;
+       struct xfs_dir2_data_hdr *block;
+       struct xfs_dir2_block_tail *btp;
+       struct xfs_dir2_leaf_entry *lep;
 
        ASSERT(startoff == 0);
        block = obj;
-       ASSERT(be32_to_cpu(block->hdr.magic) == XFS_DIR2_BLOCK_MAGIC);
-       btp = xfs_dir2_block_tail_p(mp, &block->hdr);
+       ASSERT(be32_to_cpu(block->magic) == XFS_DIR2_BLOCK_MAGIC);
+       btp = xfs_dir2_block_tail_p(mp, block);
        lep = xfs_dir2_block_leaf_p(btp) + idx;
        return bitize((int)((char *)lep - (char *)block));
 }
 
-/*ARGSUSED*/
 static int
 dir2_block_tail_count(
        void                    *obj,
        int                     startoff)
 {
-       xfs_dir2_block_t        *block;
+       struct xfs_dir2_data_hdr *block;
 
        ASSERT(startoff == 0);
        block = obj;
-       return be32_to_cpu(block->hdr.magic) == XFS_DIR2_BLOCK_MAGIC;
+       return be32_to_cpu(block->magic) == XFS_DIR2_BLOCK_MAGIC;
 }
 
 /*ARGSUSED*/
@@ -258,14 +254,14 @@ dir2_block_tail_offset(
        int                     startoff,
        int                     idx)
 {
-       xfs_dir2_block_t        *block;
-       xfs_dir2_block_tail_t   *btp;
+       struct xfs_dir2_data_hdr *block;
+       struct xfs_dir2_block_tail *btp;
 
        ASSERT(startoff == 0);
        ASSERT(idx == 0);
        block = obj;
-       ASSERT(be32_to_cpu(block->hdr.magic) == XFS_DIR2_BLOCK_MAGIC);
-       btp = xfs_dir2_block_tail_p(mp, &block->hdr);
+       ASSERT(be32_to_cpu(block->magic) == XFS_DIR2_BLOCK_MAGIC);
+       btp = xfs_dir2_block_tail_p(mp, block);
        return bitize((int)((char *)btp - (char *)block));
 }
 
@@ -275,22 +271,23 @@ dir2_block_u_count(
        void                    *obj,
        int                     startoff)
 {
-       xfs_dir2_block_t        *block;
-       xfs_dir2_block_tail_t   *btp;
-       xfs_dir2_data_entry_t   *dep;
-       xfs_dir2_data_unused_t  *dup;
+       struct xfs_dir2_data_hdr *block;
+       struct xfs_dir2_block_tail *btp;
        char                    *endptr;
        int                     i;
        char                    *ptr;
 
        ASSERT(startoff == 0);
        block = obj;
-       if (be32_to_cpu(block->hdr.magic) != XFS_DIR2_BLOCK_MAGIC)
+       if (be32_to_cpu(block->magic) != XFS_DIR2_BLOCK_MAGIC)
                return 0;
-       btp = xfs_dir2_block_tail_p(mp, &block->hdr);
-       ptr = (char *)block->u;
+       btp = xfs_dir2_block_tail_p(mp, block);
+       ptr = (char *)xfs_dir3_data_unused_p(block);
        endptr = (char *)xfs_dir2_block_leaf_p(btp);
        for (i = 0; ptr < endptr; i++) {
+               struct xfs_dir2_data_entry *dep;
+               struct xfs_dir2_data_unused *dup;
+
                dup = (xfs_dir2_data_unused_t *)ptr;
                if (be16_to_cpu(dup->freetag) == XFS_DIR2_DATA_FREE_TAG)
                        ptr += be16_to_cpu(dup->length);
@@ -309,21 +306,22 @@ dir2_block_u_offset(
        int                     startoff,
        int                     idx)
 {
-       xfs_dir2_block_t        *block;
-       xfs_dir2_block_tail_t   *btp;
-       xfs_dir2_data_entry_t   *dep;
-       xfs_dir2_data_unused_t  *dup;
+       struct xfs_dir2_data_hdr *block;
+       struct xfs_dir2_block_tail *btp;
        char                    *endptr;
        int                     i;
        char                    *ptr;
 
        ASSERT(startoff == 0);
        block = obj;
-       ASSERT(be32_to_cpu(block->hdr.magic) == XFS_DIR2_BLOCK_MAGIC);
-       btp = xfs_dir2_block_tail_p(mp, &block->hdr);
-       ptr = (char *)block->u;
+       ASSERT(be32_to_cpu(block->magic) == XFS_DIR2_BLOCK_MAGIC);
+       btp = xfs_dir2_block_tail_p(mp, block);
+       ptr = (char *)xfs_dir3_data_unused_p(block);
        endptr = (char *)xfs_dir2_block_leaf_p(btp);
        for (i = 0; i < idx; i++) {
+               struct xfs_dir2_data_entry *dep;
+               struct xfs_dir2_data_unused *dup;
+
                ASSERT(ptr < endptr);
                dup = (xfs_dir2_data_unused_t *)ptr;
                if (be16_to_cpu(dup->freetag) == XFS_DIR2_DATA_FREE_TAG)
@@ -478,11 +476,11 @@ dir2_data_hdr_count(
        void                    *obj,
        int                     startoff)
 {
-       xfs_dir2_data_t         *data;
+       struct xfs_dir2_data_hdr *data;
 
        ASSERT(startoff == 0);
        data = obj;
-       return be32_to_cpu(data->hdr.magic) == XFS_DIR2_DATA_MAGIC;
+       return be32_to_cpu(data->magic) == XFS_DIR2_DATA_MAGIC;
 }
 
 /*ARGSUSED*/
@@ -491,20 +489,21 @@ dir2_data_u_count(
        void                    *obj,
        int                     startoff)
 {
-       xfs_dir2_data_t         *data;
-       xfs_dir2_data_entry_t   *dep;
-       xfs_dir2_data_unused_t  *dup;
+       struct xfs_dir2_data_hdr *data;
        char                    *endptr;
        int                     i;
        char                    *ptr;
 
        ASSERT(startoff == 0);
        data = obj;
-       if (be32_to_cpu(data->hdr.magic) != XFS_DIR2_DATA_MAGIC)
+       if (be32_to_cpu(data->magic) != XFS_DIR2_DATA_MAGIC)
                return 0;
-       ptr = (char *)data->u;
+       ptr = (char *)xfs_dir3_data_unused_p(data);
        endptr = (char *)data + mp->m_dirblksize;
        for (i = 0; ptr < endptr; i++) {
+               struct xfs_dir2_data_entry *dep;
+               struct xfs_dir2_data_unused *dup;
+
                dup = (xfs_dir2_data_unused_t *)ptr;
                if (be16_to_cpu(dup->freetag) == XFS_DIR2_DATA_FREE_TAG)
                        ptr += be16_to_cpu(dup->length);
@@ -523,20 +522,20 @@ dir2_data_u_offset(
        int                     startoff,
        int                     idx)
 {
-       xfs_dir2_data_t         *data;
-       xfs_dir2_data_entry_t   *dep;
-       xfs_dir2_data_unused_t  *dup;
-                               /*REFERENCED*/
+       struct xfs_dir2_data_hdr *data;
        char                    *endptr;
        int                     i;
        char                    *ptr;
 
        ASSERT(startoff == 0);
        data = obj;
-       ASSERT(be32_to_cpu(data->hdr.magic) == XFS_DIR2_DATA_MAGIC);
-       ptr = (char *)data->u;
+       ASSERT(be32_to_cpu(data->magic) == XFS_DIR2_DATA_MAGIC);
+       ptr = (char *)xfs_dir3_data_unused_p(data);
        endptr = (char *)data + mp->m_dirblksize;
        for (i = 0; i < idx; i++) {
+               struct xfs_dir2_data_entry *dep;
+               struct xfs_dir2_data_unused *dup;
+
                ASSERT(ptr < endptr);
                dup = (xfs_dir2_data_unused_t *)ptr;
                if (be16_to_cpu(dup->freetag) == XFS_DIR2_DATA_FREE_TAG)
@@ -576,7 +575,7 @@ dir2_free_bests_count(
        void                    *obj,
        int                     startoff)
 {
-       xfs_dir2_free_t         *free;
+       struct xfs_dir2_free    *free;
 
        ASSERT(startoff == 0);
        free = obj;
@@ -591,7 +590,7 @@ dir2_free_hdr_count(
        void                    *obj,
        int                     startoff)
 {
-       xfs_dir2_free_t         *free;
+       struct xfs_dir2_free    *free;
 
        ASSERT(startoff == 0);
        free = obj;
@@ -604,8 +603,8 @@ dir2_leaf_bests_count(
        void                    *obj,
        int                     startoff)
 {
-       xfs_dir2_leaf_t         *leaf;
-       xfs_dir2_leaf_tail_t    *ltp;
+       struct xfs_dir2_leaf    *leaf;
+       struct xfs_dir2_leaf_tail *ltp;
 
        ASSERT(startoff == 0);
        leaf = obj;
@@ -622,9 +621,9 @@ dir2_leaf_bests_offset(
        int                     startoff,
        int                     idx)
 {
+       struct xfs_dir2_leaf    *leaf;
+       struct xfs_dir2_leaf_tail *ltp;
        __be16                  *lbp;
-       xfs_dir2_leaf_t         *leaf;
-       xfs_dir2_leaf_tail_t    *ltp;
 
        ASSERT(startoff == 0);
        leaf = obj;
@@ -640,7 +639,7 @@ dir2_leaf_ents_count(
        void                    *obj,
        int                     startoff)
 {
-       xfs_dir2_leaf_t         *leaf;
+       struct xfs_dir2_leaf    *leaf;
 
        ASSERT(startoff == 0);
        leaf = obj;
@@ -656,7 +655,7 @@ dir2_leaf_hdr_count(
        void                    *obj,
        int                     startoff)
 {
-       xfs_dir2_leaf_t         *leaf;
+       struct xfs_dir2_leaf    *leaf;
 
        ASSERT(startoff == 0);
        leaf = obj;
@@ -670,7 +669,7 @@ dir2_leaf_tail_count(
        void                    *obj,
        int                     startoff)
 {
-       xfs_dir2_leaf_t         *leaf;
+       struct xfs_dir2_leaf    *leaf;
 
        ASSERT(startoff == 0);
        leaf = obj;
@@ -684,8 +683,8 @@ dir2_leaf_tail_offset(
        int                     startoff,
        int                     idx)
 {
-       xfs_dir2_leaf_t         *leaf;
-       xfs_dir2_leaf_tail_t    *ltp;
+       struct xfs_dir2_leaf    *leaf;
+       struct xfs_dir2_leaf_tail *ltp;
 
        ASSERT(startoff == 0);
        ASSERT(idx == 0);
@@ -716,7 +715,7 @@ dir2_node_hdr_count(
        void                    *obj,
        int                     startoff)
 {
-       xfs_da_intnode_t        *node;
+       struct xfs_da_intnode   *node;
 
        ASSERT(startoff == 0);
        node = obj;
index a5f0bec97b991397ebd85a33dfb0e24c0683f234..05ab354a6f3981c7728391f5cdc26d49ab93dd31 100644 (file)
--- a/db/dir2.h
+++ b/db/dir2.h
@@ -31,31 +31,6 @@ extern const field_t da_blkinfo_flds[];
 extern const field_t   da_node_entry_flds[];
 extern const field_t   da_node_hdr_flds[];
 
-/*
- * generic dir2 structures used by xfs_db
- */
-typedef union {
-       xfs_dir2_data_entry_t   entry;
-       xfs_dir2_data_unused_t  unused;
-} xfs_dir2_data_union_t;
-
-typedef struct xfs_dir2_data {
-       xfs_dir2_data_hdr_t     hdr;            /* magic XFS_DIR2_DATA_MAGIC */
-       xfs_dir2_data_union_t   u[1];
-} xfs_dir2_data_t;
-
-typedef struct xfs_dir2_block {
-       xfs_dir2_data_hdr_t     hdr;            /* magic XFS_DIR2_BLOCK_MAGIC */
-       xfs_dir2_data_union_t   u[1];
-       xfs_dir2_leaf_entry_t   leaf[1];
-       xfs_dir2_block_tail_t   tail;
-} xfs_dir2_block_t;
-
-typedef struct xfs_dir2_sf {
-       xfs_dir2_sf_hdr_t       hdr;            /* shortform header */
-       xfs_dir2_sf_entry_t     list[1];        /* shortform entries */
-} xfs_dir2_sf_t;
-
 static inline xfs_dir2_inou_t *xfs_dir2_sf_inumberp(xfs_dir2_sf_entry_t *sfep)
 {
        return (xfs_dir2_inou_t *)&(sfep)->name[(sfep)->namelen];
index 271e08a11f51d067c0dc0fc011db7be47f8e7475..b32ca32086f1a2e7a6da50a8da4496ff4b9d5066 100644 (file)
@@ -32,9 +32,9 @@ static int    dir2_sf_entry_name_count(void *obj, int startoff);
 static int     dir2_sf_list_count(void *obj, int startoff);
 static int     dir2_sf_list_offset(void *obj, int startoff, int idx);
 
-#define        OFF(f)  bitize(offsetof(xfs_dir2_sf_t, f))
+#define        OFF(f)  bitize(offsetof(struct xfs_dir2_sf_hdr, f))
 const field_t  dir2sf_flds[] = {
-       { "hdr", FLDT_DIR2_SF_HDR, OI(OFF(hdr)), C1, 0, TYP_NONE },
+       { "hdr", FLDT_DIR2_SF_HDR, OI(OFF(count)), C1, 0, TYP_NONE },
        { "list", FLDT_DIR2_SF_ENTRY, dir2_sf_list_offset, dir2_sf_list_count,
          FLD_ARRAY|FLD_COUNT|FLD_OFFSET, TYP_NONE },
        { NULL }
@@ -75,11 +75,11 @@ dir2_inou_i4_count(
        int             startoff)
 {
        struct xfs_dinode *dip = obj;
-       xfs_dir2_sf_t   *sf;
+       struct xfs_dir2_sf_hdr  *sf;
 
        ASSERT(bitoffs(startoff) == 0);
-       sf = (xfs_dir2_sf_t *)XFS_DFORK_DPTR(dip);
-       return sf->hdr.i8count == 0;
+       sf = (struct xfs_dir2_sf_hdr *)XFS_DFORK_DPTR(dip);
+       return sf->i8count == 0;
 }
 
 /*ARGSUSED*/
@@ -89,11 +89,11 @@ dir2_inou_i8_count(
        int             startoff)
 {
        struct xfs_dinode *dip = obj;
-       xfs_dir2_sf_t   *sf;
+       struct xfs_dir2_sf_hdr  *sf;
 
        ASSERT(bitoffs(startoff) == 0);
-       sf = (xfs_dir2_sf_t *)XFS_DFORK_DPTR(dip);
-       return sf->hdr.i8count != 0;
+       sf = (struct xfs_dir2_sf_hdr *)XFS_DFORK_DPTR(dip);
+       return sf->i8count != 0;
 }
 
 /*ARGSUSED*/
@@ -104,12 +104,12 @@ dir2_inou_size(
        int             idx)
 {
        struct xfs_dinode *dip = obj;
-       xfs_dir2_sf_t   *sf;
+       struct xfs_dir2_sf_hdr  *sf;
 
        ASSERT(bitoffs(startoff) == 0);
        ASSERT(idx == 0);
-       sf = (xfs_dir2_sf_t *)XFS_DFORK_DPTR(dip);
-       return bitize(sf->hdr.i8count ?
+       sf = (struct xfs_dir2_sf_hdr *)XFS_DFORK_DPTR(dip);
+       return bitize(sf->i8count ?
                      (uint)sizeof(xfs_dir2_ino8_t) :
                      (uint)sizeof(xfs_dir2_ino4_t));
 }
@@ -149,14 +149,14 @@ dir2_sf_entry_size(
 {
        xfs_dir2_sf_entry_t     *e;
        int                     i;
-       xfs_dir2_sf_t           *sf;
+       struct xfs_dir2_sf_hdr  *sf;
 
        ASSERT(bitoffs(startoff) == 0);
-       sf = (xfs_dir2_sf_t *)((char *)obj + byteize(startoff));
-       e = xfs_dir2_sf_firstentry(&sf->hdr);
+       sf = (struct xfs_dir2_sf_hdr *)((char *)obj + byteize(startoff));
+       e = xfs_dir2_sf_firstentry(sf);
        for (i = 0; i < idx; i++)
-               e = xfs_dir2_sf_nextentry(&sf->hdr, e);
-       return bitize((int)xfs_dir2_sf_entsize(&sf->hdr, e->namelen));
+               e = xfs_dir2_sf_nextentry(sf, e);
+       return bitize((int)xfs_dir2_sf_entsize(sf, e->namelen));
 }
 
 /*ARGSUSED*/
@@ -166,12 +166,12 @@ dir2_sf_hdr_size(
        int             startoff,
        int             idx)
 {
-       xfs_dir2_sf_t   *sf;
+       struct xfs_dir2_sf_hdr  *sf;
 
        ASSERT(bitoffs(startoff) == 0);
        ASSERT(idx == 0);
-       sf = (xfs_dir2_sf_t *)((char *)obj + byteize(startoff));
-       return bitize(xfs_dir2_sf_hdr_size(sf->hdr.i8count));
+       sf = (struct xfs_dir2_sf_hdr *)((char *)obj + byteize(startoff));
+       return bitize(xfs_dir2_sf_hdr_size(sf->i8count));
 }
 
 static int
@@ -179,11 +179,11 @@ dir2_sf_list_count(
        void                    *obj,
        int                     startoff)
 {
-       xfs_dir2_sf_t           *sf;
+       struct xfs_dir2_sf_hdr  *sf;
 
        ASSERT(bitoffs(startoff) == 0);
-       sf = (xfs_dir2_sf_t *)((char *)obj + byteize(startoff));
-       return sf->hdr.count;
+       sf = (struct xfs_dir2_sf_hdr *)((char *)obj + byteize(startoff));
+       return sf->count;
 }
 
 static int
@@ -194,13 +194,13 @@ dir2_sf_list_offset(
 {
        xfs_dir2_sf_entry_t     *e;
        int                     i;
-       xfs_dir2_sf_t           *sf;
+       struct xfs_dir2_sf_hdr  *sf;
 
        ASSERT(bitoffs(startoff) == 0);
-       sf = (xfs_dir2_sf_t *)((char *)obj + byteize(startoff));
-       e = xfs_dir2_sf_firstentry(&sf->hdr);
+       sf = (struct xfs_dir2_sf_hdr *)((char *)obj + byteize(startoff));
+       e = xfs_dir2_sf_firstentry(sf);
        for (i = 0; i < idx; i++)
-               e = xfs_dir2_sf_nextentry(&sf->hdr, e);
+               e = xfs_dir2_sf_nextentry(sf, e);
        return bitize((int)((char *)e - (char *)sf));
 }
 
@@ -213,13 +213,13 @@ dir2sf_size(
 {
        xfs_dir2_sf_entry_t     *e;
        int                     i;
-       xfs_dir2_sf_t           *sf;
+       struct xfs_dir2_sf_hdr  *sf;
 
        ASSERT(bitoffs(startoff) == 0);
        ASSERT(idx == 0);
-       sf = (xfs_dir2_sf_t *)((char *)obj + byteize(startoff));
-       e = xfs_dir2_sf_firstentry(&sf->hdr);
-       for (i = 0; i < sf->hdr.count; i++)
-               e = xfs_dir2_sf_nextentry(&sf->hdr, e);
+       sf = (struct xfs_dir2_sf_hdr *)((char *)obj + byteize(startoff));
+       e = xfs_dir2_sf_firstentry(sf);
+       for (i = 0; i < sf->count; i++)
+               e = xfs_dir2_sf_nextentry(sf, e);
        return bitize((int)((char *)e - (char *)sf));
 }
index 44e7162abbeccbde72fc26033801ca64894f326f..bc1c7faab6e69c5007a4809f29c4aca74a3396d8 100644 (file)
@@ -906,12 +906,12 @@ static void
 obfuscate_sf_dir(
        xfs_dinode_t            *dip)
 {
-       xfs_dir2_sf_t           *sfp;
+       struct xfs_dir2_sf_hdr  *sfp;
        xfs_dir2_sf_entry_t     *sfep;
        __uint64_t              ino_dir_size;
        int                     i;
 
-       sfp = (xfs_dir2_sf_t *)XFS_DFORK_DPTR(dip);
+       sfp = (struct xfs_dir2_sf_hdr *)XFS_DFORK_DPTR(dip);
        ino_dir_size = be64_to_cpu(dip->di_size);
        if (ino_dir_size > XFS_DFORK_DSIZE(dip, mp)) {
                ino_dir_size = XFS_DFORK_DSIZE(dip, mp);
@@ -920,8 +920,8 @@ obfuscate_sf_dir(
                                        (long long)cur_ino);
        }
 
-       sfep = xfs_dir2_sf_firstentry(&sfp->hdr);
-       for (i = 0; (i < sfp->hdr.count) &&
+       sfep = xfs_dir2_sf_firstentry(sfp);
+       for (i = 0; (i < sfp->count) &&
                        ((char *)sfep - (char *)sfp < ino_dir_size); i++) {
 
                /*
@@ -934,27 +934,27 @@ obfuscate_sf_dir(
                        if (show_warnings)
                                print_warning("zero length entry in dir inode "
                                                "%llu", (long long)cur_ino);
-                       if (i != sfp->hdr.count - 1)
+                       if (i != sfp->count - 1)
                                break;
                        namelen = ino_dir_size - ((char *)&sfep->name[0] -
                                         (char *)sfp);
                } else if ((char *)sfep - (char *)sfp +
-                               xfs_dir2_sf_entsize(&sfp->hdr, sfep->namelen) >
+                               xfs_dir2_sf_entsize(sfp, sfep->namelen) >
                                ino_dir_size) {
                        if (show_warnings)
                                print_warning("entry length in dir inode %llu "
                                        "overflows space", (long long)cur_ino);
-                       if (i != sfp->hdr.count - 1)
+                       if (i != sfp->count - 1)
                                break;
                        namelen = ino_dir_size - ((char *)&sfep->name[0] -
                                         (char *)sfp);
                }
 
-               generate_obfuscated_name(xfs_dir2_sfe_get_ino(&sfp->hdr, sfep),
+               generate_obfuscated_name(xfs_dir2_sfe_get_ino(sfp, sfep),
                                         namelen, &sfep->name[0]);
 
                sfep = (xfs_dir2_sf_entry_t *)((char *)sfep +
-                               xfs_dir2_sf_entsize(&sfp->hdr, namelen));
+                               xfs_dir2_sf_entsize(sfp, namelen));
        }
 }
 
@@ -1101,6 +1101,9 @@ obfuscate_dir_data_blocks(
 
                if (dir_data.block_index == 0) {
                        int             wantmagic;
+                       struct xfs_dir2_data_hdr *datahdr;
+
+                       datahdr = (struct xfs_dir2_data_hdr *)block;
 
                        if (offset % mp->m_dirblkfsbs != 0)
                                return; /* corrupted, leave it alone */
@@ -1110,10 +1113,8 @@ obfuscate_dir_data_blocks(
                        if (is_block_format) {
                                xfs_dir2_leaf_entry_t   *blp;
                                xfs_dir2_block_tail_t   *btp;
-                               xfs_dir2_block_t        *blk;
 
-                               blk = (xfs_dir2_block_t *)block;
-                               btp = xfs_dir2_block_tail_p(mp, &blk->hdr);
+                               btp = xfs_dir2_block_tail_p(mp, datahdr);
                                blp = xfs_dir2_block_leaf_p(btp);
                                if ((char *)blp > (char *)btp)
                                        blp = (xfs_dir2_leaf_entry_t *)btp;
@@ -1125,10 +1126,10 @@ obfuscate_dir_data_blocks(
                                                mp->m_sb.sb_blocklog;
                                wantmagic = XFS_DIR2_DATA_MAGIC;
                        }
-                       dir_data.offset_to_entry = offsetof(xfs_dir2_data_t, u);
+                       dir_data.offset_to_entry =
+                                       xfs_dir3_data_entry_offset(datahdr);
 
-                       if (be32_to_cpu(((xfs_dir2_data_hdr_t*)block)->magic) !=
-                                       wantmagic) {
+                       if (be32_to_cpu(datahdr->magic) != wantmagic) {
                                if (show_warnings)
                                        print_warning("invalid magic in dir "
                                                "inode %llu block %ld",