diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2012-07-16 10:02:36 -0700 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2012-07-16 10:02:36 -0700 | 
| commit | fce667c5742dbbef8a9c7c13a139d43db6ed609e (patch) | |
| tree | 82578fa4f548992fe201b0a469ef872cb5bfbbae /fs/xfs/xfs_buf.c | |
| parent | 3e997130bd2e8c6f5aaa49d6e3161d4d29b43ab0 (diff) | |
| parent | 1632dcc93f55f9ab407b373da1957a727b1a7fe3 (diff) | |
Merge tag 'for-linus-v3.5-rc7' of git://oss.sgi.com/xfs/xfs
Pull xfs regression fixes from Ben Myers:
 - Really fix a cursor leak in xfs_alloc_ag_vextent_near
 - Fix a performance regression related to doing allocation in
   workqueues
 - Prevent recursion in xfs_buf_iorequest which is causing stack
   overflows
 - Don't call xfs_bdstrat_cb in xfs_buf_iodone callbacks
* tag 'for-linus-v3.5-rc7' of git://oss.sgi.com/xfs/xfs:
  xfs: do not call xfs_bdstrat_cb in xfs_buf_iodone_callbacks
  xfs: prevent recursion in xfs_buf_iorequest
  xfs: don't defer metadata allocation to the workqueue
  xfs: really fix the cursor leak in xfs_alloc_ag_vextent_near
Diffstat (limited to 'fs/xfs/xfs_buf.c')
| -rw-r--r-- | fs/xfs/xfs_buf.c | 53 | 
1 files changed, 23 insertions, 30 deletions
diff --git a/fs/xfs/xfs_buf.c b/fs/xfs/xfs_buf.c index a4beb421018a..269b35c084da 100644 --- a/fs/xfs/xfs_buf.c +++ b/fs/xfs/xfs_buf.c @@ -989,27 +989,6 @@ xfs_buf_ioerror_alert(  		(__uint64_t)XFS_BUF_ADDR(bp), func, bp->b_error, bp->b_length);  } -int -xfs_bwrite( -	struct xfs_buf		*bp) -{ -	int			error; - -	ASSERT(xfs_buf_islocked(bp)); - -	bp->b_flags |= XBF_WRITE; -	bp->b_flags &= ~(XBF_ASYNC | XBF_READ | _XBF_DELWRI_Q); - -	xfs_bdstrat_cb(bp); - -	error = xfs_buf_iowait(bp); -	if (error) { -		xfs_force_shutdown(bp->b_target->bt_mount, -				   SHUTDOWN_META_IO_ERROR); -	} -	return error; -} -  /*   * Called when we want to stop a buffer from getting written or read.   * We attach the EIO error, muck with its flags, and call xfs_buf_ioend @@ -1079,14 +1058,7 @@ xfs_bioerror_relse(  	return EIO;  } - -/* - * All xfs metadata buffers except log state machine buffers - * get this attached as their b_bdstrat callback function. - * This is so that we can catch a buffer - * after prematurely unpinning it to forcibly shutdown the filesystem. - */ -int +STATIC int  xfs_bdstrat_cb(  	struct xfs_buf	*bp)  { @@ -1107,6 +1079,27 @@ xfs_bdstrat_cb(  	return 0;  } +int +xfs_bwrite( +	struct xfs_buf		*bp) +{ +	int			error; + +	ASSERT(xfs_buf_islocked(bp)); + +	bp->b_flags |= XBF_WRITE; +	bp->b_flags &= ~(XBF_ASYNC | XBF_READ | _XBF_DELWRI_Q); + +	xfs_bdstrat_cb(bp); + +	error = xfs_buf_iowait(bp); +	if (error) { +		xfs_force_shutdown(bp->b_target->bt_mount, +				   SHUTDOWN_META_IO_ERROR); +	} +	return error; +} +  /*   * Wrapper around bdstrat so that we can stop data from going to disk in case   * we are shutting down the filesystem.  Typically user data goes thru this @@ -1243,7 +1236,7 @@ xfs_buf_iorequest(  	 */  	atomic_set(&bp->b_io_remaining, 1);  	_xfs_buf_ioapply(bp); -	_xfs_buf_ioend(bp, 0); +	_xfs_buf_ioend(bp, 1);  	xfs_buf_rele(bp);  }  | 
