diff options
Diffstat (limited to 'fs/nfs')
-rw-r--r-- | fs/nfs/write.c | 57 |
1 files changed, 33 insertions, 24 deletions
diff --git a/fs/nfs/write.c b/fs/nfs/write.c index 0c346d79fb34..667ff27ef235 100644 --- a/fs/nfs/write.c +++ b/fs/nfs/write.c | |||
@@ -292,41 +292,51 @@ static int nfs_page_async_flush(struct nfs_pageio_descriptor *pgio, | |||
292 | return 0; | 292 | return 0; |
293 | } | 293 | } |
294 | 294 | ||
295 | /* | 295 | static int nfs_do_writepage(struct page *page, struct writeback_control *wbc, struct nfs_pageio_descriptor *pgio) |
296 | * Write an mmapped page to the server. | ||
297 | */ | ||
298 | static int nfs_writepage_locked(struct page *page, struct writeback_control *wbc) | ||
299 | { | 296 | { |
300 | struct nfs_pageio_descriptor mypgio, *pgio; | ||
301 | struct inode *inode = page->mapping->host; | 297 | struct inode *inode = page->mapping->host; |
302 | int err; | ||
303 | 298 | ||
304 | nfs_inc_stats(inode, NFSIOS_VFSWRITEPAGE); | 299 | nfs_inc_stats(inode, NFSIOS_VFSWRITEPAGE); |
305 | nfs_add_stats(inode, NFSIOS_WRITEPAGES, 1); | 300 | nfs_add_stats(inode, NFSIOS_WRITEPAGES, 1); |
306 | 301 | ||
307 | if (wbc->for_writepages) | ||
308 | pgio = wbc->fs_private; | ||
309 | else { | ||
310 | nfs_pageio_init_write(&mypgio, inode, wb_priority(wbc)); | ||
311 | pgio = &mypgio; | ||
312 | } | ||
313 | |||
314 | nfs_pageio_cond_complete(pgio, page->index); | 302 | nfs_pageio_cond_complete(pgio, page->index); |
303 | return nfs_page_async_flush(pgio, page); | ||
304 | } | ||
315 | 305 | ||
316 | err = nfs_page_async_flush(pgio, page); | 306 | /* |
307 | * Write an mmapped page to the server. | ||
308 | */ | ||
309 | static int nfs_writepage_locked(struct page *page, struct writeback_control *wbc) | ||
310 | { | ||
311 | struct nfs_pageio_descriptor pgio; | ||
312 | int err; | ||
317 | 313 | ||
318 | if (!wbc->for_writepages) | 314 | nfs_pageio_init_write(&pgio, page->mapping->host, wb_priority(wbc)); |
319 | nfs_pageio_complete(pgio); | 315 | err = nfs_do_writepage(page, wbc, &pgio); |
320 | return err; | 316 | nfs_pageio_complete(&pgio); |
317 | if (err < 0) | ||
318 | return err; | ||
319 | if (pgio.pg_error < 0) | ||
320 | return pgio.pg_error; | ||
321 | return 0; | ||
321 | } | 322 | } |
322 | 323 | ||
323 | int nfs_writepage(struct page *page, struct writeback_control *wbc) | 324 | int nfs_writepage(struct page *page, struct writeback_control *wbc) |
324 | { | 325 | { |
325 | int err; | 326 | int ret; |
326 | 327 | ||
327 | err = nfs_writepage_locked(page, wbc); | 328 | ret = nfs_writepage_locked(page, wbc); |
328 | unlock_page(page); | 329 | unlock_page(page); |
329 | return err; | 330 | return ret; |
331 | } | ||
332 | |||
333 | static int nfs_writepages_callback(struct page *page, struct writeback_control *wbc, void *data) | ||
334 | { | ||
335 | int ret; | ||
336 | |||
337 | ret = nfs_do_writepage(page, wbc, data); | ||
338 | unlock_page(page); | ||
339 | return ret; | ||
330 | } | 340 | } |
331 | 341 | ||
332 | int nfs_writepages(struct address_space *mapping, struct writeback_control *wbc) | 342 | int nfs_writepages(struct address_space *mapping, struct writeback_control *wbc) |
@@ -338,12 +348,11 @@ int nfs_writepages(struct address_space *mapping, struct writeback_control *wbc) | |||
338 | nfs_inc_stats(inode, NFSIOS_VFSWRITEPAGES); | 348 | nfs_inc_stats(inode, NFSIOS_VFSWRITEPAGES); |
339 | 349 | ||
340 | nfs_pageio_init_write(&pgio, inode, wb_priority(wbc)); | 350 | nfs_pageio_init_write(&pgio, inode, wb_priority(wbc)); |
341 | wbc->fs_private = &pgio; | 351 | err = write_cache_pages(mapping, wbc, nfs_writepages_callback, &pgio); |
342 | err = generic_writepages(mapping, wbc); | ||
343 | nfs_pageio_complete(&pgio); | 352 | nfs_pageio_complete(&pgio); |
344 | if (err) | 353 | if (err < 0) |
345 | return err; | 354 | return err; |
346 | if (pgio.pg_error) | 355 | if (pgio.pg_error < 0) |
347 | return pgio.pg_error; | 356 | return pgio.pg_error; |
348 | return 0; | 357 | return 0; |
349 | } | 358 | } |