|
@@ -231,7 +231,6 @@ static void bad_page(struct page *page)
|
|
printk(KERN_EMERG "Trying to fix it up, but a reboot is needed\n"
|
|
printk(KERN_EMERG "Trying to fix it up, but a reboot is needed\n"
|
|
KERN_EMERG "Backtrace:\n");
|
|
KERN_EMERG "Backtrace:\n");
|
|
dump_stack();
|
|
dump_stack();
|
|
- page->flags &= ~PAGE_FLAGS_CLEAR_WHEN_BAD;
|
|
|
|
set_page_count(page, 0);
|
|
set_page_count(page, 0);
|
|
reset_page_mapcount(page);
|
|
reset_page_mapcount(page);
|
|
page->mapping = NULL;
|
|
page->mapping = NULL;
|
|
@@ -468,16 +467,16 @@ static inline int free_pages_check(struct page *page)
|
|
(page_count(page) != 0) |
|
|
(page_count(page) != 0) |
|
|
(page->flags & PAGE_FLAGS_CHECK_AT_FREE)))
|
|
(page->flags & PAGE_FLAGS_CHECK_AT_FREE)))
|
|
bad_page(page);
|
|
bad_page(page);
|
|
- if (PageDirty(page))
|
|
|
|
- __ClearPageDirty(page);
|
|
|
|
- if (PageSwapBacked(page))
|
|
|
|
- __ClearPageSwapBacked(page);
|
|
|
|
/*
|
|
/*
|
|
* For now, we report if PG_reserved was found set, but do not
|
|
* For now, we report if PG_reserved was found set, but do not
|
|
* clear it, and do not free the page. But we shall soon need
|
|
* clear it, and do not free the page. But we shall soon need
|
|
* to do more, for when the ZERO_PAGE count wraps negative.
|
|
* to do more, for when the ZERO_PAGE count wraps negative.
|
|
*/
|
|
*/
|
|
- return PageReserved(page);
|
|
|
|
|
|
+ if (PageReserved(page))
|
|
|
|
+ return 1;
|
|
|
|
+ if (page->flags & PAGE_FLAGS_CHECK_AT_PREP)
|
|
|
|
+ page->flags &= ~PAGE_FLAGS_CHECK_AT_PREP;
|
|
|
|
+ return 0;
|
|
}
|
|
}
|
|
|
|
|
|
/*
|
|
/*
|
|
@@ -621,13 +620,7 @@ static int prep_new_page(struct page *page, int order, gfp_t gfp_flags)
|
|
if (PageReserved(page))
|
|
if (PageReserved(page))
|
|
return 1;
|
|
return 1;
|
|
|
|
|
|
- page->flags &= ~(1 << PG_uptodate | 1 << PG_error | 1 << PG_reclaim |
|
|
|
|
- 1 << PG_referenced | 1 << PG_arch_1 |
|
|
|
|
- 1 << PG_owner_priv_1 | 1 << PG_mappedtodisk
|
|
|
|
-#ifdef CONFIG_UNEVICTABLE_LRU
|
|
|
|
- | 1 << PG_mlocked
|
|
|
|
-#endif
|
|
|
|
- );
|
|
|
|
|
|
+ page->flags &= ~PAGE_FLAGS_CHECK_AT_PREP;
|
|
set_page_private(page, 0);
|
|
set_page_private(page, 0);
|
|
set_page_refcounted(page);
|
|
set_page_refcounted(page);
|
|
|
|
|