X-Git-Url: https://git.karo-electronics.de/?a=blobdiff_plain;f=mm%2Fvmscan.c;h=135bf8ca96ee60ac78783caac94fa30f2bfabfc8;hb=254ce8dc882f8d69e5d49ed4807c94a61976fb15;hp=843c87d1e61f5f63e68aa53a903567a3802958f8;hpb=8a212ab6b8a4ccc6f3c3d1beba5f92655c576404;p=mv-sheeva.git diff --git a/mm/vmscan.c b/mm/vmscan.c index 843c87d1e61..135bf8ca96e 100644 --- a/mm/vmscan.c +++ b/mm/vmscan.c @@ -417,7 +417,9 @@ static int shrink_list(struct list_head *page_list, struct scan_control *sc) * Anonymous process memory has backing store? * Try to allocate it some swap space here. */ - if (PageAnon(page) && !PageSwapCache(page) && sc->may_swap) { + if (PageAnon(page) && !PageSwapCache(page)) { + if (!sc->may_swap) + goto keep_locked; if (!add_to_swap(page)) goto activate_locked; } @@ -519,7 +521,7 @@ static int shrink_list(struct list_head *page_list, struct scan_control *sc) #ifdef CONFIG_SWAP if (PageSwapCache(page)) { - swp_entry_t swap = { .val = page->private }; + swp_entry_t swap = { .val = page_private(page) }; __delete_from_swap_cache(page); write_unlock_irq(&mapping->tree_lock); swap_free(swap);