aboutsummaryrefslogtreecommitdiffstats
path: root/include/asm-x86/pgalloc_32.h
diff options
context:
space:
mode:
Diffstat (limited to 'include/asm-x86/pgalloc_32.h')
-rw-r--r--include/asm-x86/pgalloc_32.h22
1 files changed, 18 insertions, 4 deletions
diff --git a/include/asm-x86/pgalloc_32.h b/include/asm-x86/pgalloc_32.h
index 3482c3427897..0caa37a9a25f 100644
--- a/include/asm-x86/pgalloc_32.h
+++ b/include/asm-x86/pgalloc_32.h
@@ -63,21 +63,35 @@ static inline void __pte_free_tlb(struct mmu_gather *tlb, struct page *pte)
63 */ 63 */
64static inline pmd_t *pmd_alloc_one(struct mm_struct *mm, unsigned long addr) 64static inline pmd_t *pmd_alloc_one(struct mm_struct *mm, unsigned long addr)
65{ 65{
66 BUG(); 66 return (pmd_t *)get_zeroed_page(GFP_KERNEL|__GFP_REPEAT);
67 return (pmd_t *)2;
68} 67}
69 68
70static inline void pmd_free(pmd_t *pmd) 69static inline void pmd_free(pmd_t *pmd)
71{ 70{
71 BUG_ON((unsigned long)pmd & (PAGE_SIZE-1));
72 free_page((unsigned long)pmd);
72} 73}
73 74
74static inline void __pmd_free_tlb(struct mmu_gather *tlb, pmd_t *pmd) 75static inline void __pmd_free_tlb(struct mmu_gather *tlb, pmd_t *pmd)
75{ 76{
77 paravirt_release_pd(__pa(pmd) >> PAGE_SHIFT);
78 tlb_remove_page(tlb, virt_to_page(pmd));
76} 79}
77 80
78static inline void pud_populate(struct mm_struct *mm, pud_t *pud, pmd_t *pmd) 81static inline void pud_populate(struct mm_struct *mm, pud_t *pudp, pmd_t *pmd)
79{ 82{
80 BUG(); 83 paravirt_alloc_pd(mm, __pa(pmd) >> PAGE_SHIFT);
84
85 /* Note: almost everything apart from _PAGE_PRESENT is
86 reserved at the pmd (PDPT) level. */
87 set_pud(pudp, __pud(__pa(pmd) | _PAGE_PRESENT));
88
89 /*
90 * Pentium-II erratum A13: in PAE mode we explicitly have to flush
91 * the TLB via cr3 if the top-level pgd is changed...
92 */
93 if (mm == current->active_mm)
94 write_cr3(read_cr3());
81} 95}
82#endif /* CONFIG_X86_PAE */ 96#endif /* CONFIG_X86_PAE */
83 97