diff options
Diffstat (limited to 'fs/mpage.c')
| -rw-r--r-- | fs/mpage.c | 27 | 
1 files changed, 17 insertions, 10 deletions
| diff --git a/fs/mpage.c b/fs/mpage.c index a7c34274f207..1480d3a18037 100644 --- a/fs/mpage.c +++ b/fs/mpage.c @@ -361,7 +361,7 @@ mpage_readpages(struct address_space *mapping, struct list_head *pages,  	sector_t last_block_in_bio = 0;  	struct buffer_head map_bh;  	unsigned long first_logical_block = 0; -	gfp_t gfp = GFP_KERNEL & mapping_gfp_mask(mapping); +	gfp_t gfp = mapping_gfp_constraint(mapping, GFP_KERNEL);  	map_bh.b_state = 0;  	map_bh.b_size = 0; @@ -397,7 +397,7 @@ int mpage_readpage(struct page *page, get_block_t get_block)  	sector_t last_block_in_bio = 0;  	struct buffer_head map_bh;  	unsigned long first_logical_block = 0; -	gfp_t gfp = GFP_KERNEL & mapping_gfp_mask(page->mapping); +	gfp_t gfp = mapping_gfp_constraint(page->mapping, GFP_KERNEL);  	map_bh.b_state = 0;  	map_bh.b_size = 0; @@ -485,6 +485,7 @@ static int __mpage_writepage(struct page *page, struct writeback_control *wbc,  	struct buffer_head map_bh;  	loff_t i_size = i_size_read(inode);  	int ret = 0; +	int wr = (wbc->sync_mode == WB_SYNC_ALL ?  WRITE_SYNC : WRITE);  	if (page_has_buffers(page)) {  		struct buffer_head *head = page_buffers(page); @@ -593,7 +594,7 @@ page_is_mapped:  	 * This page will go to BIO.  Do we need to send this BIO off first?  	 */  	if (bio && mpd->last_block_in_bio != blocks[0] - 1) -		bio = mpage_bio_submit(WRITE, bio); +		bio = mpage_bio_submit(wr, bio);  alloc_new:  	if (bio == NULL) { @@ -620,7 +621,7 @@ alloc_new:  	wbc_account_io(wbc, page, PAGE_SIZE);  	length = first_unmapped << blkbits;  	if (bio_add_page(bio, page, length, 0) < length) { -		bio = mpage_bio_submit(WRITE, bio); +		bio = mpage_bio_submit(wr, bio);  		goto alloc_new;  	} @@ -630,7 +631,7 @@ alloc_new:  	set_page_writeback(page);  	unlock_page(page);  	if (boundary || (first_unmapped != blocks_per_page)) { -		bio = mpage_bio_submit(WRITE, bio); +		bio = mpage_bio_submit(wr, bio);  		if (boundary_block) {  			write_boundary_block(boundary_bdev,  					boundary_block, 1 << blkbits); @@ -642,7 +643,7 @@ alloc_new:  confused:  	if (bio) -		bio = mpage_bio_submit(WRITE, bio); +		bio = mpage_bio_submit(wr, bio);  	if (mpd->use_writepage) {  		ret = mapping->a_ops->writepage(page, wbc); @@ -698,8 +699,11 @@ mpage_writepages(struct address_space *mapping,  		};  		ret = write_cache_pages(mapping, wbc, __mpage_writepage, &mpd); -		if (mpd.bio) -			mpage_bio_submit(WRITE, mpd.bio); +		if (mpd.bio) { +			int wr = (wbc->sync_mode == WB_SYNC_ALL ? +				  WRITE_SYNC : WRITE); +			mpage_bio_submit(wr, mpd.bio); +		}  	}  	blk_finish_plug(&plug);  	return ret; @@ -716,8 +720,11 @@ int mpage_writepage(struct page *page, get_block_t get_block,  		.use_writepage = 0,  	};  	int ret = __mpage_writepage(page, wbc, &mpd); -	if (mpd.bio) -		mpage_bio_submit(WRITE, mpd.bio); +	if (mpd.bio) { +		int wr = (wbc->sync_mode == WB_SYNC_ALL ? +			  WRITE_SYNC : WRITE); +		mpage_bio_submit(wr, mpd.bio); +	}  	return ret;  }  EXPORT_SYMBOL(mpage_writepage); | 
