static int             sbver_err;
 static int             serious_error;
 static int             sflag;
-static xfs_suminfo_t   *sumcompute;
-static xfs_suminfo_t   *sumfile;
+static union xfs_suminfo_raw *sumcompute;
+static union xfs_suminfo_raw *sumfile;
 static const char      *typename[] = {
        "unknown",
        "agf",
        }
 }
 
+static inline xfs_suminfo_t
+get_suminfo(
+       struct xfs_mount        *mp,
+       union xfs_suminfo_raw   *raw)
+{
+       return raw->old;
+}
+
 static void
 check_summary(void)
 {
        xfs_rfsblock_t  bno;
-       xfs_suminfo_t   *csp;
-       xfs_suminfo_t   *fsp;
+       union xfs_suminfo_raw *csp;
+       union xfs_suminfo_raw *fsp;
        int             log;
 
        csp = sumcompute;
                for (bno = 0;
                     bno < mp->m_sb.sb_rbmblocks;
                     bno++, csp++, fsp++) {
-                       if (*csp != *fsp) {
+                       if (csp->old != fsp->old) {
                                if (!sflag)
                                        dbprintf(_("rt summary mismatch, size %d "
                                                 "block %llu, file: %d, "
                                                 "computed: %d\n"),
-                                               log, bno, *fsp, *csp);
+                                               log, bno,
+                                               get_suminfo(mp, fsp),
+                                               get_suminfo(mp, csp));
                                error++;
                        }
                }
                inomap[c] = xcalloc(mp->m_sb.sb_rblocks, sizeof(**inomap));
                words = libxfs_rtsummary_wordcount(mp, mp->m_rsumlevels,
                                mp->m_sb.sb_rbmblocks);
-               sumfile = xcalloc(words, sizeof(xfs_suminfo_t));
-               sumcompute = xcalloc(words, sizeof(xfs_suminfo_t));
+               sumfile = xcalloc(words, sizeof(union xfs_suminfo_raw));
+               sumcompute = xcalloc(words, sizeof(union xfs_suminfo_raw));
        }
        nflag = sflag = tflag = verbose = optind = 0;
        while ((c = getopt(argc, argv, "b:i:npstv")) != EOF) {
        }
 }
 
+static inline void
+inc_sumcount(
+       struct xfs_mount        *mp,
+       union xfs_suminfo_raw   *info,
+       xfs_rtsumoff_t          index)
+{
+       union xfs_suminfo_raw   *p = info + index;
+
+       p->old++;
+}
+
 static void
 process_rtbitmap(
        blkmap_t        *blkmap)
                                        bitsperblock + (bit - start_bit);
                                log = XFS_RTBLOCKLOG(len);
                                offs = xfs_rtsumoffs(mp, log, start_bmbno);
-                               sumcompute[offs]++;
+                               inc_sumcount(mp, sumcompute, offs);
                                prevbit = 0;
                        }
                }
                        (bit - start_bit);
                log = XFS_RTBLOCKLOG(len);
                offs = xfs_rtsumoffs(mp, log, start_bmbno);
-               sumcompute[offs]++;
+               inc_sumcount(mp, sumcompute, offs);
        }
        free(words);
 }
        blkmap_t        *blkmap)
 {
        xfs_fsblock_t   bno;
-       char            *bytes;
+       union xfs_suminfo_raw *sfile = sumfile;
        xfs_fileoff_t   sumbno;
        int             t;
 
        sumbno = NULLFILEOFF;
        while ((sumbno = blkmap_next_off(blkmap, sumbno, &t)) != NULLFILEOFF) {
+               struct xfs_rtalloc_args args = {
+                       .mp             = mp,
+               };
+               union xfs_suminfo_raw   *ondisk;
+
                bno = blkmap_get(blkmap, sumbno);
                if (bno == NULLFSBLOCK) {
                        if (!sflag)
                push_cur();
                set_cur(&typtab[TYP_RTSUMMARY], XFS_FSB_TO_DADDR(mp, bno),
                        blkbb, DB_RING_IGN, NULL);
-               if ((bytes = iocur_top->data) == NULL) {
+               if (!iocur_top->bp) {
                        if (!sflag)
                                dbprintf(_("can't read block %lld for rtsummary "
                                         "inode\n"),
                                        (xfs_fileoff_t)sumbno);
                        error++;
                        pop_cur();
+                       sfile += mp->m_blockwsize;
                        continue;
                }
-               memcpy((char *)sumfile + sumbno * mp->m_sb.sb_blocksize, bytes,
-                       mp->m_sb.sb_blocksize);
+
+               args.sumbp = iocur_top->bp;
+               ondisk = xfs_rsumblock_infoptr(&args, 0);
+               memcpy(sfile, ondisk, mp->m_sb.sb_blocksize);
                pop_cur();
+               sfile += mp->m_blockwsize;
        }
 }
 
 
        struct xfs_buf  *bp;
        xfs_trans_t     *tp;
        xfs_inode_t     *ip;
-       xfs_suminfo_t   *smp;
+       union xfs_suminfo_raw *smp;
        int             nmap;
        int             error;
        xfs_fileoff_t   bno;
        }
 
        while (bno < end_bno)  {
+               struct xfs_rtalloc_args args = {
+                       .mp             = mp,
+                       .tp             = tp,
+               };
+               union xfs_suminfo_raw   *ondisk;
+
                /*
                 * fill the file one block at a time
                 */
                        return(1);
                }
 
-               memmove(bp->b_addr, smp, mp->m_sb.sb_blocksize);
+               args.sumbp = bp;
+               ondisk = xfs_rsumblock_infoptr(&args, 0);
+               memcpy(ondisk, smp, mp->m_sb.sb_blocksize);
 
                libxfs_trans_log_buf(tp, bp, 0, mp->m_sb.sb_blocksize - 1);
 
-               smp = (xfs_suminfo_t *)((intptr_t)smp + mp->m_sb.sb_blocksize);
+               smp += mp->m_blockwsize;
                bno++;
        }
 
 
 
        wordcnt = libxfs_rtsummary_wordcount(mp, mp->m_rsumlevels,
                        mp->m_sb.sb_rbmblocks);
-       sumcompute = calloc(wordcnt, sizeof(xfs_suminfo_t));
+       sumcompute = calloc(wordcnt, sizeof(union xfs_suminfo_raw));
        if (!sumcompute)
                do_error(
        _("couldn't allocate memory for incore realtime summary info.\n"));
        word->old = value;
 }
 
+static inline void
+inc_sumcount(
+       struct xfs_mount        *mp,
+       union xfs_suminfo_raw   *info,
+       xfs_rtsumoff_t          index)
+{
+       union xfs_suminfo_raw   *p = info + index;
+
+       p->old++;
+}
+
 /*
  * generate the real-time bitmap and summary info based on the
  * incore realtime extent map.
 generate_rtinfo(
        struct xfs_mount        *mp,
        union xfs_rtword_raw    *words,
-       xfs_suminfo_t           *sumcompute)
+       union xfs_suminfo_raw   *sumcompute)
 {
        xfs_rtxnum_t    extno;
        xfs_rtxnum_t    start_ext;
                                len = (int) (extno - start_ext);
                                log = XFS_RTBLOCKLOG(len);
                                offs = xfs_rtsumoffs(mp, log, start_bmbno);
-                               sumcompute[offs]++;
+                               inc_sumcount(mp, sumcompute, offs);
                                in_extent = 0;
                        }
 
                len = (int) (extno - start_ext);
                log = XFS_RTBLOCKLOG(len);
                offs = xfs_rtsumoffs(mp, log, start_bmbno);
-               sumcompute[offs]++;
+               inc_sumcount(mp, sumcompute, offs);
        }
 
        if (mp->m_sb.sb_frextents != sb_frextents) {