提交 a4e37c70 编写于 作者: F Feiyang Chen 提交者: Hongchen Zhang

MIPS&LoongArch&NIOS2: Adjust prototypes of p?d_init()

LoongArch inclusion
category: feature
bugzilla: https://gitee.com/openeuler/kernel/issues/I5OHOB

--------------------------------

We are preparing to add sparse vmemmap support to LoongArch. MIPS and
LoongArch need to call pgd_init()/pud_init()/pmd_init() when populating
page tables, so adjust their prototypes to make generic helpers can call
them.

NIOS2 declares pmd_init() but doesn't use, just remove it to avoid build
errors.
Reviewed-by: NJiaxun Yang <jiaxun.yang@flygoat.com>
Signed-off-by: NFeiyang Chen <chenfeiyang@loongson.cn>
Signed-off-by: NHuacai Chen <chenhuacai@loongson.cn>
上级 2d46fff9
...@@ -44,15 +44,6 @@ static inline void p4d_populate(struct mm_struct *mm, p4d_t *p4d, pud_t *pud) ...@@ -44,15 +44,6 @@ static inline void p4d_populate(struct mm_struct *mm, p4d_t *p4d, pud_t *pud)
extern void pagetable_init(void); extern void pagetable_init(void);
/*
* Initialize a new pmd table with invalid pointers.
*/
extern void pmd_init(unsigned long page, unsigned long pagetable);
/*
* Initialize a new pgd / pmd table with invalid pointers.
*/
extern void pgd_init(unsigned long page);
extern pgd_t *pgd_alloc(struct mm_struct *mm); extern pgd_t *pgd_alloc(struct mm_struct *mm);
#define __pte_free_tlb(tlb, pte, address) \ #define __pte_free_tlb(tlb, pte, address) \
...@@ -78,7 +69,7 @@ static inline pmd_t *pmd_alloc_one(struct mm_struct *mm, unsigned long address) ...@@ -78,7 +69,7 @@ static inline pmd_t *pmd_alloc_one(struct mm_struct *mm, unsigned long address)
} }
pmd = (pmd_t *)page_address(pg); pmd = (pmd_t *)page_address(pg);
pmd_init((unsigned long)pmd, (unsigned long)invalid_pte_table); pmd_init(pmd);
return pmd; return pmd;
} }
...@@ -94,7 +85,7 @@ static inline pud_t *pud_alloc_one(struct mm_struct *mm, unsigned long address) ...@@ -94,7 +85,7 @@ static inline pud_t *pud_alloc_one(struct mm_struct *mm, unsigned long address)
pud = (pud_t *) __get_free_page(GFP_KERNEL); pud = (pud_t *) __get_free_page(GFP_KERNEL);
if (pud) if (pud)
pud_init((unsigned long)pud, (unsigned long)invalid_pmd_table); pud_init(pud);
return pud; return pud;
} }
......
...@@ -239,11 +239,11 @@ extern void set_pmd_at(struct mm_struct *mm, unsigned long addr, pmd_t *pmdp, pm ...@@ -239,11 +239,11 @@ extern void set_pmd_at(struct mm_struct *mm, unsigned long addr, pmd_t *pmdp, pm
#define pfn_pmd(pfn, prot) __pmd(((pfn) << _PFN_SHIFT) | pgprot_val(prot)) #define pfn_pmd(pfn, prot) __pmd(((pfn) << _PFN_SHIFT) | pgprot_val(prot))
/* /*
* Initialize a new pgd / pmd table with invalid pointers. * Initialize a new pgd / pud / pmd table with invalid pointers.
*/ */
extern void pgd_init(unsigned long page); extern void pgd_init(void *addr);
extern void pud_init(unsigned long page, unsigned long pagetable); extern void pud_init(void *addr);
extern void pmd_init(unsigned long page, unsigned long pagetable); extern void pmd_init(void *addr);
/* /*
* Non-present pages: high 40 bits are offset, next 8 bits type, * Non-present pages: high 40 bits are offset, next 8 bits type,
......
...@@ -78,7 +78,7 @@ void __init pcpu_populate_pte(unsigned long addr) ...@@ -78,7 +78,7 @@ void __init pcpu_populate_pte(unsigned long addr)
new = memblock_alloc(PAGE_SIZE, PAGE_SIZE); new = memblock_alloc(PAGE_SIZE, PAGE_SIZE);
pgd_populate(&init_mm, pgd, new); pgd_populate(&init_mm, pgd, new);
#ifndef __PAGETABLE_PUD_FOLDED #ifndef __PAGETABLE_PUD_FOLDED
pud_init((unsigned long)new, (unsigned long)invalid_pmd_table); pud_init(new);
#endif #endif
} }
...@@ -89,7 +89,7 @@ void __init pcpu_populate_pte(unsigned long addr) ...@@ -89,7 +89,7 @@ void __init pcpu_populate_pte(unsigned long addr)
new = memblock_alloc(PAGE_SIZE, PAGE_SIZE); new = memblock_alloc(PAGE_SIZE, PAGE_SIZE);
pud_populate(&init_mm, pud, new); pud_populate(&init_mm, pud, new);
#ifndef __PAGETABLE_PMD_FOLDED #ifndef __PAGETABLE_PMD_FOLDED
pmd_init((unsigned long)new, (unsigned long)invalid_pte_table); pmd_init(new);
#endif #endif
} }
......
...@@ -16,7 +16,7 @@ pgd_t *pgd_alloc(struct mm_struct *mm) ...@@ -16,7 +16,7 @@ pgd_t *pgd_alloc(struct mm_struct *mm)
ret = (pgd_t *) __get_free_page(GFP_KERNEL); ret = (pgd_t *) __get_free_page(GFP_KERNEL);
if (ret) { if (ret) {
init = pgd_offset(&init_mm, 0UL); init = pgd_offset(&init_mm, 0UL);
pgd_init((unsigned long)ret); pgd_init(ret);
memcpy(ret + USER_PTRS_PER_PGD, init + USER_PTRS_PER_PGD, memcpy(ret + USER_PTRS_PER_PGD, init + USER_PTRS_PER_PGD,
(PTRS_PER_PGD - USER_PTRS_PER_PGD) * sizeof(pgd_t)); (PTRS_PER_PGD - USER_PTRS_PER_PGD) * sizeof(pgd_t));
} }
...@@ -25,7 +25,7 @@ pgd_t *pgd_alloc(struct mm_struct *mm) ...@@ -25,7 +25,7 @@ pgd_t *pgd_alloc(struct mm_struct *mm)
} }
EXPORT_SYMBOL_GPL(pgd_alloc); EXPORT_SYMBOL_GPL(pgd_alloc);
void pgd_init(unsigned long page) void pgd_init(void *addr)
{ {
unsigned long *p, *end; unsigned long *p, *end;
unsigned long entry; unsigned long entry;
...@@ -38,7 +38,7 @@ void pgd_init(unsigned long page) ...@@ -38,7 +38,7 @@ void pgd_init(unsigned long page)
entry = (unsigned long)invalid_pte_table; entry = (unsigned long)invalid_pte_table;
#endif #endif
p = (unsigned long *) page; p = (unsigned long *)addr;
end = p + PTRS_PER_PGD; end = p + PTRS_PER_PGD;
do { do {
...@@ -56,11 +56,12 @@ void pgd_init(unsigned long page) ...@@ -56,11 +56,12 @@ void pgd_init(unsigned long page)
EXPORT_SYMBOL_GPL(pgd_init); EXPORT_SYMBOL_GPL(pgd_init);
#ifndef __PAGETABLE_PMD_FOLDED #ifndef __PAGETABLE_PMD_FOLDED
void pmd_init(unsigned long addr, unsigned long pagetable) void pmd_init(void *addr)
{ {
unsigned long *p, *end; unsigned long *p, *end;
unsigned long pagetable = (unsigned long)invalid_pte_table;
p = (unsigned long *) addr; p = (unsigned long *)addr;
end = p + PTRS_PER_PMD; end = p + PTRS_PER_PMD;
do { do {
...@@ -79,9 +80,10 @@ EXPORT_SYMBOL_GPL(pmd_init); ...@@ -79,9 +80,10 @@ EXPORT_SYMBOL_GPL(pmd_init);
#endif #endif
#ifndef __PAGETABLE_PUD_FOLDED #ifndef __PAGETABLE_PUD_FOLDED
void pud_init(unsigned long addr, unsigned long pagetable) void pud_init(void *addr)
{ {
unsigned long *p, *end; unsigned long *p, *end;
unsigned long pagetable = (unsigned long)invalid_pmd_table;
p = (unsigned long *)addr; p = (unsigned long *)addr;
end = p + PTRS_PER_PUD; end = p + PTRS_PER_PUD;
...@@ -98,6 +100,7 @@ void pud_init(unsigned long addr, unsigned long pagetable) ...@@ -98,6 +100,7 @@ void pud_init(unsigned long addr, unsigned long pagetable)
p[-1] = pagetable; p[-1] = pagetable;
} while (p != end); } while (p != end);
} }
EXPORT_SYMBOL_GPL(pud_init);
#endif #endif
pmd_t mk_pmd(struct page *page, pgprot_t prot) pmd_t mk_pmd(struct page *page, pgprot_t prot)
...@@ -119,12 +122,12 @@ void set_pmd_at(struct mm_struct *mm, unsigned long addr, ...@@ -119,12 +122,12 @@ void set_pmd_at(struct mm_struct *mm, unsigned long addr,
void __init pagetable_init(void) void __init pagetable_init(void)
{ {
/* Initialize the entire pgd. */ /* Initialize the entire pgd. */
pgd_init((unsigned long)swapper_pg_dir); pgd_init(swapper_pg_dir);
pgd_init((unsigned long)invalid_pg_dir); pgd_init(invalid_pg_dir);
#ifndef __PAGETABLE_PUD_FOLDED #ifndef __PAGETABLE_PUD_FOLDED
pud_init((unsigned long)invalid_pud_table, (unsigned long)invalid_pmd_table); pud_init(invalid_pud_table);
#endif #endif
#ifndef __PAGETABLE_PMD_FOLDED #ifndef __PAGETABLE_PMD_FOLDED
pmd_init((unsigned long)invalid_pmd_table, (unsigned long)invalid_pte_table); pmd_init(invalid_pmd_table);
#endif #endif
} }
...@@ -34,7 +34,7 @@ static inline void pmd_populate(struct mm_struct *mm, pmd_t *pmd, ...@@ -34,7 +34,7 @@ static inline void pmd_populate(struct mm_struct *mm, pmd_t *pmd,
/* /*
* Initialize a new pmd table with invalid pointers. * Initialize a new pmd table with invalid pointers.
*/ */
extern void pmd_init(unsigned long page, unsigned long pagetable); extern void pmd_init(void *addr);
#ifndef __PAGETABLE_PMD_FOLDED #ifndef __PAGETABLE_PMD_FOLDED
...@@ -45,9 +45,9 @@ static inline void pud_populate(struct mm_struct *mm, pud_t *pud, pmd_t *pmd) ...@@ -45,9 +45,9 @@ static inline void pud_populate(struct mm_struct *mm, pud_t *pud, pmd_t *pmd)
#endif #endif
/* /*
* Initialize a new pgd / pmd table with invalid pointers. * Initialize a new pgd table with invalid pointers.
*/ */
extern void pgd_init(unsigned long page); extern void pgd_init(void *addr);
extern pgd_t *pgd_alloc(struct mm_struct *mm); extern pgd_t *pgd_alloc(struct mm_struct *mm);
static inline void pgd_free(struct mm_struct *mm, pgd_t *pgd) static inline void pgd_free(struct mm_struct *mm, pgd_t *pgd)
...@@ -78,7 +78,7 @@ static inline pmd_t *pmd_alloc_one(struct mm_struct *mm, unsigned long address) ...@@ -78,7 +78,7 @@ static inline pmd_t *pmd_alloc_one(struct mm_struct *mm, unsigned long address)
} }
pmd = (pmd_t *)page_address(pg); pmd = (pmd_t *)page_address(pg);
pmd_init((unsigned long)pmd, (unsigned long)invalid_pte_table); pmd_init(pmd);
return pmd; return pmd;
} }
...@@ -94,7 +94,7 @@ static inline pud_t *pud_alloc_one(struct mm_struct *mm, unsigned long address) ...@@ -94,7 +94,7 @@ static inline pud_t *pud_alloc_one(struct mm_struct *mm, unsigned long address)
pud = (pud_t *) __get_free_pages(GFP_KERNEL, PUD_ORDER); pud = (pud_t *) __get_free_pages(GFP_KERNEL, PUD_ORDER);
if (pud) if (pud)
pud_init((unsigned long)pud, (unsigned long)invalid_pmd_table); pud_init(pud);
return pud; return pud;
} }
......
...@@ -324,11 +324,11 @@ static inline pmd_t *pud_pgtable(pud_t pud) ...@@ -324,11 +324,11 @@ static inline pmd_t *pud_pgtable(pud_t pud)
#endif #endif
/* /*
* Initialize a new pgd / pmd table with invalid pointers. * Initialize a new pgd / pud / pmd table with invalid pointers.
*/ */
extern void pgd_init(unsigned long page); extern void pgd_init(void *addr);
extern void pud_init(unsigned long page, unsigned long pagetable); extern void pud_init(void *addr);
extern void pmd_init(unsigned long page, unsigned long pagetable); extern void pmd_init(void *addr);
/* /*
* Non-present pages: high 40 bits are offset, next 8 bits type, * Non-present pages: high 40 bits are offset, next 8 bits type,
......
...@@ -122,8 +122,7 @@ static pte_t *kvm_mips_walk_pgd(pgd_t *pgd, struct kvm_mmu_memory_cache *cache, ...@@ -122,8 +122,7 @@ static pte_t *kvm_mips_walk_pgd(pgd_t *pgd, struct kvm_mmu_memory_cache *cache,
if (!cache) if (!cache)
return NULL; return NULL;
new_pmd = kvm_mmu_memory_cache_alloc(cache); new_pmd = kvm_mmu_memory_cache_alloc(cache);
pmd_init((unsigned long)new_pmd, pmd_init(new_pmd);
(unsigned long)invalid_pte_table);
pud_populate(NULL, pud, new_pmd); pud_populate(NULL, pud, new_pmd);
} }
pmd = pmd_offset(pud, addr); pmd = pmd_offset(pud, addr);
......
...@@ -13,9 +13,9 @@ ...@@ -13,9 +13,9 @@
#include <asm/pgalloc.h> #include <asm/pgalloc.h>
#include <asm/tlbflush.h> #include <asm/tlbflush.h>
void pgd_init(unsigned long page) void pgd_init(void *addr)
{ {
unsigned long *p = (unsigned long *) page; unsigned long *p = (unsigned long *)addr;
int i; int i;
for (i = 0; i < USER_PTRS_PER_PGD; i+=8) { for (i = 0; i < USER_PTRS_PER_PGD; i+=8) {
...@@ -62,9 +62,9 @@ void __init pagetable_init(void) ...@@ -62,9 +62,9 @@ void __init pagetable_init(void)
#endif #endif
/* Initialize the entire pgd. */ /* Initialize the entire pgd. */
pgd_init((unsigned long)swapper_pg_dir); pgd_init(swapper_pg_dir);
pgd_init((unsigned long)swapper_pg_dir pgd_init((void *)((unsigned long)swapper_pg_dir
+ sizeof(pgd_t) * USER_PTRS_PER_PGD); + sizeof(pgd_t) * USER_PTRS_PER_PGD));
pgd_base = swapper_pg_dir; pgd_base = swapper_pg_dir;
......
...@@ -13,7 +13,7 @@ ...@@ -13,7 +13,7 @@
#include <asm/pgalloc.h> #include <asm/pgalloc.h>
#include <asm/tlbflush.h> #include <asm/tlbflush.h>
void pgd_init(unsigned long page) void pgd_init(void *addr)
{ {
unsigned long *p, *end; unsigned long *p, *end;
unsigned long entry; unsigned long entry;
...@@ -26,7 +26,7 @@ void pgd_init(unsigned long page) ...@@ -26,7 +26,7 @@ void pgd_init(unsigned long page)
entry = (unsigned long)invalid_pte_table; entry = (unsigned long)invalid_pte_table;
#endif #endif
p = (unsigned long *) page; p = (unsigned long *) addr;
end = p + PTRS_PER_PGD; end = p + PTRS_PER_PGD;
do { do {
...@@ -43,11 +43,12 @@ void pgd_init(unsigned long page) ...@@ -43,11 +43,12 @@ void pgd_init(unsigned long page)
} }
#ifndef __PAGETABLE_PMD_FOLDED #ifndef __PAGETABLE_PMD_FOLDED
void pmd_init(unsigned long addr, unsigned long pagetable) void pmd_init(void *addr)
{ {
unsigned long *p, *end; unsigned long *p, *end;
unsigned long pagetable = (unsigned long)invalid_pte_table;
p = (unsigned long *) addr; p = (unsigned long *)addr;
end = p + PTRS_PER_PMD; end = p + PTRS_PER_PMD;
do { do {
...@@ -66,9 +67,10 @@ EXPORT_SYMBOL_GPL(pmd_init); ...@@ -66,9 +67,10 @@ EXPORT_SYMBOL_GPL(pmd_init);
#endif #endif
#ifndef __PAGETABLE_PUD_FOLDED #ifndef __PAGETABLE_PUD_FOLDED
void pud_init(unsigned long addr, unsigned long pagetable) void pud_init(void *addr)
{ {
unsigned long *p, *end; unsigned long *p, *end;
unsigned long pagetable = (unsigned long)invalid_pmd_table;
p = (unsigned long *)addr; p = (unsigned long *)addr;
end = p + PTRS_PER_PUD; end = p + PTRS_PER_PUD;
...@@ -109,12 +111,12 @@ void __init pagetable_init(void) ...@@ -109,12 +111,12 @@ void __init pagetable_init(void)
pgd_t *pgd_base; pgd_t *pgd_base;
/* Initialize the entire pgd. */ /* Initialize the entire pgd. */
pgd_init((unsigned long)swapper_pg_dir); pgd_init(swapper_pg_dir);
#ifndef __PAGETABLE_PUD_FOLDED #ifndef __PAGETABLE_PUD_FOLDED
pud_init((unsigned long)invalid_pud_table, (unsigned long)invalid_pmd_table); pud_init(invalid_pud_table);
#endif #endif
#ifndef __PAGETABLE_PMD_FOLDED #ifndef __PAGETABLE_PMD_FOLDED
pmd_init((unsigned long)invalid_pmd_table, (unsigned long)invalid_pte_table); pmd_init(invalid_pmd_table);
#endif #endif
pgd_base = swapper_pg_dir; pgd_base = swapper_pg_dir;
/* /*
......
...@@ -15,7 +15,7 @@ pgd_t *pgd_alloc(struct mm_struct *mm) ...@@ -15,7 +15,7 @@ pgd_t *pgd_alloc(struct mm_struct *mm)
ret = (pgd_t *) __get_free_pages(GFP_KERNEL, PGD_ORDER); ret = (pgd_t *) __get_free_pages(GFP_KERNEL, PGD_ORDER);
if (ret) { if (ret) {
init = pgd_offset(&init_mm, 0UL); init = pgd_offset(&init_mm, 0UL);
pgd_init((unsigned long)ret); pgd_init(ret);
memcpy(ret + USER_PTRS_PER_PGD, init + USER_PTRS_PER_PGD, memcpy(ret + USER_PTRS_PER_PGD, init + USER_PTRS_PER_PGD,
(PTRS_PER_PGD - USER_PTRS_PER_PGD) * sizeof(pgd_t)); (PTRS_PER_PGD - USER_PTRS_PER_PGD) * sizeof(pgd_t));
} }
......
...@@ -27,11 +27,6 @@ static inline void pmd_populate(struct mm_struct *mm, pmd_t *pmd, ...@@ -27,11 +27,6 @@ static inline void pmd_populate(struct mm_struct *mm, pmd_t *pmd,
} }
#define pmd_pgtable(pmd) pmd_page(pmd) #define pmd_pgtable(pmd) pmd_page(pmd)
/*
* Initialize a new pmd table with invalid pointers.
*/
extern void pmd_init(unsigned long page, unsigned long pagetable);
extern pgd_t *pgd_alloc(struct mm_struct *mm); extern pgd_t *pgd_alloc(struct mm_struct *mm);
#define __pte_free_tlb(tlb, pte, addr) \ #define __pte_free_tlb(tlb, pte, addr) \
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册