mm/s390: use common help functions to free reserved pages

Use common help functions to free reserved pages.

Signed-off-by: Jiang Liu <jiang.liu@huawei.com>
Cc: Martin Schwidefsky <schwidefsky@de.ibm.com>
Cc: Heiko Carstens <heiko.carstens@de.ibm.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
Jiang Liu 2013-04-29 15:06:48 -07:00 committed by Linus Torvalds
parent 5d585e5c48
commit 0999f1193a
1 changed files with 6 additions and 29 deletions

View File

@ -42,11 +42,10 @@ pgd_t swapper_pg_dir[PTRS_PER_PGD] __attribute__((__aligned__(PAGE_SIZE)));
unsigned long empty_zero_page, zero_page_mask; unsigned long empty_zero_page, zero_page_mask;
EXPORT_SYMBOL(empty_zero_page); EXPORT_SYMBOL(empty_zero_page);
static unsigned long __init setup_zero_pages(void) static void __init setup_zero_pages(void)
{ {
struct cpuid cpu_id; struct cpuid cpu_id;
unsigned int order; unsigned int order;
unsigned long size;
struct page *page; struct page *page;
int i; int i;
@ -83,14 +82,11 @@ static unsigned long __init setup_zero_pages(void)
page = virt_to_page((void *) empty_zero_page); page = virt_to_page((void *) empty_zero_page);
split_page(page, order); split_page(page, order);
for (i = 1 << order; i > 0; i--) { for (i = 1 << order; i > 0; i--) {
SetPageReserved(page); mark_page_reserved(page);
page++; page++;
} }
size = PAGE_SIZE << order; zero_page_mask = ((PAGE_SIZE << order) - 1) & PAGE_MASK;
zero_page_mask = (size - 1) & PAGE_MASK;
return 1UL << order;
} }
/* /*
@ -147,7 +143,7 @@ void __init mem_init(void)
/* this will put all low memory onto the freelists */ /* this will put all low memory onto the freelists */
totalram_pages += free_all_bootmem(); totalram_pages += free_all_bootmem();
totalram_pages -= setup_zero_pages(); /* Setup zeroed pages. */ setup_zero_pages(); /* Setup zeroed pages. */
reservedpages = 0; reservedpages = 0;
@ -166,34 +162,15 @@ void __init mem_init(void)
PFN_ALIGN((unsigned long)&_eshared) - 1); PFN_ALIGN((unsigned long)&_eshared) - 1);
} }
void free_init_pages(char *what, unsigned long begin, unsigned long end)
{
unsigned long addr = begin;
if (begin >= end)
return;
for (; addr < end; addr += PAGE_SIZE) {
ClearPageReserved(virt_to_page(addr));
init_page_count(virt_to_page(addr));
memset((void *)(addr & PAGE_MASK), POISON_FREE_INITMEM,
PAGE_SIZE);
free_page(addr);
totalram_pages++;
}
printk(KERN_INFO "Freeing %s: %luk freed\n", what, (end - begin) >> 10);
}
void free_initmem(void) void free_initmem(void)
{ {
free_init_pages("unused kernel memory", free_initmem_default(0);
(unsigned long)&__init_begin,
(unsigned long)&__init_end);
} }
#ifdef CONFIG_BLK_DEV_INITRD #ifdef CONFIG_BLK_DEV_INITRD
void __init free_initrd_mem(unsigned long start, unsigned long end) void __init free_initrd_mem(unsigned long start, unsigned long end)
{ {
free_init_pages("initrd memory", start, end); free_reserved_area(start, end, POISON_FREE_INITMEM, "initrd");
} }
#endif #endif