aboutsummaryrefslogtreecommitdiffstats
path: root/mm
diff options
context:
space:
mode:
Diffstat (limited to 'mm')
-rw-r--r--mm/truncate.c9
1 files changed, 5 insertions, 4 deletions
diff --git a/mm/truncate.c b/mm/truncate.c
index bf9e2965d666..89a5c359b6e8 100644
--- a/mm/truncate.c
+++ b/mm/truncate.c
@@ -60,11 +60,12 @@ void cancel_dirty_page(struct page *page, unsigned int account_size)
60 WARN_ON(++warncount < 5); 60 WARN_ON(++warncount < 5);
61 } 61 }
62 62
63 if (TestClearPageDirty(page) && account_size) 63 if (TestClearPageDirty(page) && account_size) {
64 dec_zone_page_state(page, NR_FILE_DIRTY);
64 task_io_account_cancelled_write(account_size); 65 task_io_account_cancelled_write(account_size);
66 }
65} 67}
66 68
67
68/* 69/*
69 * If truncate cannot remove the fs-private metadata from the page, the page 70 * If truncate cannot remove the fs-private metadata from the page, the page
70 * becomes anonymous. It will be left on the LRU and may even be mapped into 71 * becomes anonymous. It will be left on the LRU and may even be mapped into
@@ -81,11 +82,11 @@ truncate_complete_page(struct address_space *mapping, struct page *page)
81 if (page->mapping != mapping) 82 if (page->mapping != mapping)
82 return; 83 return;
83 84
85 cancel_dirty_page(page, PAGE_CACHE_SIZE);
86
84 if (PagePrivate(page)) 87 if (PagePrivate(page))
85 do_invalidatepage(page, 0); 88 do_invalidatepage(page, 0);
86 89
87 cancel_dirty_page(page, PAGE_CACHE_SIZE);
88
89 ClearPageUptodate(page); 90 ClearPageUptodate(page);
90 ClearPageMappedToDisk(page); 91 ClearPageMappedToDisk(page);
91 remove_from_page_cache(page); 92 remove_from_page_cache(page);