diff options
Diffstat (limited to 'arch/x86/include/asm/pgalloc.h')
| -rw-r--r-- | arch/x86/include/asm/pgalloc.h | 31 | 
1 files changed, 29 insertions, 2 deletions
| diff --git a/arch/x86/include/asm/pgalloc.h b/arch/x86/include/asm/pgalloc.h index ec7f43327033..a281e61ec60c 100644 --- a/arch/x86/include/asm/pgalloc.h +++ b/arch/x86/include/asm/pgalloc.h @@ -47,8 +47,8 @@ extern gfp_t __userpte_alloc_gfp;  extern pgd_t *pgd_alloc(struct mm_struct *);  extern void pgd_free(struct mm_struct *mm, pgd_t *pgd); -extern pte_t *pte_alloc_one_kernel(struct mm_struct *, unsigned long); -extern pgtable_t pte_alloc_one(struct mm_struct *, unsigned long); +extern pte_t *pte_alloc_one_kernel(struct mm_struct *); +extern pgtable_t pte_alloc_one(struct mm_struct *);  /* Should really implement gc for free page table pages. This could be     done with a reference count in struct page. */ @@ -80,6 +80,13 @@ static inline void pmd_populate_kernel(struct mm_struct *mm,  	set_pmd(pmd, __pmd(__pa(pte) | _PAGE_TABLE));  } +static inline void pmd_populate_kernel_safe(struct mm_struct *mm, +				       pmd_t *pmd, pte_t *pte) +{ +	paravirt_alloc_pte(mm, __pa(pte) >> PAGE_SHIFT); +	set_pmd_safe(pmd, __pmd(__pa(pte) | _PAGE_TABLE)); +} +  static inline void pmd_populate(struct mm_struct *mm, pmd_t *pmd,  				struct page *pte)  { @@ -132,6 +139,12 @@ static inline void pud_populate(struct mm_struct *mm, pud_t *pud, pmd_t *pmd)  	paravirt_alloc_pmd(mm, __pa(pmd) >> PAGE_SHIFT);  	set_pud(pud, __pud(_PAGE_TABLE | __pa(pmd)));  } + +static inline void pud_populate_safe(struct mm_struct *mm, pud_t *pud, pmd_t *pmd) +{ +	paravirt_alloc_pmd(mm, __pa(pmd) >> PAGE_SHIFT); +	set_pud_safe(pud, __pud(_PAGE_TABLE | __pa(pmd))); +}  #endif	/* CONFIG_X86_PAE */  #if CONFIG_PGTABLE_LEVELS > 3 @@ -141,6 +154,12 @@ static inline void p4d_populate(struct mm_struct *mm, p4d_t *p4d, pud_t *pud)  	set_p4d(p4d, __p4d(_PAGE_TABLE | __pa(pud)));  } +static inline void p4d_populate_safe(struct mm_struct *mm, p4d_t *p4d, pud_t *pud) +{ +	paravirt_alloc_pud(mm, __pa(pud) >> PAGE_SHIFT); +	set_p4d_safe(p4d, __p4d(_PAGE_TABLE | __pa(pud))); +} +  static inline pud_t *pud_alloc_one(struct mm_struct *mm, unsigned long addr)  {  	gfp_t gfp = GFP_KERNEL_ACCOUNT; @@ -173,6 +192,14 @@ static inline void pgd_populate(struct mm_struct *mm, pgd_t *pgd, p4d_t *p4d)  	set_pgd(pgd, __pgd(_PAGE_TABLE | __pa(p4d)));  } +static inline void pgd_populate_safe(struct mm_struct *mm, pgd_t *pgd, p4d_t *p4d) +{ +	if (!pgtable_l5_enabled()) +		return; +	paravirt_alloc_p4d(mm, __pa(p4d) >> PAGE_SHIFT); +	set_pgd_safe(pgd, __pgd(_PAGE_TABLE | __pa(p4d))); +} +  static inline p4d_t *p4d_alloc_one(struct mm_struct *mm, unsigned long addr)  {  	gfp_t gfp = GFP_KERNEL_ACCOUNT; | 
