diff options
| author | Christoph Hellwig <hch@infradead.org> | 2010-08-18 05:29:17 -0400 | 
|---|---|---|
| committer | Jens Axboe <jaxboe@fusionio.com> | 2010-09-10 12:35:39 +0200 | 
| commit | 9c35575bbe6b1dd4914a5323c8df8b3159edcc75 (patch) | |
| tree | 537c521af9d3cfcd1d9031cad99ac349b586fc03 /fs/jbd2 | |
| parent | f73bee49855fe968e87af18e44f2d17e1e675e74 (diff) | |
jbd2: replace barriers with explicit flush / FUA usage
Switch to the WRITE_FLUSH_FUA flag for journal commits and remove the
EOPNOTSUPP detection for barriers.
Signed-off-by: Christoph Hellwig <hch@lst.de>
Acked-by: Jan Kara <jack@suse.cz>
Signed-off-by: Tejun Heo <tj@kernel.org>
Signed-off-by: Jens Axboe <jaxboe@fusionio.com>
Diffstat (limited to 'fs/jbd2')
| -rw-r--r-- | fs/jbd2/commit.c | 43 | 
1 files changed, 4 insertions, 39 deletions
| diff --git a/fs/jbd2/commit.c b/fs/jbd2/commit.c index d6aeb1f6cfe..f204e27f44d 100644 --- a/fs/jbd2/commit.c +++ b/fs/jbd2/commit.c @@ -134,25 +134,11 @@ static int journal_submit_commit_record(journal_t *journal,  	if (journal->j_flags & JBD2_BARRIER &&  	    !JBD2_HAS_INCOMPAT_FEATURE(journal, -				       JBD2_FEATURE_INCOMPAT_ASYNC_COMMIT)) { -		ret = submit_bh(WRITE_SYNC_PLUG | WRITE_BARRIER, bh); -		if (ret == -EOPNOTSUPP) { -			printk(KERN_WARNING -			       "JBD2: Disabling barriers on %s, " -			       "not supported by device\n", journal->j_devname); -			write_lock(&journal->j_state_lock); -			journal->j_flags &= ~JBD2_BARRIER; -			write_unlock(&journal->j_state_lock); - -			/* And try again, without the barrier */ -			lock_buffer(bh); -			set_buffer_uptodate(bh); -			clear_buffer_dirty(bh); -			ret = submit_bh(WRITE_SYNC_PLUG, bh); -		} -	} else { +				       JBD2_FEATURE_INCOMPAT_ASYNC_COMMIT)) +		ret = submit_bh(WRITE_SYNC_PLUG | WRITE_FLUSH_FUA, bh); +	else  		ret = submit_bh(WRITE_SYNC_PLUG, bh); -	} +  	*cbh = bh;  	return ret;  } @@ -166,29 +152,8 @@ static int journal_wait_on_commit_record(journal_t *journal,  {  	int ret = 0; -retry:  	clear_buffer_dirty(bh);  	wait_on_buffer(bh); -	if (buffer_eopnotsupp(bh) && (journal->j_flags & JBD2_BARRIER)) { -		printk(KERN_WARNING -		       "JBD2: %s: disabling barries on %s - not supported " -		       "by device\n", __func__, journal->j_devname); -		write_lock(&journal->j_state_lock); -		journal->j_flags &= ~JBD2_BARRIER; -		write_unlock(&journal->j_state_lock); - -		lock_buffer(bh); -		clear_buffer_dirty(bh); -		set_buffer_uptodate(bh); -		bh->b_end_io = journal_end_buffer_io_sync; - -		ret = submit_bh(WRITE_SYNC_PLUG, bh); -		if (ret) { -			unlock_buffer(bh); -			return ret; -		} -		goto retry; -	}  	if (unlikely(!buffer_uptodate(bh)))  		ret = -EIO; | 
