On 3/24/15 5:59 AM, Dave Chinner wrote: > From: Dave Chinner <dchinner@xxxxxxxxxx> > > Rather than use a jump label for the final transaction commit in > the rename, factor it into a simple helper function and call it > appropriately. This slightly reduces the spaghetti nature of > xfs_rename. Nit, subject should be "xfs_finish_rename" not "xfs_rename_finish" -Eric > Signed-off-by: Dave Chinner <dchinner@xxxxxxxxxx> > --- > fs/xfs/xfs_inode.c | 48 +++++++++++++++++++++++++++--------------------- > 1 file changed, 27 insertions(+), 21 deletions(-) > > diff --git a/fs/xfs/xfs_inode.c b/fs/xfs/xfs_inode.c > index 981e036..4a13a48 100644 > --- a/fs/xfs/xfs_inode.c > +++ b/fs/xfs/xfs_inode.c > @@ -2716,6 +2716,31 @@ xfs_sort_for_rename( > } > } > > +static int > +xfs_finish_rename( > + struct xfs_trans *tp, > + struct xfs_bmap_free *free_list) > +{ > + int committed = 0; > + int error; > + > + /* > + * If this is a synchronous mount, make sure that the rename transaction > + * goes to disk before returning to the user. > + */ > + if (tp->t_mountp->m_flags & (XFS_MOUNT_WSYNC|XFS_MOUNT_DIRSYNC)) > + xfs_trans_set_sync(tp); > + > + error = xfs_bmap_finish(&tp, free_list, &committed); > + if (error) { > + xfs_bmap_cancel(free_list); > + xfs_trans_cancel(tp, XFS_TRANS_RELEASE_LOG_RES|XFS_TRANS_ABORT); > + return error; > + } > + > + return xfs_trans_commit(tp, XFS_TRANS_RELEASE_LOG_RES); > +} > + > /* > * xfs_cross_rename() > * > @@ -2855,7 +2880,6 @@ xfs_rename( > xfs_bmap_free_t free_list; > xfs_fsblock_t first_block; > int cancel_flags = 0; > - int committed; > xfs_inode_t *inodes[__XFS_SORT_INODES]; > int num_inodes = __XFS_SORT_INODES; > int spaceres; > @@ -2932,7 +2956,7 @@ xfs_rename( > &free_list, &first_block, spaceres); > if (error) > goto out_trans_abort; > - goto finish_rename; > + return xfs_finish_rename(tp, &free_list); > } > > /* > @@ -3074,25 +3098,7 @@ xfs_rename( > if (new_parent) > xfs_trans_log_inode(tp, target_dp, XFS_ILOG_CORE); > > -finish_rename: > - /* > - * If this is a synchronous mount, make sure that the > - * rename transaction goes to disk before returning to > - * the user. > - */ > - if (mp->m_flags & (XFS_MOUNT_WSYNC|XFS_MOUNT_DIRSYNC)) { > - xfs_trans_set_sync(tp); > - } > - > - error = xfs_bmap_finish(&tp, &free_list, &committed); > - if (error) > - goto out_trans_abort; > - > - /* > - * trans_commit will unlock src_ip, target_ip & decrement > - * the vnode references. > - */ > - return xfs_trans_commit(tp, XFS_TRANS_RELEASE_LOG_RES); > + return xfs_finish_rename(tp, &free_list); > > out_trans_abort: > cancel_flags |= XFS_TRANS_ABORT; > _______________________________________________ xfs mailing list xfs@xxxxxxxxxxx http://oss.sgi.com/mailman/listinfo/xfs