mm/fadvise.c: drain all pagevecs if POSIX_FADV_DONTNEED fails to discard all pages
[platform/adaptation/renesas_rcar/renesas_kernel.git] / mm / util.c
index 16a7319..ab1424d 100644 (file)
--- a/mm/util.c
+++ b/mm/util.c
@@ -6,6 +6,7 @@
 #include <linux/sched.h>
 #include <linux/security.h>
 #include <linux/swap.h>
+#include <linux/swapops.h>
 #include <asm/uaccess.h>
 
 #include "internal.h"
@@ -389,9 +390,12 @@ struct address_space *page_mapping(struct page *page)
 
        VM_BUG_ON(PageSlab(page));
 #ifdef CONFIG_SWAP
-       if (unlikely(PageSwapCache(page)))
-               mapping = &swapper_space;
-       else
+       if (unlikely(PageSwapCache(page))) {
+               swp_entry_t entry;
+
+               entry.val = page_private(page);
+               mapping = swap_address_space(entry);
+       } else
 #endif
        if ((unsigned long)mapping & PAGE_MAPPING_ANON)
                mapping = NULL;