mm: refactor truncate_complete_page()
[sfrench/cifs-2.6.git] / mm / truncate.c
index 2330223841fbbdf40c4e50764a11a557d9c7b426..383a530d511edd9edc25b7d535366fae7a3b0ee1 100644 (file)
@@ -134,11 +134,17 @@ void do_invalidatepage(struct page *page, unsigned int offset,
  * its lock, b) when a concurrent invalidate_mapping_pages got there first and
  * c) when tmpfs swizzles a page between a tmpfs inode and swapper_space.
  */
-static int
-truncate_complete_page(struct address_space *mapping, struct page *page)
+static void
+truncate_cleanup_page(struct address_space *mapping, struct page *page)
 {
-       if (page->mapping != mapping)
-               return -EIO;
+       if (page_mapped(page)) {
+               loff_t holelen;
+
+               holelen = PageTransHuge(page) ? HPAGE_PMD_SIZE : PAGE_SIZE;
+               unmap_mapping_range(mapping,
+                                  (loff_t)page->index << PAGE_SHIFT,
+                                  holelen, 0);
+       }
 
        if (page_has_private(page))
                do_invalidatepage(page, 0, PAGE_SIZE);
@@ -150,8 +156,6 @@ truncate_complete_page(struct address_space *mapping, struct page *page)
         */
        cancel_dirty_page(page);
        ClearPageMappedToDisk(page);
-       delete_from_page_cache(page);
-       return 0;
 }
 
 /*
@@ -180,16 +184,14 @@ invalidate_complete_page(struct address_space *mapping, struct page *page)
 
 int truncate_inode_page(struct address_space *mapping, struct page *page)
 {
-       loff_t holelen;
        VM_BUG_ON_PAGE(PageTail(page), page);
 
-       holelen = PageTransHuge(page) ? HPAGE_PMD_SIZE : PAGE_SIZE;
-       if (page_mapped(page)) {
-               unmap_mapping_range(mapping,
-                                  (loff_t)page->index << PAGE_SHIFT,
-                                  holelen, 0);
-       }
-       return truncate_complete_page(mapping, page);
+       if (page->mapping != mapping)
+               return -EIO;
+
+       truncate_cleanup_page(mapping, page);
+       delete_from_page_cache(page);
+       return 0;
 }
 
 /*