diff options
Diffstat (limited to 'fs/xfs/linux-2.6')
| -rw-r--r-- | fs/xfs/linux-2.6/xfs_aops.c | 4 | ||||
| -rw-r--r-- | fs/xfs/linux-2.6/xfs_buf.c | 13 | 
2 files changed, 6 insertions, 11 deletions
| diff --git a/fs/xfs/linux-2.6/xfs_aops.c b/fs/xfs/linux-2.6/xfs_aops.c index 8c5c87277456..52dbd14260ba 100644 --- a/fs/xfs/linux-2.6/xfs_aops.c +++ b/fs/xfs/linux-2.6/xfs_aops.c @@ -413,8 +413,7 @@ xfs_submit_ioend_bio(  	if (xfs_ioend_new_eof(ioend))  		xfs_mark_inode_dirty(XFS_I(ioend->io_inode)); -	submit_bio(wbc->sync_mode == WB_SYNC_ALL ? -		   WRITE_SYNC_PLUG : WRITE, bio); +	submit_bio(wbc->sync_mode == WB_SYNC_ALL ? WRITE_SYNC : WRITE, bio);  }  STATIC struct bio * @@ -1495,7 +1494,6 @@ const struct address_space_operations xfs_address_space_operations = {  	.readpages		= xfs_vm_readpages,  	.writepage		= xfs_vm_writepage,  	.writepages		= xfs_vm_writepages, -	.sync_page		= block_sync_page,  	.releasepage		= xfs_vm_releasepage,  	.invalidatepage		= xfs_vm_invalidatepage,  	.write_begin		= xfs_vm_write_begin, diff --git a/fs/xfs/linux-2.6/xfs_buf.c b/fs/xfs/linux-2.6/xfs_buf.c index 5cb230f2cb4f..c05324d3282c 100644 --- a/fs/xfs/linux-2.6/xfs_buf.c +++ b/fs/xfs/linux-2.6/xfs_buf.c @@ -990,7 +990,7 @@ xfs_buf_lock(  	if (atomic_read(&bp->b_pin_count) && (bp->b_flags & XBF_STALE))  		xfs_log_force(bp->b_target->bt_mount, 0);  	if (atomic_read(&bp->b_io_remaining)) -		blk_run_address_space(bp->b_target->bt_mapping); +		blk_flush_plug(current);  	down(&bp->b_sema);  	XB_SET_OWNER(bp); @@ -1034,9 +1034,7 @@ xfs_buf_wait_unpin(  		set_current_state(TASK_UNINTERRUPTIBLE);  		if (atomic_read(&bp->b_pin_count) == 0)  			break; -		if (atomic_read(&bp->b_io_remaining)) -			blk_run_address_space(bp->b_target->bt_mapping); -		schedule(); +		io_schedule();  	}  	remove_wait_queue(&bp->b_waiters, &wait);  	set_current_state(TASK_RUNNING); @@ -1442,7 +1440,7 @@ xfs_buf_iowait(  	trace_xfs_buf_iowait(bp, _RET_IP_);  	if (atomic_read(&bp->b_io_remaining)) -		blk_run_address_space(bp->b_target->bt_mapping); +		blk_flush_plug(current);  	wait_for_completion(&bp->b_iowait);  	trace_xfs_buf_iowait_done(bp, _RET_IP_); @@ -1666,7 +1664,6 @@ xfs_mapping_buftarg(  	struct inode		*inode;  	struct address_space	*mapping;  	static const struct address_space_operations mapping_aops = { -		.sync_page = block_sync_page,  		.migratepage = fail_migrate_page,  	}; @@ -1947,7 +1944,7 @@ xfsbufd(  			count++;  		}  		if (count) -			blk_run_address_space(target->bt_mapping); +			blk_flush_plug(current);  	} while (!kthread_should_stop()); @@ -1995,7 +1992,7 @@ xfs_flush_buftarg(  	if (wait) {  		/* Expedite and wait for IO to complete. */ -		blk_run_address_space(target->bt_mapping); +		blk_flush_plug(current);  		while (!list_empty(&wait_list)) {  			bp = list_first_entry(&wait_list, struct xfs_buf, b_list); | 
