diff options
Diffstat (limited to 'mm/page_alloc.c')
-rw-r--r-- | mm/page_alloc.c | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/mm/page_alloc.c b/mm/page_alloc.c index 0c9f406e3c44..5dac5d8cb148 100644 --- a/mm/page_alloc.c +++ b/mm/page_alloc.c | |||
@@ -493,6 +493,22 @@ static inline void __free_one_page(struct page *page, | |||
493 | zone->free_area[order].nr_free++; | 493 | zone->free_area[order].nr_free++; |
494 | } | 494 | } |
495 | 495 | ||
496 | #ifdef CONFIG_HAVE_MLOCKED_PAGE_BIT | ||
497 | /* | ||
498 | * free_page_mlock() -- clean up attempts to free and mlocked() page. | ||
499 | * Page should not be on lru, so no need to fix that up. | ||
500 | * free_pages_check() will verify... | ||
501 | */ | ||
502 | static inline void free_page_mlock(struct page *page) | ||
503 | { | ||
504 | __ClearPageMlocked(page); | ||
505 | __dec_zone_page_state(page, NR_MLOCK); | ||
506 | __count_vm_event(UNEVICTABLE_MLOCKFREED); | ||
507 | } | ||
508 | #else | ||
509 | static void free_page_mlock(struct page *page) { } | ||
510 | #endif | ||
511 | |||
496 | static inline int free_pages_check(struct page *page) | 512 | static inline int free_pages_check(struct page *page) |
497 | { | 513 | { |
498 | if (unlikely(page_mapcount(page) | | 514 | if (unlikely(page_mapcount(page) | |