Hi Dave, On Thu, Jul 12, 2012 at 07:40:42AM +1000, Dave Chinner wrote: > From: Dave Chinner <dchinner@xxxxxxxxxx> > > The current cursor is reallocated when retrying the allocation, so > the existing cursor needs to be destroyed in both the restart and > the failure cases. > > Signed-off-by: Dave Chinner <dchinner@xxxxxxxxxx> > Tested-by: Mike Snitzer <snitzer@xxxxxxxxxx> > --- > fs/xfs/xfs_alloc.c | 4 ++-- > 1 file changed, 2 insertions(+), 2 deletions(-) > > diff --git a/fs/xfs/xfs_alloc.c b/fs/xfs/xfs_alloc.c > index 9d1aeb7..f654f51 100644 > --- a/fs/xfs/xfs_alloc.c > +++ b/fs/xfs/xfs_alloc.c > @@ -1074,13 +1074,13 @@ restart: > * If we couldn't get anything, give up. > */ > if (bno_cur_lt == NULL && bno_cur_gt == NULL) { > + xfs_btree_del_cursor(cnt_cur, XFS_BTREE_NOERROR); > + I'd suggest setting cnt_cur = NULL here, but it is very clearly overwritten right away in the case of goto restart. No need. This looks good to me. I'll pull this in today. Reviewed-by: Ben Myers <bpm@xxxxxxx> Regards, Ben > if (!forced++) { > trace_xfs_alloc_near_busy(args); > xfs_log_force(args->mp, XFS_LOG_SYNC); > goto restart; > } > - > - xfs_btree_del_cursor(cnt_cur, XFS_BTREE_NOERROR); > trace_xfs_alloc_size_neither(args); > args->agbno = NULLAGBLOCK; > return 0; > -- > 1.7.10 > > _______________________________________________ > xfs mailing list > xfs@xxxxxxxxxxx > http://oss.sgi.com/mailman/listinfo/xfs _______________________________________________ xfs mailing list xfs@xxxxxxxxxxx http://oss.sgi.com/mailman/listinfo/xfs