Commit 906abed5 authored by Christoph Hellwig's avatar Christoph Hellwig Committed by Darrick J. Wong

xfs: iterate over extents in xfs_bmap_extents_to_btree

This actually makes the function very slightly less efficient for now as we
detour through the expanded irect format between the in-core extent format
and the on-disk one instead of just endian swapping them.  But with the
incore extent btree the in-core one will use a different format and the
representation will be entirely hidden.
Signed-off-by: default avatarChristoph Hellwig <hch@lst.de>
Reviewed-by: default avatarBrian Foster <bfoster@redhat.com>
Reviewed-by: default avatarDarrick J. Wong <darrick.wong@oracle.com>
Signed-off-by: default avatarDarrick J. Wong <darrick.wong@oracle.com>
parent 71565f4b
...@@ -667,14 +667,13 @@ xfs_bmap_extents_to_btree( ...@@ -667,14 +667,13 @@ xfs_bmap_extents_to_btree(
xfs_bmbt_rec_t *arp; /* child record pointer */ xfs_bmbt_rec_t *arp; /* child record pointer */
struct xfs_btree_block *block; /* btree root block */ struct xfs_btree_block *block; /* btree root block */
xfs_btree_cur_t *cur; /* bmap btree cursor */ xfs_btree_cur_t *cur; /* bmap btree cursor */
xfs_bmbt_rec_host_t *ep; /* extent record pointer */
int error; /* error return value */ int error; /* error return value */
xfs_extnum_t i, cnt; /* extent record index */
xfs_ifork_t *ifp; /* inode fork pointer */ xfs_ifork_t *ifp; /* inode fork pointer */
xfs_bmbt_key_t *kp; /* root block key pointer */ xfs_bmbt_key_t *kp; /* root block key pointer */
xfs_mount_t *mp; /* mount structure */ xfs_mount_t *mp; /* mount structure */
xfs_extnum_t nextents; /* number of file extents */
xfs_bmbt_ptr_t *pp; /* root block address pointer */ xfs_bmbt_ptr_t *pp; /* root block address pointer */
struct xfs_bmbt_irec rec;
xfs_extnum_t i = 0, cnt = 0;
mp = ip->i_mount; mp = ip->i_mount;
ASSERT(whichfork != XFS_COW_FORK); ASSERT(whichfork != XFS_COW_FORK);
...@@ -753,15 +752,12 @@ xfs_bmap_extents_to_btree( ...@@ -753,15 +752,12 @@ xfs_bmap_extents_to_btree(
XFS_BTNUM_BMAP, 0, 0, ip->i_ino, XFS_BTNUM_BMAP, 0, 0, ip->i_ino,
XFS_BTREE_LONG_PTRS); XFS_BTREE_LONG_PTRS);
arp = XFS_BMBT_REC_ADDR(mp, ablock, 1); while (xfs_iext_get_extent(ifp, i++, &rec)) {
nextents = xfs_iext_count(ifp); if (isnullstartblock(rec.br_startblock))
for (cnt = i = 0; i < nextents; i++) { continue;
ep = xfs_iext_get_ext(ifp, i); arp = XFS_BMBT_REC_ADDR(mp, ablock, 1 + cnt);
if (!isnullstartblock(xfs_bmbt_get_startblock(ep))) { xfs_bmbt_disk_set_all(arp, &rec);
arp->l0 = cpu_to_be64(ep->l0); cnt++;
arp->l1 = cpu_to_be64(ep->l1);
arp++; cnt++;
}
} }
ASSERT(cnt == XFS_IFORK_NEXTENTS(ip, whichfork)); ASSERT(cnt == XFS_IFORK_NEXTENTS(ip, whichfork));
xfs_btree_set_numrecs(ablock, cnt); xfs_btree_set_numrecs(ablock, cnt);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment