xfs_fileoff_t           del_endoff, got_endoff;
        xfs_filblks_t           got_indlen, new_indlen, stolen;
        uint32_t                state = xfs_bmap_fork_to_state(whichfork);
+       uint64_t                fdblocks;
        int                     error = 0;
        bool                    isrt;
 
        ASSERT(got->br_startoff <= del->br_startoff);
        ASSERT(got_endoff >= del_endoff);
 
-       if (isrt)
-               xfs_add_frextents(mp, xfs_rtb_to_rtx(mp, del->br_blockcount));
-
        /*
         * Update the inode delalloc counter now and wait to update the
         * sb counters as we might have to borrow some blocks for the
         * indirect block accounting.
         */
-       ASSERT(!isrt);
        error = xfs_quota_unreserve_blkres(ip, del->br_blockcount);
        if (error)
                return error;
 
        ASSERT(da_old >= da_new);
        da_diff = da_old - da_new;
-       if (!isrt)
-               da_diff += del->br_blockcount;
-       if (da_diff) {
-               xfs_add_fdblocks(mp, da_diff);
-               xfs_mod_delalloc(mp, -da_diff);
-       }
+       fdblocks = da_diff;
+
+       if (isrt)
+               xfs_add_frextents(mp, xfs_rtb_to_rtx(mp, del->br_blockcount));
+       else
+               fdblocks += del->br_blockcount;
+
+       xfs_add_fdblocks(mp, fdblocks);
+       xfs_mod_delalloc(mp, -(int64_t)fdblocks);
        return error;
 }