aboutsummaryrefslogtreecommitdiffstats
path: root/fs/ext4/inode.c
diff options
context:
space:
mode:
Diffstat (limited to 'fs/ext4/inode.c')
-rw-r--r--fs/ext4/inode.c74
1 files changed, 32 insertions, 42 deletions
diff --git a/fs/ext4/inode.c b/fs/ext4/inode.c
index 008b28a859d0..24d0f9d2b320 100644
--- a/fs/ext4/inode.c
+++ b/fs/ext4/inode.c
@@ -2242,47 +2242,6 @@ static int __mpage_da_writepage(struct page *page,
2242} 2242}
2243 2243
2244/* 2244/*
2245 * mpage_da_writepages - walk the list of dirty pages of the given
2246 * address space, allocates non-allocated blocks, maps newly-allocated
2247 * blocks to existing bhs and issue IO them
2248 *
2249 * @mapping: address space structure to write
2250 * @wbc: subtract the number of written pages from *@wbc->nr_to_write
2251 *
2252 * This is a library function, which implements the writepages()
2253 * address_space_operation.
2254 */
2255static int mpage_da_writepages(struct address_space *mapping,
2256 struct writeback_control *wbc,
2257 struct mpage_da_data *mpd)
2258{
2259 int ret;
2260
2261 mpd->b_size = 0;
2262 mpd->b_state = 0;
2263 mpd->b_blocknr = 0;
2264 mpd->first_page = 0;
2265 mpd->next_page = 0;
2266 mpd->io_done = 0;
2267 mpd->pages_written = 0;
2268 mpd->retval = 0;
2269
2270 ret = write_cache_pages(mapping, wbc, __mpage_da_writepage, mpd);
2271 /*
2272 * Handle last extent of pages
2273 */
2274 if (!mpd->io_done && mpd->next_page != mpd->first_page) {
2275 if (mpage_da_map_blocks(mpd) == 0)
2276 mpage_da_submit_io(mpd);
2277
2278 mpd->io_done = 1;
2279 ret = MPAGE_DA_EXTENT_TAIL;
2280 }
2281 wbc->nr_to_write -= mpd->pages_written;
2282 return ret;
2283}
2284
2285/*
2286 * this is a special callback for ->write_begin() only 2245 * this is a special callback for ->write_begin() only
2287 * it's intention is to return mapped block or reserve space 2246 * it's intention is to return mapped block or reserve space
2288 */ 2247 */
@@ -2571,7 +2530,38 @@ retry:
2571 dump_stack(); 2530 dump_stack();
2572 goto out_writepages; 2531 goto out_writepages;
2573 } 2532 }
2574 ret = mpage_da_writepages(mapping, wbc, &mpd); 2533
2534 /*
2535 * Now call __mpage_da_writepage to find the next
2536 * contiguous region of logical blocks that need
2537 * blocks to be allocated by ext4. We don't actually
2538 * submit the blocks for I/O here, even though
2539 * write_cache_pages thinks it will, and will set the
2540 * pages as clean for write before calling
2541 * __mpage_da_writepage().
2542 */
2543 mpd.b_size = 0;
2544 mpd.b_state = 0;
2545 mpd.b_blocknr = 0;
2546 mpd.first_page = 0;
2547 mpd.next_page = 0;
2548 mpd.io_done = 0;
2549 mpd.pages_written = 0;
2550 mpd.retval = 0;
2551 ret = write_cache_pages(mapping, wbc, __mpage_da_writepage,
2552 &mpd);
2553 /*
2554 * If we have a contigous extent of pages and we
2555 * haven't done the I/O yet, map the blocks and submit
2556 * them for I/O.
2557 */
2558 if (!mpd.io_done && mpd.next_page != mpd.first_page) {
2559 if (mpage_da_map_blocks(&mpd) == 0)
2560 mpage_da_submit_io(&mpd);
2561 mpd.io_done = 1;
2562 ret = MPAGE_DA_EXTENT_TAIL;
2563 }
2564 wbc->nr_to_write -= mpd.pages_written;
2575 2565
2576 ext4_journal_stop(handle); 2566 ext4_journal_stop(handle);
2577 2567