diff options
Diffstat (limited to 'arch/x86/include/asm/pgtable.h')
-rw-r--r-- | arch/x86/include/asm/pgtable.h | 103 |
1 files changed, 60 insertions, 43 deletions
diff --git a/arch/x86/include/asm/pgtable.h b/arch/x86/include/asm/pgtable.h index 9f5085097977..b0d1066ab6a5 100644 --- a/arch/x86/include/asm/pgtable.h +++ b/arch/x86/include/asm/pgtable.h | |||
@@ -25,6 +25,66 @@ extern unsigned long empty_zero_page[PAGE_SIZE / sizeof(unsigned long)]; | |||
25 | extern spinlock_t pgd_lock; | 25 | extern spinlock_t pgd_lock; |
26 | extern struct list_head pgd_list; | 26 | extern struct list_head pgd_list; |
27 | 27 | ||
28 | #ifdef CONFIG_PARAVIRT | ||
29 | #include <asm/paravirt.h> | ||
30 | #else /* !CONFIG_PARAVIRT */ | ||
31 | #define set_pte(ptep, pte) native_set_pte(ptep, pte) | ||
32 | #define set_pte_at(mm, addr, ptep, pte) native_set_pte_at(mm, addr, ptep, pte) | ||
33 | |||
34 | #define set_pte_present(mm, addr, ptep, pte) \ | ||
35 | native_set_pte_present(mm, addr, ptep, pte) | ||
36 | #define set_pte_atomic(ptep, pte) \ | ||
37 | native_set_pte_atomic(ptep, pte) | ||
38 | |||
39 | #define set_pmd(pmdp, pmd) native_set_pmd(pmdp, pmd) | ||
40 | |||
41 | #ifndef __PAGETABLE_PUD_FOLDED | ||
42 | #define set_pgd(pgdp, pgd) native_set_pgd(pgdp, pgd) | ||
43 | #define pgd_clear(pgd) native_pgd_clear(pgd) | ||
44 | #endif | ||
45 | |||
46 | #ifndef set_pud | ||
47 | # define set_pud(pudp, pud) native_set_pud(pudp, pud) | ||
48 | #endif | ||
49 | |||
50 | #ifndef __PAGETABLE_PMD_FOLDED | ||
51 | #define pud_clear(pud) native_pud_clear(pud) | ||
52 | #endif | ||
53 | |||
54 | #define pte_clear(mm, addr, ptep) native_pte_clear(mm, addr, ptep) | ||
55 | #define pmd_clear(pmd) native_pmd_clear(pmd) | ||
56 | |||
57 | #define pte_update(mm, addr, ptep) do { } while (0) | ||
58 | #define pte_update_defer(mm, addr, ptep) do { } while (0) | ||
59 | |||
60 | static inline void __init paravirt_pagetable_setup_start(pgd_t *base) | ||
61 | { | ||
62 | native_pagetable_setup_start(base); | ||
63 | } | ||
64 | |||
65 | static inline void __init paravirt_pagetable_setup_done(pgd_t *base) | ||
66 | { | ||
67 | native_pagetable_setup_done(base); | ||
68 | } | ||
69 | |||
70 | #define pgd_val(x) native_pgd_val(x) | ||
71 | #define __pgd(x) native_make_pgd(x) | ||
72 | |||
73 | #ifndef __PAGETABLE_PUD_FOLDED | ||
74 | #define pud_val(x) native_pud_val(x) | ||
75 | #define __pud(x) native_make_pud(x) | ||
76 | #endif | ||
77 | |||
78 | #ifndef __PAGETABLE_PMD_FOLDED | ||
79 | #define pmd_val(x) native_pmd_val(x) | ||
80 | #define __pmd(x) native_make_pmd(x) | ||
81 | #endif | ||
82 | |||
83 | #define pte_val(x) native_pte_val(x) | ||
84 | #define __pte(x) native_make_pte(x) | ||
85 | |||
86 | #endif /* CONFIG_PARAVIRT */ | ||
87 | |||
28 | /* | 88 | /* |
29 | * The following only work if pte_present() is true. | 89 | * The following only work if pte_present() is true. |
30 | * Undefined behaviour if not.. | 90 | * Undefined behaviour if not.. |
@@ -214,49 +274,6 @@ static inline int is_new_memtype_allowed(unsigned long flags, | |||
214 | return 1; | 274 | return 1; |
215 | } | 275 | } |
216 | 276 | ||
217 | #ifdef CONFIG_PARAVIRT | ||
218 | #include <asm/paravirt.h> | ||
219 | #else /* !CONFIG_PARAVIRT */ | ||
220 | #define set_pte(ptep, pte) native_set_pte(ptep, pte) | ||
221 | #define set_pte_at(mm, addr, ptep, pte) native_set_pte_at(mm, addr, ptep, pte) | ||
222 | |||
223 | #define set_pte_present(mm, addr, ptep, pte) \ | ||
224 | native_set_pte_present(mm, addr, ptep, pte) | ||
225 | #define set_pte_atomic(ptep, pte) \ | ||
226 | native_set_pte_atomic(ptep, pte) | ||
227 | |||
228 | #define set_pmd(pmdp, pmd) native_set_pmd(pmdp, pmd) | ||
229 | |||
230 | #ifndef __PAGETABLE_PUD_FOLDED | ||
231 | #define set_pgd(pgdp, pgd) native_set_pgd(pgdp, pgd) | ||
232 | #define pgd_clear(pgd) native_pgd_clear(pgd) | ||
233 | #endif | ||
234 | |||
235 | #ifndef set_pud | ||
236 | # define set_pud(pudp, pud) native_set_pud(pudp, pud) | ||
237 | #endif | ||
238 | |||
239 | #ifndef __PAGETABLE_PMD_FOLDED | ||
240 | #define pud_clear(pud) native_pud_clear(pud) | ||
241 | #endif | ||
242 | |||
243 | #define pte_clear(mm, addr, ptep) native_pte_clear(mm, addr, ptep) | ||
244 | #define pmd_clear(pmd) native_pmd_clear(pmd) | ||
245 | |||
246 | #define pte_update(mm, addr, ptep) do { } while (0) | ||
247 | #define pte_update_defer(mm, addr, ptep) do { } while (0) | ||
248 | |||
249 | static inline void __init paravirt_pagetable_setup_start(pgd_t *base) | ||
250 | { | ||
251 | native_pagetable_setup_start(base); | ||
252 | } | ||
253 | |||
254 | static inline void __init paravirt_pagetable_setup_done(pgd_t *base) | ||
255 | { | ||
256 | native_pagetable_setup_done(base); | ||
257 | } | ||
258 | #endif /* CONFIG_PARAVIRT */ | ||
259 | |||
260 | #endif /* __ASSEMBLY__ */ | 277 | #endif /* __ASSEMBLY__ */ |
261 | 278 | ||
262 | #ifdef CONFIG_X86_32 | 279 | #ifdef CONFIG_X86_32 |