On Thu, Jun 16, 2016 at 06:20:00PM -0700, Darrick J. Wong wrote: > Drop the compatibility shims that we were using to integrate the new > deferred operation mechanism into the existing code. No new code. I've since renamed xfs_bmap_free_item to xfs_extent_free_item to better reflect the increased separation between bmap and extent free. --D > > Signed-off-by: Darrick J. Wong <darrick.wong@xxxxxxxxxx> > --- > fs/xfs/libxfs/xfs_attr.c | 58 ++++++++++++++++++------------------ > fs/xfs/libxfs/xfs_attr_remote.c | 14 ++++----- > fs/xfs/libxfs/xfs_bmap.c | 38 ++++++++++++------------ > fs/xfs/libxfs/xfs_bmap.h | 10 +++--- > fs/xfs/libxfs/xfs_btree.h | 5 ++- > fs/xfs/libxfs/xfs_da_btree.h | 4 +-- > fs/xfs/libxfs/xfs_defer.h | 7 ---- > fs/xfs/libxfs/xfs_dir2.c | 6 ++-- > fs/xfs/libxfs/xfs_dir2.h | 8 +++-- > fs/xfs/libxfs/xfs_ialloc.c | 6 ++-- > fs/xfs/libxfs/xfs_ialloc.h | 2 + > fs/xfs/libxfs/xfs_trans_resv.c | 4 +-- > fs/xfs/xfs_bmap_util.c | 28 +++++++++--------- > fs/xfs/xfs_dquot.c | 10 +++--- > fs/xfs/xfs_inode.c | 62 ++++++++++++++++++++------------------- > fs/xfs/xfs_inode.h | 4 +-- > fs/xfs/xfs_iomap.c | 24 ++++++++------- > fs/xfs/xfs_rtalloc.c | 8 +++-- > fs/xfs/xfs_symlink.c | 16 +++++----- > 19 files changed, 154 insertions(+), 160 deletions(-) > > > diff --git a/fs/xfs/libxfs/xfs_attr.c b/fs/xfs/libxfs/xfs_attr.c > index 79d3a30..66baf97 100644 > --- a/fs/xfs/libxfs/xfs_attr.c > +++ b/fs/xfs/libxfs/xfs_attr.c > @@ -204,7 +204,7 @@ xfs_attr_set( > { > struct xfs_mount *mp = dp->i_mount; > struct xfs_da_args args; > - struct xfs_bmap_free flist; > + struct xfs_defer_ops flist; > struct xfs_trans_res tres; > xfs_fsblock_t firstblock; > int rsvd = (flags & ATTR_ROOT) != 0; > @@ -317,13 +317,13 @@ xfs_attr_set( > * It won't fit in the shortform, transform to a leaf block. > * GROT: another possible req'mt for a double-split btree op. > */ > - xfs_bmap_init(args.flist, args.firstblock); > + xfs_defer_init(args.flist, args.firstblock); > error = xfs_attr_shortform_to_leaf(&args); > if (!error) > - error = xfs_bmap_finish(&args.trans, args.flist, dp); > + error = xfs_defer_finish(&args.trans, args.flist, dp); > if (error) { > args.trans = NULL; > - xfs_bmap_cancel(&flist); > + xfs_defer_cancel(&flist); > goto out; > } > > @@ -383,7 +383,7 @@ xfs_attr_remove( > { > struct xfs_mount *mp = dp->i_mount; > struct xfs_da_args args; > - struct xfs_bmap_free flist; > + struct xfs_defer_ops flist; > xfs_fsblock_t firstblock; > int error; > > @@ -585,13 +585,13 @@ xfs_attr_leaf_addname(xfs_da_args_t *args) > * Commit that transaction so that the node_addname() call > * can manage its own transactions. > */ > - xfs_bmap_init(args->flist, args->firstblock); > + xfs_defer_init(args->flist, args->firstblock); > error = xfs_attr3_leaf_to_node(args); > if (!error) > - error = xfs_bmap_finish(&args->trans, args->flist, dp); > + error = xfs_defer_finish(&args->trans, args->flist, dp); > if (error) { > args->trans = NULL; > - xfs_bmap_cancel(args->flist); > + xfs_defer_cancel(args->flist); > return error; > } > > @@ -675,15 +675,15 @@ xfs_attr_leaf_addname(xfs_da_args_t *args) > * If the result is small enough, shrink it all into the inode. > */ > if ((forkoff = xfs_attr_shortform_allfit(bp, dp))) { > - xfs_bmap_init(args->flist, args->firstblock); > + xfs_defer_init(args->flist, args->firstblock); > error = xfs_attr3_leaf_to_shortform(bp, args, forkoff); > /* bp is gone due to xfs_da_shrink_inode */ > if (!error) > - error = xfs_bmap_finish(&args->trans, > + error = xfs_defer_finish(&args->trans, > args->flist, dp); > if (error) { > args->trans = NULL; > - xfs_bmap_cancel(args->flist); > + xfs_defer_cancel(args->flist); > return error; > } > } > @@ -738,14 +738,14 @@ xfs_attr_leaf_removename(xfs_da_args_t *args) > * If the result is small enough, shrink it all into the inode. > */ > if ((forkoff = xfs_attr_shortform_allfit(bp, dp))) { > - xfs_bmap_init(args->flist, args->firstblock); > + xfs_defer_init(args->flist, args->firstblock); > error = xfs_attr3_leaf_to_shortform(bp, args, forkoff); > /* bp is gone due to xfs_da_shrink_inode */ > if (!error) > - error = xfs_bmap_finish(&args->trans, args->flist, dp); > + error = xfs_defer_finish(&args->trans, args->flist, dp); > if (error) { > args->trans = NULL; > - xfs_bmap_cancel(args->flist); > + xfs_defer_cancel(args->flist); > return error; > } > } > @@ -864,14 +864,14 @@ restart: > */ > xfs_da_state_free(state); > state = NULL; > - xfs_bmap_init(args->flist, args->firstblock); > + xfs_defer_init(args->flist, args->firstblock); > error = xfs_attr3_leaf_to_node(args); > if (!error) > - error = xfs_bmap_finish(&args->trans, > + error = xfs_defer_finish(&args->trans, > args->flist, dp); > if (error) { > args->trans = NULL; > - xfs_bmap_cancel(args->flist); > + xfs_defer_cancel(args->flist); > goto out; > } > > @@ -892,13 +892,13 @@ restart: > * in the index/blkno/rmtblkno/rmtblkcnt fields and > * in the index2/blkno2/rmtblkno2/rmtblkcnt2 fields. > */ > - xfs_bmap_init(args->flist, args->firstblock); > + xfs_defer_init(args->flist, args->firstblock); > error = xfs_da3_split(state); > if (!error) > - error = xfs_bmap_finish(&args->trans, args->flist, dp); > + error = xfs_defer_finish(&args->trans, args->flist, dp); > if (error) { > args->trans = NULL; > - xfs_bmap_cancel(args->flist); > + xfs_defer_cancel(args->flist); > goto out; > } > } else { > @@ -991,14 +991,14 @@ restart: > * Check to see if the tree needs to be collapsed. > */ > if (retval && (state->path.active > 1)) { > - xfs_bmap_init(args->flist, args->firstblock); > + xfs_defer_init(args->flist, args->firstblock); > error = xfs_da3_join(state); > if (!error) > - error = xfs_bmap_finish(&args->trans, > + error = xfs_defer_finish(&args->trans, > args->flist, dp); > if (error) { > args->trans = NULL; > - xfs_bmap_cancel(args->flist); > + xfs_defer_cancel(args->flist); > goto out; > } > } > @@ -1114,13 +1114,13 @@ xfs_attr_node_removename(xfs_da_args_t *args) > * Check to see if the tree needs to be collapsed. > */ > if (retval && (state->path.active > 1)) { > - xfs_bmap_init(args->flist, args->firstblock); > + xfs_defer_init(args->flist, args->firstblock); > error = xfs_da3_join(state); > if (!error) > - error = xfs_bmap_finish(&args->trans, args->flist, dp); > + error = xfs_defer_finish(&args->trans, args->flist, dp); > if (error) { > args->trans = NULL; > - xfs_bmap_cancel(args->flist); > + xfs_defer_cancel(args->flist); > goto out; > } > /* > @@ -1147,15 +1147,15 @@ xfs_attr_node_removename(xfs_da_args_t *args) > goto out; > > if ((forkoff = xfs_attr_shortform_allfit(bp, dp))) { > - xfs_bmap_init(args->flist, args->firstblock); > + xfs_defer_init(args->flist, args->firstblock); > error = xfs_attr3_leaf_to_shortform(bp, args, forkoff); > /* bp is gone due to xfs_da_shrink_inode */ > if (!error) > - error = xfs_bmap_finish(&args->trans, > + error = xfs_defer_finish(&args->trans, > args->flist, dp); > if (error) { > args->trans = NULL; > - xfs_bmap_cancel(args->flist); > + xfs_defer_cancel(args->flist); > goto out; > } > } else > diff --git a/fs/xfs/libxfs/xfs_attr_remote.c b/fs/xfs/libxfs/xfs_attr_remote.c > index 93a9ce1..aabb516 100644 > --- a/fs/xfs/libxfs/xfs_attr_remote.c > +++ b/fs/xfs/libxfs/xfs_attr_remote.c > @@ -461,16 +461,16 @@ xfs_attr_rmtval_set( > * extent and then crash then the block may not contain the > * correct metadata after log recovery occurs. > */ > - xfs_bmap_init(args->flist, args->firstblock); > + xfs_defer_init(args->flist, args->firstblock); > nmap = 1; > error = xfs_bmapi_write(args->trans, dp, (xfs_fileoff_t)lblkno, > blkcnt, XFS_BMAPI_ATTRFORK, args->firstblock, > args->total, &map, &nmap, args->flist); > if (!error) > - error = xfs_bmap_finish(&args->trans, args->flist, dp); > + error = xfs_defer_finish(&args->trans, args->flist, dp); > if (error) { > args->trans = NULL; > - xfs_bmap_cancel(args->flist); > + xfs_defer_cancel(args->flist); > return error; > } > > @@ -504,7 +504,7 @@ xfs_attr_rmtval_set( > > ASSERT(blkcnt > 0); > > - xfs_bmap_init(args->flist, args->firstblock); > + xfs_defer_init(args->flist, args->firstblock); > nmap = 1; > error = xfs_bmapi_read(dp, (xfs_fileoff_t)lblkno, > blkcnt, &map, &nmap, > @@ -604,16 +604,16 @@ xfs_attr_rmtval_remove( > blkcnt = args->rmtblkcnt; > done = 0; > while (!done) { > - xfs_bmap_init(args->flist, args->firstblock); > + xfs_defer_init(args->flist, args->firstblock); > error = xfs_bunmapi(args->trans, args->dp, lblkno, blkcnt, > XFS_BMAPI_ATTRFORK, 1, args->firstblock, > args->flist, &done); > if (!error) > - error = xfs_bmap_finish(&args->trans, args->flist, > + error = xfs_defer_finish(&args->trans, args->flist, > args->dp); > if (error) { > args->trans = NULL; > - xfs_bmap_cancel(args->flist); > + xfs_defer_cancel(args->flist); > return error; > } > > diff --git a/fs/xfs/libxfs/xfs_bmap.c b/fs/xfs/libxfs/xfs_bmap.c > index 64ca97f..45ce7bd 100644 > --- a/fs/xfs/libxfs/xfs_bmap.c > +++ b/fs/xfs/libxfs/xfs_bmap.c > @@ -572,7 +572,7 @@ xfs_bmap_validate_ret( > void > xfs_bmap_add_free( > struct xfs_mount *mp, /* mount point structure */ > - struct xfs_bmap_free *flist, /* list of extents */ > + struct xfs_defer_ops *flist, /* list of extents */ > xfs_fsblock_t bno, /* fs block number of extent */ > xfs_filblks_t len) /* length of extent */ > { > @@ -672,7 +672,7 @@ xfs_bmap_extents_to_btree( > xfs_trans_t *tp, /* transaction pointer */ > xfs_inode_t *ip, /* incore inode pointer */ > xfs_fsblock_t *firstblock, /* first-block-allocated */ > - xfs_bmap_free_t *flist, /* blocks freed in xaction */ > + struct xfs_defer_ops *flist, /* blocks freed in xaction */ > xfs_btree_cur_t **curp, /* cursor returned to caller */ > int wasdel, /* converting a delayed alloc */ > int *logflagsp, /* inode logging flags */ > @@ -940,7 +940,7 @@ xfs_bmap_add_attrfork_btree( > xfs_trans_t *tp, /* transaction pointer */ > xfs_inode_t *ip, /* incore inode pointer */ > xfs_fsblock_t *firstblock, /* first block allocated */ > - xfs_bmap_free_t *flist, /* blocks to free at commit */ > + struct xfs_defer_ops *flist, /* blocks to free at commit */ > int *flags) /* inode logging flags */ > { > xfs_btree_cur_t *cur; /* btree cursor */ > @@ -983,7 +983,7 @@ xfs_bmap_add_attrfork_extents( > xfs_trans_t *tp, /* transaction pointer */ > xfs_inode_t *ip, /* incore inode pointer */ > xfs_fsblock_t *firstblock, /* first block allocated */ > - xfs_bmap_free_t *flist, /* blocks to free at commit */ > + struct xfs_defer_ops *flist, /* blocks to free at commit */ > int *flags) /* inode logging flags */ > { > xfs_btree_cur_t *cur; /* bmap btree cursor */ > @@ -1018,7 +1018,7 @@ xfs_bmap_add_attrfork_local( > xfs_trans_t *tp, /* transaction pointer */ > xfs_inode_t *ip, /* incore inode pointer */ > xfs_fsblock_t *firstblock, /* first block allocated */ > - xfs_bmap_free_t *flist, /* blocks to free at commit */ > + struct xfs_defer_ops *flist, /* blocks to free at commit */ > int *flags) /* inode logging flags */ > { > xfs_da_args_t dargs; /* args for dir/attr code */ > @@ -1059,7 +1059,7 @@ xfs_bmap_add_attrfork( > int rsvd) /* xact may use reserved blks */ > { > xfs_fsblock_t firstblock; /* 1st block/ag allocated */ > - xfs_bmap_free_t flist; /* freed extent records */ > + struct xfs_defer_ops flist; /* freed extent records */ > xfs_mount_t *mp; /* mount structure */ > xfs_trans_t *tp; /* transaction pointer */ > int blks; /* space reservation */ > @@ -1125,7 +1125,7 @@ xfs_bmap_add_attrfork( > ip->i_afp = kmem_zone_zalloc(xfs_ifork_zone, KM_SLEEP); > ip->i_afp->if_flags = XFS_IFEXTENTS; > logflags = 0; > - xfs_bmap_init(&flist, &firstblock); > + xfs_defer_init(&flist, &firstblock); > switch (ip->i_d.di_format) { > case XFS_DINODE_FMT_LOCAL: > error = xfs_bmap_add_attrfork_local(tp, ip, &firstblock, &flist, > @@ -1165,7 +1165,7 @@ xfs_bmap_add_attrfork( > xfs_log_sb(tp); > } > > - error = xfs_bmap_finish(&tp, &flist, NULL); > + error = xfs_defer_finish(&tp, &flist, NULL); > if (error) > goto bmap_cancel; > error = xfs_trans_commit(tp); > @@ -1173,7 +1173,7 @@ xfs_bmap_add_attrfork( > return error; > > bmap_cancel: > - xfs_bmap_cancel(&flist); > + xfs_defer_cancel(&flist); > trans_cancel: > xfs_trans_cancel(tp); > xfs_iunlock(ip, XFS_ILOCK_EXCL); > @@ -2214,7 +2214,7 @@ xfs_bmap_add_extent_unwritten_real( > xfs_btree_cur_t **curp, /* if *curp is null, not a btree */ > xfs_bmbt_irec_t *new, /* new data to add to file extents */ > xfs_fsblock_t *first, /* pointer to firstblock variable */ > - xfs_bmap_free_t *flist, /* list of extents to be freed */ > + struct xfs_defer_ops *flist, /* list of extents to be freed */ > int *logflagsp) /* inode logging flags */ > { > xfs_btree_cur_t *cur; /* btree cursor */ > @@ -4447,7 +4447,7 @@ xfs_bmapi_write( > xfs_extlen_t total, /* total blocks needed */ > struct xfs_bmbt_irec *mval, /* output: map values */ > int *nmap, /* i/o: mval size/count */ > - struct xfs_bmap_free *flist) /* i/o: list extents to free */ > + struct xfs_defer_ops *flist) /* i/o: list extents to free */ > { > struct xfs_mount *mp = ip->i_mount; > struct xfs_ifork *ifp; > @@ -4735,7 +4735,7 @@ xfs_bmap_del_extent( > xfs_inode_t *ip, /* incore inode pointer */ > xfs_trans_t *tp, /* current transaction pointer */ > xfs_extnum_t *idx, /* extent number to update/delete */ > - xfs_bmap_free_t *flist, /* list of extents to be freed */ > + struct xfs_defer_ops *flist, /* list of extents to be freed */ > xfs_btree_cur_t *cur, /* if null, not a btree */ > xfs_bmbt_irec_t *del, /* data to remove from extents */ > int *logflagsp, /* inode logging flags */ > @@ -5064,7 +5064,7 @@ xfs_bunmapi( > xfs_extnum_t nexts, /* number of extents max */ > xfs_fsblock_t *firstblock, /* first allocated block > controls a.g. for allocs */ > - xfs_bmap_free_t *flist, /* i/o: list extents to free */ > + struct xfs_defer_ops *flist, /* i/o: list extents to free */ > int *done) /* set if not done yet */ > { > xfs_btree_cur_t *cur; /* bmap btree cursor */ > @@ -5678,7 +5678,7 @@ xfs_bmap_shift_extents( > int *done, > xfs_fileoff_t stop_fsb, > xfs_fsblock_t *firstblock, > - struct xfs_bmap_free *flist, > + struct xfs_defer_ops *flist, > enum shift_direction direction, > int num_exts) > { > @@ -5832,7 +5832,7 @@ xfs_bmap_split_extent_at( > struct xfs_inode *ip, > xfs_fileoff_t split_fsb, > xfs_fsblock_t *firstfsb, > - struct xfs_bmap_free *free_list) > + struct xfs_defer_ops *free_list) > { > int whichfork = XFS_DATA_FORK; > struct xfs_btree_cur *cur = NULL; > @@ -5971,7 +5971,7 @@ xfs_bmap_split_extent( > { > struct xfs_mount *mp = ip->i_mount; > struct xfs_trans *tp; > - struct xfs_bmap_free free_list; > + struct xfs_defer_ops free_list; > xfs_fsblock_t firstfsb; > int error; > > @@ -5983,21 +5983,21 @@ xfs_bmap_split_extent( > xfs_ilock(ip, XFS_ILOCK_EXCL); > xfs_trans_ijoin(tp, ip, XFS_ILOCK_EXCL); > > - xfs_bmap_init(&free_list, &firstfsb); > + xfs_defer_init(&free_list, &firstfsb); > > error = xfs_bmap_split_extent_at(tp, ip, split_fsb, > &firstfsb, &free_list); > if (error) > goto out; > > - error = xfs_bmap_finish(&tp, &free_list, NULL); > + error = xfs_defer_finish(&tp, &free_list, NULL); > if (error) > goto out; > > return xfs_trans_commit(tp); > > out: > - xfs_bmap_cancel(&free_list); > + xfs_defer_cancel(&free_list); > xfs_trans_cancel(tp); > return error; > } > diff --git a/fs/xfs/libxfs/xfs_bmap.h b/fs/xfs/libxfs/xfs_bmap.h > index 6681bd9..e2a0425 100644 > --- a/fs/xfs/libxfs/xfs_bmap.h > +++ b/fs/xfs/libxfs/xfs_bmap.h > @@ -32,7 +32,7 @@ extern kmem_zone_t *xfs_bmap_free_item_zone; > */ > struct xfs_bmalloca { > xfs_fsblock_t *firstblock; /* i/o first block allocated */ > - struct xfs_bmap_free *flist; /* bmap freelist */ > + struct xfs_defer_ops *flist; /* bmap freelist */ > struct xfs_trans *tp; /* transaction pointer */ > struct xfs_inode *ip; /* incore inode pointer */ > struct xfs_bmbt_irec prev; /* extent before the new one */ > @@ -164,7 +164,7 @@ void xfs_bmap_trace_exlist(struct xfs_inode *ip, xfs_extnum_t cnt, > > int xfs_bmap_add_attrfork(struct xfs_inode *ip, int size, int rsvd); > void xfs_bmap_local_to_extents_empty(struct xfs_inode *ip, int whichfork); > -void xfs_bmap_add_free(struct xfs_mount *mp, struct xfs_bmap_free *flist, > +void xfs_bmap_add_free(struct xfs_mount *mp, struct xfs_defer_ops *flist, > xfs_fsblock_t bno, xfs_filblks_t len); > void xfs_bmap_compute_maxlevels(struct xfs_mount *mp, int whichfork); > int xfs_bmap_first_unused(struct xfs_trans *tp, struct xfs_inode *ip, > @@ -186,18 +186,18 @@ int xfs_bmapi_write(struct xfs_trans *tp, struct xfs_inode *ip, > xfs_fileoff_t bno, xfs_filblks_t len, int flags, > xfs_fsblock_t *firstblock, xfs_extlen_t total, > struct xfs_bmbt_irec *mval, int *nmap, > - struct xfs_bmap_free *flist); > + struct xfs_defer_ops *flist); > int xfs_bunmapi(struct xfs_trans *tp, struct xfs_inode *ip, > xfs_fileoff_t bno, xfs_filblks_t len, int flags, > xfs_extnum_t nexts, xfs_fsblock_t *firstblock, > - struct xfs_bmap_free *flist, int *done); > + struct xfs_defer_ops *flist, int *done); > int xfs_check_nostate_extents(struct xfs_ifork *ifp, xfs_extnum_t idx, > xfs_extnum_t num); > uint xfs_default_attroffset(struct xfs_inode *ip); > int xfs_bmap_shift_extents(struct xfs_trans *tp, struct xfs_inode *ip, > xfs_fileoff_t *next_fsb, xfs_fileoff_t offset_shift_fsb, > int *done, xfs_fileoff_t stop_fsb, xfs_fsblock_t *firstblock, > - struct xfs_bmap_free *flist, enum shift_direction direction, > + struct xfs_defer_ops *flist, enum shift_direction direction, > int num_exts); > int xfs_bmap_split_extent(struct xfs_inode *ip, xfs_fileoff_t split_offset); > > diff --git a/fs/xfs/libxfs/xfs_btree.h b/fs/xfs/libxfs/xfs_btree.h > index 0ec3055..ae714a8 100644 > --- a/fs/xfs/libxfs/xfs_btree.h > +++ b/fs/xfs/libxfs/xfs_btree.h > @@ -19,7 +19,7 @@ > #define __XFS_BTREE_H__ > > struct xfs_buf; > -struct xfs_bmap_free; > +struct xfs_defer_ops; > struct xfs_inode; > struct xfs_mount; > struct xfs_trans; > @@ -234,11 +234,12 @@ typedef struct xfs_btree_cur > union { > struct { /* needed for BNO, CNT, INO */ > struct xfs_buf *agbp; /* agf/agi buffer pointer */ > + struct xfs_defer_ops *flist; /* deferred updates */ > xfs_agnumber_t agno; /* ag number */ > } a; > struct { /* needed for BMAP */ > struct xfs_inode *ip; /* pointer to our inode */ > - struct xfs_bmap_free *flist; /* list to free after */ > + struct xfs_defer_ops *flist; /* deferred updates */ > xfs_fsblock_t firstblock; /* 1st blk allocated */ > int allocated; /* count of alloced */ > short forksize; /* fork's inode space */ > diff --git a/fs/xfs/libxfs/xfs_da_btree.h b/fs/xfs/libxfs/xfs_da_btree.h > index 6e153e3..249813a 100644 > --- a/fs/xfs/libxfs/xfs_da_btree.h > +++ b/fs/xfs/libxfs/xfs_da_btree.h > @@ -19,7 +19,7 @@ > #ifndef __XFS_DA_BTREE_H__ > #define __XFS_DA_BTREE_H__ > > -struct xfs_bmap_free; > +struct xfs_defer_ops; > struct xfs_inode; > struct xfs_trans; > struct zone; > @@ -70,7 +70,7 @@ typedef struct xfs_da_args { > xfs_ino_t inumber; /* input/output inode number */ > struct xfs_inode *dp; /* directory inode to manipulate */ > xfs_fsblock_t *firstblock; /* ptr to firstblock for bmap calls */ > - struct xfs_bmap_free *flist; /* ptr to freelist for bmap_finish */ > + struct xfs_defer_ops *flist; /* ptr to freelist for bmap_finish */ > struct xfs_trans *trans; /* current trans (changes over time) */ > xfs_extlen_t total; /* total blocks needed, for 1st bmap */ > int whichfork; /* data or attribute fork */ > diff --git a/fs/xfs/libxfs/xfs_defer.h b/fs/xfs/libxfs/xfs_defer.h > index 4c05ba6..743fc32 100644 > --- a/fs/xfs/libxfs/xfs_defer.h > +++ b/fs/xfs/libxfs/xfs_defer.h > @@ -94,11 +94,4 @@ struct xfs_defer_op_type { > void xfs_defer_init_op_type(const struct xfs_defer_op_type *type); > void xfs_defer_init_types(void); > > -/* XXX: compatibility shims, will go away in the next patch */ > -#define xfs_bmap_finish xfs_defer_finish > -#define xfs_bmap_cancel xfs_defer_cancel > -#define xfs_bmap_init xfs_defer_init > -#define xfs_bmap_free xfs_defer_ops > -typedef struct xfs_defer_ops xfs_bmap_free_t; > - > #endif /* __XFS_DEFER_H__ */ > diff --git a/fs/xfs/libxfs/xfs_dir2.c b/fs/xfs/libxfs/xfs_dir2.c > index 945c0345..0523100 100644 > --- a/fs/xfs/libxfs/xfs_dir2.c > +++ b/fs/xfs/libxfs/xfs_dir2.c > @@ -260,7 +260,7 @@ xfs_dir_createname( > struct xfs_name *name, > xfs_ino_t inum, /* new entry inode number */ > xfs_fsblock_t *first, /* bmap's firstblock */ > - xfs_bmap_free_t *flist, /* bmap's freeblock list */ > + struct xfs_defer_ops *flist, /* bmap's freeblock list */ > xfs_extlen_t total) /* bmap's total block count */ > { > struct xfs_da_args *args; > @@ -437,7 +437,7 @@ xfs_dir_removename( > struct xfs_name *name, > xfs_ino_t ino, > xfs_fsblock_t *first, /* bmap's firstblock */ > - xfs_bmap_free_t *flist, /* bmap's freeblock list */ > + struct xfs_defer_ops *flist, /* bmap's freeblock list */ > xfs_extlen_t total) /* bmap's total block count */ > { > struct xfs_da_args *args; > @@ -499,7 +499,7 @@ xfs_dir_replace( > struct xfs_name *name, /* name of entry to replace */ > xfs_ino_t inum, /* new inode number */ > xfs_fsblock_t *first, /* bmap's firstblock */ > - xfs_bmap_free_t *flist, /* bmap's freeblock list */ > + struct xfs_defer_ops *flist, /* bmap's freeblock list */ > xfs_extlen_t total) /* bmap's total block count */ > { > struct xfs_da_args *args; > diff --git a/fs/xfs/libxfs/xfs_dir2.h b/fs/xfs/libxfs/xfs_dir2.h > index 0a62e73..5737d85 100644 > --- a/fs/xfs/libxfs/xfs_dir2.h > +++ b/fs/xfs/libxfs/xfs_dir2.h > @@ -18,7 +18,7 @@ > #ifndef __XFS_DIR2_H__ > #define __XFS_DIR2_H__ > > -struct xfs_bmap_free; > +struct xfs_defer_ops; > struct xfs_da_args; > struct xfs_inode; > struct xfs_mount; > @@ -129,18 +129,18 @@ extern int xfs_dir_init(struct xfs_trans *tp, struct xfs_inode *dp, > extern int xfs_dir_createname(struct xfs_trans *tp, struct xfs_inode *dp, > struct xfs_name *name, xfs_ino_t inum, > xfs_fsblock_t *first, > - struct xfs_bmap_free *flist, xfs_extlen_t tot); > + struct xfs_defer_ops *flist, xfs_extlen_t tot); > extern int xfs_dir_lookup(struct xfs_trans *tp, struct xfs_inode *dp, > struct xfs_name *name, xfs_ino_t *inum, > struct xfs_name *ci_name); > extern int xfs_dir_removename(struct xfs_trans *tp, struct xfs_inode *dp, > struct xfs_name *name, xfs_ino_t ino, > xfs_fsblock_t *first, > - struct xfs_bmap_free *flist, xfs_extlen_t tot); > + struct xfs_defer_ops *flist, xfs_extlen_t tot); > extern int xfs_dir_replace(struct xfs_trans *tp, struct xfs_inode *dp, > struct xfs_name *name, xfs_ino_t inum, > xfs_fsblock_t *first, > - struct xfs_bmap_free *flist, xfs_extlen_t tot); > + struct xfs_defer_ops *flist, xfs_extlen_t tot); > extern int xfs_dir_canenter(struct xfs_trans *tp, struct xfs_inode *dp, > struct xfs_name *name); > > diff --git a/fs/xfs/libxfs/xfs_ialloc.c b/fs/xfs/libxfs/xfs_ialloc.c > index 9ae9a43..f2e29a1 100644 > --- a/fs/xfs/libxfs/xfs_ialloc.c > +++ b/fs/xfs/libxfs/xfs_ialloc.c > @@ -1818,7 +1818,7 @@ xfs_difree_inode_chunk( > struct xfs_mount *mp, > xfs_agnumber_t agno, > struct xfs_inobt_rec_incore *rec, > - struct xfs_bmap_free *flist) > + struct xfs_defer_ops *flist) > { > xfs_agblock_t sagbno = XFS_AGINO_TO_AGBNO(mp, rec->ir_startino); > int startidx, endidx; > @@ -1890,7 +1890,7 @@ xfs_difree_inobt( > struct xfs_trans *tp, > struct xfs_buf *agbp, > xfs_agino_t agino, > - struct xfs_bmap_free *flist, > + struct xfs_defer_ops *flist, > struct xfs_icluster *xic, > struct xfs_inobt_rec_incore *orec) > { > @@ -2122,7 +2122,7 @@ int > xfs_difree( > struct xfs_trans *tp, /* transaction pointer */ > xfs_ino_t inode, /* inode to be freed */ > - struct xfs_bmap_free *flist, /* extents to free */ > + struct xfs_defer_ops *flist, /* extents to free */ > struct xfs_icluster *xic) /* cluster info if deleted */ > { > /* REFERENCED */ > diff --git a/fs/xfs/libxfs/xfs_ialloc.h b/fs/xfs/libxfs/xfs_ialloc.h > index 6e450df..2e06b67 100644 > --- a/fs/xfs/libxfs/xfs_ialloc.h > +++ b/fs/xfs/libxfs/xfs_ialloc.h > @@ -95,7 +95,7 @@ int /* error */ > xfs_difree( > struct xfs_trans *tp, /* transaction pointer */ > xfs_ino_t inode, /* inode to be freed */ > - struct xfs_bmap_free *flist, /* extents to free */ > + struct xfs_defer_ops *flist, /* extents to free */ > struct xfs_icluster *ifree); /* cluster info if deleted */ > > /* > diff --git a/fs/xfs/libxfs/xfs_trans_resv.c b/fs/xfs/libxfs/xfs_trans_resv.c > index 68cb1e7..4c7eb9d 100644 > --- a/fs/xfs/libxfs/xfs_trans_resv.c > +++ b/fs/xfs/libxfs/xfs_trans_resv.c > @@ -153,9 +153,9 @@ xfs_calc_finobt_res( > * item logged to try to account for the overhead of the transaction mechanism. > * > * Note: Most of the reservations underestimate the number of allocation > - * groups into which they could free extents in the xfs_bmap_finish() call. > + * groups into which they could free extents in the xfs_defer_finish() call. > * This is because the number in the worst case is quite high and quite > - * unusual. In order to fix this we need to change xfs_bmap_finish() to free > + * unusual. In order to fix this we need to change xfs_defer_finish() to free > * extents in only a single AG at a time. This will require changes to the > * EFI code as well, however, so that the EFI for the extents not freed is > * logged again in each transaction. See SGI PV #261917. > diff --git a/fs/xfs/xfs_bmap_util.c b/fs/xfs/xfs_bmap_util.c > index 972a27a..928dfa4 100644 > --- a/fs/xfs/xfs_bmap_util.c > +++ b/fs/xfs/xfs_bmap_util.c > @@ -685,7 +685,7 @@ xfs_bmap_punch_delalloc_range( > xfs_bmbt_irec_t imap; > int nimaps = 1; > xfs_fsblock_t firstblock; > - xfs_bmap_free_t flist; > + struct xfs_defer_ops flist; > > /* > * Map the range first and check that it is a delalloc extent > @@ -721,7 +721,7 @@ xfs_bmap_punch_delalloc_range( > * allocated or freed for a delalloc extent and hence we need > * don't cancel or finish them after the xfs_bunmapi() call. > */ > - xfs_bmap_init(&flist, &firstblock); > + xfs_defer_init(&flist, &firstblock); > error = xfs_bunmapi(NULL, ip, start_fsb, 1, 0, 1, &firstblock, > &flist, &done); > if (error) > @@ -884,7 +884,7 @@ xfs_alloc_file_space( > int rt; > xfs_trans_t *tp; > xfs_bmbt_irec_t imaps[1], *imapp; > - xfs_bmap_free_t free_list; > + struct xfs_defer_ops free_list; > uint qblocks, resblks, resrtextents; > int error; > > @@ -975,7 +975,7 @@ xfs_alloc_file_space( > > xfs_trans_ijoin(tp, ip, 0); > > - xfs_bmap_init(&free_list, &firstfsb); > + xfs_defer_init(&free_list, &firstfsb); > error = xfs_bmapi_write(tp, ip, startoffset_fsb, > allocatesize_fsb, alloc_type, &firstfsb, > resblks, imapp, &nimaps, &free_list); > @@ -985,7 +985,7 @@ xfs_alloc_file_space( > /* > * Complete the transaction > */ > - error = xfs_bmap_finish(&tp, &free_list, NULL); > + error = xfs_defer_finish(&tp, &free_list, NULL); > if (error) > goto error0; > > @@ -1008,7 +1008,7 @@ xfs_alloc_file_space( > return error; > > error0: /* Cancel bmap, unlock inode, unreserve quota blocks, cancel trans */ > - xfs_bmap_cancel(&free_list); > + xfs_defer_cancel(&free_list); > xfs_trans_unreserve_quota_nblks(tp, ip, (long)qblocks, 0, quota_flag); > > error1: /* Just cancel transaction */ > @@ -1122,7 +1122,7 @@ xfs_free_file_space( > xfs_fileoff_t endoffset_fsb; > int error; > xfs_fsblock_t firstfsb; > - xfs_bmap_free_t free_list; > + struct xfs_defer_ops free_list; > xfs_bmbt_irec_t imap; > xfs_off_t ioffset; > xfs_off_t iendoffset; > @@ -1245,7 +1245,7 @@ xfs_free_file_space( > /* > * issue the bunmapi() call to free the blocks > */ > - xfs_bmap_init(&free_list, &firstfsb); > + xfs_defer_init(&free_list, &firstfsb); > error = xfs_bunmapi(tp, ip, startoffset_fsb, > endoffset_fsb - startoffset_fsb, > 0, 2, &firstfsb, &free_list, &done); > @@ -1255,7 +1255,7 @@ xfs_free_file_space( > /* > * complete the transaction > */ > - error = xfs_bmap_finish(&tp, &free_list, NULL); > + error = xfs_defer_finish(&tp, &free_list, ip); > if (error) > goto error0; > > @@ -1267,7 +1267,7 @@ xfs_free_file_space( > return error; > > error0: > - xfs_bmap_cancel(&free_list); > + xfs_defer_cancel(&free_list); > error1: > xfs_trans_cancel(tp); > xfs_iunlock(ip, XFS_ILOCK_EXCL); > @@ -1333,7 +1333,7 @@ xfs_shift_file_space( > struct xfs_mount *mp = ip->i_mount; > struct xfs_trans *tp; > int error; > - struct xfs_bmap_free free_list; > + struct xfs_defer_ops free_list; > xfs_fsblock_t first_block; > xfs_fileoff_t stop_fsb; > xfs_fileoff_t next_fsb; > @@ -1411,7 +1411,7 @@ xfs_shift_file_space( > > xfs_trans_ijoin(tp, ip, XFS_ILOCK_EXCL); > > - xfs_bmap_init(&free_list, &first_block); > + xfs_defer_init(&free_list, &first_block); > > /* > * We are using the write transaction in which max 2 bmbt > @@ -1423,7 +1423,7 @@ xfs_shift_file_space( > if (error) > goto out_bmap_cancel; > > - error = xfs_bmap_finish(&tp, &free_list, NULL); > + error = xfs_defer_finish(&tp, &free_list, NULL); > if (error) > goto out_bmap_cancel; > > @@ -1433,7 +1433,7 @@ xfs_shift_file_space( > return error; > > out_bmap_cancel: > - xfs_bmap_cancel(&free_list); > + xfs_defer_cancel(&free_list); > out_trans_cancel: > xfs_trans_cancel(tp); > return error; > diff --git a/fs/xfs/xfs_dquot.c b/fs/xfs/xfs_dquot.c > index be17f0a..764e1cc 100644 > --- a/fs/xfs/xfs_dquot.c > +++ b/fs/xfs/xfs_dquot.c > @@ -307,7 +307,7 @@ xfs_qm_dqalloc( > xfs_buf_t **O_bpp) > { > xfs_fsblock_t firstblock; > - xfs_bmap_free_t flist; > + struct xfs_defer_ops flist; > xfs_bmbt_irec_t map; > int nmaps, error; > xfs_buf_t *bp; > @@ -320,7 +320,7 @@ xfs_qm_dqalloc( > /* > * Initialize the bmap freelist prior to calling bmapi code. > */ > - xfs_bmap_init(&flist, &firstblock); > + xfs_defer_init(&flist, &firstblock); > xfs_ilock(quotip, XFS_ILOCK_EXCL); > /* > * Return if this type of quotas is turned off while we didn't > @@ -368,7 +368,7 @@ xfs_qm_dqalloc( > dqp->dq_flags & XFS_DQ_ALLTYPES, bp); > > /* > - * xfs_bmap_finish() may commit the current transaction and > + * xfs_defer_finish() may commit the current transaction and > * start a second transaction if the freelist is not empty. > * > * Since we still want to modify this buffer, we need to > @@ -382,7 +382,7 @@ xfs_qm_dqalloc( > > xfs_trans_bhold(tp, bp); > > - error = xfs_bmap_finish(tpp, &flist, NULL); > + error = xfs_defer_finish(tpp, &flist, NULL); > if (error) > goto error1; > > @@ -398,7 +398,7 @@ xfs_qm_dqalloc( > return 0; > > error1: > - xfs_bmap_cancel(&flist); > + xfs_defer_cancel(&flist); > error0: > xfs_iunlock(quotip, XFS_ILOCK_EXCL); > > diff --git a/fs/xfs/xfs_inode.c b/fs/xfs/xfs_inode.c > index d2389bb..3ce50da 100644 > --- a/fs/xfs/xfs_inode.c > +++ b/fs/xfs/xfs_inode.c > @@ -1123,7 +1123,7 @@ xfs_create( > struct xfs_inode *ip = NULL; > struct xfs_trans *tp = NULL; > int error; > - xfs_bmap_free_t free_list; > + struct xfs_defer_ops free_list; > xfs_fsblock_t first_block; > bool unlock_dp_on_error = false; > prid_t prid; > @@ -1183,7 +1183,7 @@ xfs_create( > XFS_IOLOCK_PARENT | XFS_ILOCK_PARENT); > unlock_dp_on_error = true; > > - xfs_bmap_init(&free_list, &first_block); > + xfs_defer_init(&free_list, &first_block); > > /* > * Reserve disk quota and the inode. > @@ -1254,7 +1254,7 @@ xfs_create( > */ > xfs_qm_vop_create_dqattach(tp, ip, udqp, gdqp, pdqp); > > - error = xfs_bmap_finish(&tp, &free_list, NULL); > + error = xfs_defer_finish(&tp, &free_list, NULL); > if (error) > goto out_bmap_cancel; > > @@ -1270,7 +1270,7 @@ xfs_create( > return 0; > > out_bmap_cancel: > - xfs_bmap_cancel(&free_list); > + xfs_defer_cancel(&free_list); > out_trans_cancel: > xfs_trans_cancel(tp); > out_release_inode: > @@ -1402,7 +1402,7 @@ xfs_link( > xfs_mount_t *mp = tdp->i_mount; > xfs_trans_t *tp; > int error; > - xfs_bmap_free_t free_list; > + struct xfs_defer_ops free_list; > xfs_fsblock_t first_block; > int resblks; > > @@ -1453,7 +1453,7 @@ xfs_link( > goto error_return; > } > > - xfs_bmap_init(&free_list, &first_block); > + xfs_defer_init(&free_list, &first_block); > > /* > * Handle initial link state of O_TMPFILE inode > @@ -1483,9 +1483,9 @@ xfs_link( > if (mp->m_flags & (XFS_MOUNT_WSYNC|XFS_MOUNT_DIRSYNC)) > xfs_trans_set_sync(tp); > > - error = xfs_bmap_finish(&tp, &free_list, NULL); > + error = xfs_defer_finish(&tp, &free_list, NULL); > if (error) { > - xfs_bmap_cancel(&free_list); > + xfs_defer_cancel(&free_list); > goto error_return; > } > > @@ -1527,7 +1527,7 @@ xfs_itruncate_extents( > { > struct xfs_mount *mp = ip->i_mount; > struct xfs_trans *tp = *tpp; > - xfs_bmap_free_t free_list; > + struct xfs_defer_ops free_list; > xfs_fsblock_t first_block; > xfs_fileoff_t first_unmap_block; > xfs_fileoff_t last_block; > @@ -1563,7 +1563,7 @@ xfs_itruncate_extents( > ASSERT(first_unmap_block < last_block); > unmap_len = last_block - first_unmap_block + 1; > while (!done) { > - xfs_bmap_init(&free_list, &first_block); > + xfs_defer_init(&free_list, &first_block); > error = xfs_bunmapi(tp, ip, > first_unmap_block, unmap_len, > xfs_bmapi_aflag(whichfork), > @@ -1577,7 +1577,7 @@ xfs_itruncate_extents( > * Duplicate the transaction that has the permanent > * reservation and commit the old transaction. > */ > - error = xfs_bmap_finish(&tp, &free_list, ip); > + error = xfs_defer_finish(&tp, &free_list, ip); > if (error) > goto out_bmap_cancel; > > @@ -1603,7 +1603,7 @@ out_bmap_cancel: > * the transaction can be properly aborted. We just need to make sure > * we're not holding any resources that we were not when we came in. > */ > - xfs_bmap_cancel(&free_list); > + xfs_defer_cancel(&free_list); > goto out; > } > > @@ -1744,7 +1744,7 @@ STATIC int > xfs_inactive_ifree( > struct xfs_inode *ip) > { > - xfs_bmap_free_t free_list; > + struct xfs_defer_ops free_list; > xfs_fsblock_t first_block; > struct xfs_mount *mp = ip->i_mount; > struct xfs_trans *tp; > @@ -1781,7 +1781,7 @@ xfs_inactive_ifree( > xfs_ilock(ip, XFS_ILOCK_EXCL); > xfs_trans_ijoin(tp, ip, 0); > > - xfs_bmap_init(&free_list, &first_block); > + xfs_defer_init(&free_list, &first_block); > error = xfs_ifree(tp, ip, &free_list); > if (error) { > /* > @@ -1808,11 +1808,11 @@ xfs_inactive_ifree( > * Just ignore errors at this point. There is nothing we can do except > * to try to keep going. Make sure it's not a silent error. > */ > - error = xfs_bmap_finish(&tp, &free_list, NULL); > + error = xfs_defer_finish(&tp, &free_list, NULL); > if (error) { > - xfs_notice(mp, "%s: xfs_bmap_finish returned error %d", > + xfs_notice(mp, "%s: xfs_defer_finish returned error %d", > __func__, error); > - xfs_bmap_cancel(&free_list); > + xfs_defer_cancel(&free_list); > } > error = xfs_trans_commit(tp); > if (error) > @@ -2368,7 +2368,7 @@ int > xfs_ifree( > xfs_trans_t *tp, > xfs_inode_t *ip, > - xfs_bmap_free_t *flist) > + struct xfs_defer_ops *flist) > { > int error; > struct xfs_icluster xic = { 0 }; > @@ -2475,7 +2475,7 @@ xfs_iunpin_wait( > * directory entry. > * > * This is still safe from a transactional point of view - it is not until we > - * get to xfs_bmap_finish() that we have the possibility of multiple > + * get to xfs_defer_finish() that we have the possibility of multiple > * transactions in this operation. Hence as long as we remove the directory > * entry and drop the link count in the first transaction of the remove > * operation, there are no transactional constraints on the ordering here. > @@ -2490,7 +2490,7 @@ xfs_remove( > xfs_trans_t *tp = NULL; > int is_dir = S_ISDIR(VFS_I(ip)->i_mode); > int error = 0; > - xfs_bmap_free_t free_list; > + struct xfs_defer_ops free_list; > xfs_fsblock_t first_block; > uint resblks; > > @@ -2572,7 +2572,7 @@ xfs_remove( > if (error) > goto out_trans_cancel; > > - xfs_bmap_init(&free_list, &first_block); > + xfs_defer_init(&free_list, &first_block); > error = xfs_dir_removename(tp, dp, name, ip->i_ino, > &first_block, &free_list, resblks); > if (error) { > @@ -2588,7 +2588,7 @@ xfs_remove( > if (mp->m_flags & (XFS_MOUNT_WSYNC|XFS_MOUNT_DIRSYNC)) > xfs_trans_set_sync(tp); > > - error = xfs_bmap_finish(&tp, &free_list, NULL); > + error = xfs_defer_finish(&tp, &free_list, NULL); > if (error) > goto out_bmap_cancel; > > @@ -2602,7 +2602,7 @@ xfs_remove( > return 0; > > out_bmap_cancel: > - xfs_bmap_cancel(&free_list); > + xfs_defer_cancel(&free_list); > out_trans_cancel: > xfs_trans_cancel(tp); > std_return: > @@ -2663,7 +2663,7 @@ xfs_sort_for_rename( > static int > xfs_finish_rename( > struct xfs_trans *tp, > - struct xfs_bmap_free *free_list) > + struct xfs_defer_ops *free_list) > { > int error; > > @@ -2674,9 +2674,9 @@ xfs_finish_rename( > if (tp->t_mountp->m_flags & (XFS_MOUNT_WSYNC|XFS_MOUNT_DIRSYNC)) > xfs_trans_set_sync(tp); > > - error = xfs_bmap_finish(&tp, free_list, NULL); > + error = xfs_defer_finish(&tp, free_list, NULL); > if (error) { > - xfs_bmap_cancel(free_list); > + xfs_defer_cancel(free_list); > xfs_trans_cancel(tp); > return error; > } > @@ -2698,7 +2698,7 @@ xfs_cross_rename( > struct xfs_inode *dp2, > struct xfs_name *name2, > struct xfs_inode *ip2, > - struct xfs_bmap_free *free_list, > + struct xfs_defer_ops *free_list, > xfs_fsblock_t *first_block, > int spaceres) > { > @@ -2801,7 +2801,7 @@ xfs_cross_rename( > return xfs_finish_rename(tp, free_list); > > out_trans_abort: > - xfs_bmap_cancel(free_list); > + xfs_defer_cancel(free_list); > xfs_trans_cancel(tp); > return error; > } > @@ -2856,7 +2856,7 @@ xfs_rename( > { > struct xfs_mount *mp = src_dp->i_mount; > struct xfs_trans *tp; > - struct xfs_bmap_free free_list; > + struct xfs_defer_ops free_list; > xfs_fsblock_t first_block; > struct xfs_inode *wip = NULL; /* whiteout inode */ > struct xfs_inode *inodes[__XFS_SORT_INODES]; > @@ -2945,7 +2945,7 @@ xfs_rename( > goto out_trans_cancel; > } > > - xfs_bmap_init(&free_list, &first_block); > + xfs_defer_init(&free_list, &first_block); > > /* RENAME_EXCHANGE is unique from here on. */ > if (flags & RENAME_EXCHANGE) > @@ -3131,7 +3131,7 @@ xfs_rename( > return error; > > out_bmap_cancel: > - xfs_bmap_cancel(&free_list); > + xfs_defer_cancel(&free_list); > out_trans_cancel: > xfs_trans_cancel(tp); > out_release_wip: > diff --git a/fs/xfs/xfs_inode.h b/fs/xfs/xfs_inode.h > index 99d7522..633f2af 100644 > --- a/fs/xfs/xfs_inode.h > +++ b/fs/xfs/xfs_inode.h > @@ -27,7 +27,7 @@ > struct xfs_dinode; > struct xfs_inode; > struct xfs_buf; > -struct xfs_bmap_free; > +struct xfs_defer_ops; > struct xfs_bmbt_irec; > struct xfs_inode_log_item; > struct xfs_mount; > @@ -398,7 +398,7 @@ uint xfs_ilock_attr_map_shared(struct xfs_inode *); > > uint xfs_ip2xflags(struct xfs_inode *); > int xfs_ifree(struct xfs_trans *, xfs_inode_t *, > - struct xfs_bmap_free *); > + struct xfs_defer_ops *); > int xfs_itruncate_extents(struct xfs_trans **, struct xfs_inode *, > int, xfs_fsize_t); > void xfs_iext_realloc(xfs_inode_t *, int, int); > diff --git a/fs/xfs/xfs_iomap.c b/fs/xfs/xfs_iomap.c > index b090bc1..cb7abe84 100644 > --- a/fs/xfs/xfs_iomap.c > +++ b/fs/xfs/xfs_iomap.c > @@ -128,7 +128,7 @@ xfs_iomap_write_direct( > int quota_flag; > int rt; > xfs_trans_t *tp; > - xfs_bmap_free_t free_list; > + struct xfs_defer_ops free_list; > uint qblocks, resblks, resrtextents; > int error; > int lockmode; > @@ -231,7 +231,7 @@ xfs_iomap_write_direct( > * From this point onwards we overwrite the imap pointer that the > * caller gave to us. > */ > - xfs_bmap_init(&free_list, &firstfsb); > + xfs_defer_init(&free_list, &firstfsb); > nimaps = 1; > error = xfs_bmapi_write(tp, ip, offset_fsb, count_fsb, > bmapi_flags, &firstfsb, resblks, imap, > @@ -242,7 +242,7 @@ xfs_iomap_write_direct( > /* > * Complete the transaction > */ > - error = xfs_bmap_finish(&tp, &free_list, NULL); > + error = xfs_defer_finish(&tp, &free_list, NULL); > if (error) > goto out_bmap_cancel; > > @@ -266,7 +266,7 @@ out_unlock: > return error; > > out_bmap_cancel: > - xfs_bmap_cancel(&free_list); > + xfs_defer_cancel(&free_list); > xfs_trans_unreserve_quota_nblks(tp, ip, (long)qblocks, 0, quota_flag); > out_trans_cancel: > xfs_trans_cancel(tp); > @@ -685,7 +685,7 @@ xfs_iomap_write_allocate( > xfs_fileoff_t offset_fsb, last_block; > xfs_fileoff_t end_fsb, map_start_fsb; > xfs_fsblock_t first_block; > - xfs_bmap_free_t free_list; > + struct xfs_defer_ops free_list; > xfs_filblks_t count_fsb; > xfs_trans_t *tp; > int nimaps; > @@ -727,7 +727,7 @@ xfs_iomap_write_allocate( > xfs_ilock(ip, XFS_ILOCK_EXCL); > xfs_trans_ijoin(tp, ip, 0); > > - xfs_bmap_init(&free_list, &first_block); > + xfs_defer_init(&free_list, &first_block); > > /* > * it is possible that the extents have changed since > @@ -787,7 +787,7 @@ xfs_iomap_write_allocate( > if (error) > goto trans_cancel; > > - error = xfs_bmap_finish(&tp, &free_list, NULL); > + error = xfs_defer_finish(&tp, &free_list, NULL); > if (error) > goto trans_cancel; > > @@ -821,7 +821,7 @@ xfs_iomap_write_allocate( > } > > trans_cancel: > - xfs_bmap_cancel(&free_list); > + xfs_defer_cancel(&free_list); > xfs_trans_cancel(tp); > error0: > xfs_iunlock(ip, XFS_ILOCK_EXCL); > @@ -842,7 +842,7 @@ xfs_iomap_write_unwritten( > int nimaps; > xfs_trans_t *tp; > xfs_bmbt_irec_t imap; > - xfs_bmap_free_t free_list; > + struct xfs_defer_ops free_list; > xfs_fsize_t i_size; > uint resblks; > int error; > @@ -886,7 +886,7 @@ xfs_iomap_write_unwritten( > /* > * Modify the unwritten extent state of the buffer. > */ > - xfs_bmap_init(&free_list, &firstfsb); > + xfs_defer_init(&free_list, &firstfsb); > nimaps = 1; > error = xfs_bmapi_write(tp, ip, offset_fsb, count_fsb, > XFS_BMAPI_CONVERT, &firstfsb, resblks, > @@ -909,7 +909,7 @@ xfs_iomap_write_unwritten( > xfs_trans_log_inode(tp, ip, XFS_ILOG_CORE); > } > > - error = xfs_bmap_finish(&tp, &free_list, NULL); > + error = xfs_defer_finish(&tp, &free_list, NULL); > if (error) > goto error_on_bmapi_transaction; > > @@ -936,7 +936,7 @@ xfs_iomap_write_unwritten( > return 0; > > error_on_bmapi_transaction: > - xfs_bmap_cancel(&free_list); > + xfs_defer_cancel(&free_list); > xfs_trans_cancel(tp); > xfs_iunlock(ip, XFS_ILOCK_EXCL); > return error; > diff --git a/fs/xfs/xfs_rtalloc.c b/fs/xfs/xfs_rtalloc.c > index 627f7e6..c761a6a 100644 > --- a/fs/xfs/xfs_rtalloc.c > +++ b/fs/xfs/xfs_rtalloc.c > @@ -770,7 +770,7 @@ xfs_growfs_rt_alloc( > xfs_daddr_t d; /* disk block address */ > int error; /* error return value */ > xfs_fsblock_t firstblock;/* first block allocated in xaction */ > - struct xfs_bmap_free flist; /* list of freed blocks */ > + struct xfs_defer_ops flist; /* list of freed blocks */ > xfs_fsblock_t fsbno; /* filesystem block for bno */ > struct xfs_bmbt_irec map; /* block map output */ > int nmap; /* number of block maps */ > @@ -795,7 +795,7 @@ xfs_growfs_rt_alloc( > xfs_ilock(ip, XFS_ILOCK_EXCL); > xfs_trans_ijoin(tp, ip, XFS_ILOCK_EXCL); > > - xfs_bmap_init(&flist, &firstblock); > + xfs_defer_init(&flist, &firstblock); > /* > * Allocate blocks to the bitmap file. > */ > @@ -810,7 +810,7 @@ xfs_growfs_rt_alloc( > /* > * Free any blocks freed up in the transaction, then commit. > */ > - error = xfs_bmap_finish(&tp, &flist, NULL); > + error = xfs_defer_finish(&tp, &flist, NULL); > if (error) > goto out_bmap_cancel; > error = xfs_trans_commit(tp); > @@ -863,7 +863,7 @@ xfs_growfs_rt_alloc( > return 0; > > out_bmap_cancel: > - xfs_bmap_cancel(&flist); > + xfs_defer_cancel(&flist); > out_trans_cancel: > xfs_trans_cancel(tp); > return error; > diff --git a/fs/xfs/xfs_symlink.c b/fs/xfs/xfs_symlink.c > index 20af47b..3b005ec 100644 > --- a/fs/xfs/xfs_symlink.c > +++ b/fs/xfs/xfs_symlink.c > @@ -173,7 +173,7 @@ xfs_symlink( > struct xfs_inode *ip = NULL; > int error = 0; > int pathlen; > - struct xfs_bmap_free free_list; > + struct xfs_defer_ops free_list; > xfs_fsblock_t first_block; > bool unlock_dp_on_error = false; > xfs_fileoff_t first_fsb; > @@ -270,7 +270,7 @@ xfs_symlink( > * Initialize the bmap freelist prior to calling either > * bmapi or the directory create code. > */ > - xfs_bmap_init(&free_list, &first_block); > + xfs_defer_init(&free_list, &first_block); > > /* > * Allocate an inode for the symlink. > @@ -377,7 +377,7 @@ xfs_symlink( > xfs_trans_set_sync(tp); > } > > - error = xfs_bmap_finish(&tp, &free_list, NULL); > + error = xfs_defer_finish(&tp, &free_list, NULL); > if (error) > goto out_bmap_cancel; > > @@ -393,7 +393,7 @@ xfs_symlink( > return 0; > > out_bmap_cancel: > - xfs_bmap_cancel(&free_list); > + xfs_defer_cancel(&free_list); > out_trans_cancel: > xfs_trans_cancel(tp); > out_release_inode: > @@ -427,7 +427,7 @@ xfs_inactive_symlink_rmt( > int done; > int error; > xfs_fsblock_t first_block; > - xfs_bmap_free_t free_list; > + struct xfs_defer_ops free_list; > int i; > xfs_mount_t *mp; > xfs_bmbt_irec_t mval[XFS_SYMLINK_MAPS]; > @@ -466,7 +466,7 @@ xfs_inactive_symlink_rmt( > * Find the block(s) so we can inval and unmap them. > */ > done = 0; > - xfs_bmap_init(&free_list, &first_block); > + xfs_defer_init(&free_list, &first_block); > nmaps = ARRAY_SIZE(mval); > error = xfs_bmapi_read(ip, 0, xfs_symlink_blocks(mp, size), > mval, &nmaps, 0); > @@ -496,7 +496,7 @@ xfs_inactive_symlink_rmt( > /* > * Commit the first transaction. This logs the EFI and the inode. > */ > - error = xfs_bmap_finish(&tp, &free_list, ip); > + error = xfs_defer_finish(&tp, &free_list, ip); > if (error) > goto error_bmap_cancel; > /* > @@ -526,7 +526,7 @@ xfs_inactive_symlink_rmt( > return 0; > > error_bmap_cancel: > - xfs_bmap_cancel(&free_list); > + xfs_defer_cancel(&free_list); > error_trans_cancel: > xfs_trans_cancel(tp); > error_unlock: > > _______________________________________________ > xfs mailing list > xfs@xxxxxxxxxxx > http://oss.sgi.com/mailman/listinfo/xfs _______________________________________________ xfs mailing list xfs@xxxxxxxxxxx http://oss.sgi.com/mailman/listinfo/xfs