提交 2069e978 编写于 作者: H Heiko Carstens 提交者: Martin Schwidefsky

[S390] sparsemem vmemmap: initialize memmap.

Let's just use the generic vmmemmap_alloc_block() function which
always returns initialized memory.

Cc: Gerald Schaefer <gerald.schaefer@de.ibm.com>
Signed-off-by: NHeiko Carstens <heiko.carstens@de.ibm.com>
Signed-off-by: NMartin Schwidefsky <schwidefsky@de.ibm.com>
上级 e0a45ee0
...@@ -27,19 +27,12 @@ struct memory_segment { ...@@ -27,19 +27,12 @@ struct memory_segment {
static LIST_HEAD(mem_segs); static LIST_HEAD(mem_segs);
static void __ref *vmem_alloc_pages(unsigned int order) static pud_t *vmem_pud_alloc(void)
{
if (slab_is_available())
return (void *)__get_free_pages(GFP_KERNEL, order);
return alloc_bootmem_pages((1 << order) * PAGE_SIZE);
}
static inline pud_t *vmem_pud_alloc(void)
{ {
pud_t *pud = NULL; pud_t *pud = NULL;
#ifdef CONFIG_64BIT #ifdef CONFIG_64BIT
pud = vmem_alloc_pages(2); pud = vmemmap_alloc_block(PAGE_SIZE * 4, 0);
if (!pud) if (!pud)
return NULL; return NULL;
clear_table((unsigned long *) pud, _REGION3_ENTRY_EMPTY, PAGE_SIZE * 4); clear_table((unsigned long *) pud, _REGION3_ENTRY_EMPTY, PAGE_SIZE * 4);
...@@ -47,12 +40,12 @@ static inline pud_t *vmem_pud_alloc(void) ...@@ -47,12 +40,12 @@ static inline pud_t *vmem_pud_alloc(void)
return pud; return pud;
} }
static inline pmd_t *vmem_pmd_alloc(void) static pmd_t *vmem_pmd_alloc(void)
{ {
pmd_t *pmd = NULL; pmd_t *pmd = NULL;
#ifdef CONFIG_64BIT #ifdef CONFIG_64BIT
pmd = vmem_alloc_pages(2); pmd = vmemmap_alloc_block(PAGE_SIZE * 4, 0);
if (!pmd) if (!pmd)
return NULL; return NULL;
clear_table((unsigned long *) pmd, _SEGMENT_ENTRY_EMPTY, PAGE_SIZE * 4); clear_table((unsigned long *) pmd, _SEGMENT_ENTRY_EMPTY, PAGE_SIZE * 4);
...@@ -60,7 +53,7 @@ static inline pmd_t *vmem_pmd_alloc(void) ...@@ -60,7 +53,7 @@ static inline pmd_t *vmem_pmd_alloc(void)
return pmd; return pmd;
} }
static pte_t __init_refok *vmem_pte_alloc(void) static pte_t __ref *vmem_pte_alloc(void)
{ {
pte_t *pte; pte_t *pte;
...@@ -214,7 +207,7 @@ int __meminit vmemmap_populate(struct page *start, unsigned long nr, int node) ...@@ -214,7 +207,7 @@ int __meminit vmemmap_populate(struct page *start, unsigned long nr, int node)
if (pte_none(*pt_dir)) { if (pte_none(*pt_dir)) {
unsigned long new_page; unsigned long new_page;
new_page =__pa(vmem_alloc_pages(0)); new_page =__pa(vmemmap_alloc_block(PAGE_SIZE, 0));
if (!new_page) if (!new_page)
goto out; goto out;
pte = pfn_pte(new_page >> PAGE_SHIFT, PAGE_KERNEL); pte = pfn_pte(new_page >> PAGE_SHIFT, PAGE_KERNEL);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册