diff options
Diffstat (limited to 'arch/x86')
-rw-r--r-- | arch/x86/kernel/paravirt.c | 2 | ||||
-rw-r--r-- | arch/x86/mm/pgtable.c | 9 | ||||
-rw-r--r-- | arch/x86/xen/enlighten.c | 29 |
3 files changed, 38 insertions, 2 deletions
diff --git a/arch/x86/kernel/paravirt.c b/arch/x86/kernel/paravirt.c index 74f0c5ea2a03..cf06670349dc 100644 --- a/arch/x86/kernel/paravirt.c +++ b/arch/x86/kernel/paravirt.c | |||
@@ -416,6 +416,8 @@ struct pv_mmu_ops pv_mmu_ops = { | |||
416 | .enter = paravirt_nop, | 416 | .enter = paravirt_nop, |
417 | .leave = paravirt_nop, | 417 | .leave = paravirt_nop, |
418 | }, | 418 | }, |
419 | |||
420 | .set_fixmap = native_set_fixmap, | ||
419 | }; | 421 | }; |
420 | 422 | ||
421 | EXPORT_SYMBOL_GPL(pv_time_ops); | 423 | EXPORT_SYMBOL_GPL(pv_time_ops); |
diff --git a/arch/x86/mm/pgtable.c b/arch/x86/mm/pgtable.c index 7498124e30fc..e9fb66361fc8 100644 --- a/arch/x86/mm/pgtable.c +++ b/arch/x86/mm/pgtable.c | |||
@@ -277,7 +277,7 @@ int ptep_clear_flush_young(struct vm_area_struct *vma, | |||
277 | 277 | ||
278 | int fixmaps_set; | 278 | int fixmaps_set; |
279 | 279 | ||
280 | void __set_fixmap (enum fixed_addresses idx, unsigned long phys, pgprot_t flags) | 280 | void __native_set_fixmap(enum fixed_addresses idx, pte_t pte) |
281 | { | 281 | { |
282 | unsigned long address = __fix_to_virt(idx); | 282 | unsigned long address = __fix_to_virt(idx); |
283 | 283 | ||
@@ -285,6 +285,11 @@ void __set_fixmap (enum fixed_addresses idx, unsigned long phys, pgprot_t flags) | |||
285 | BUG(); | 285 | BUG(); |
286 | return; | 286 | return; |
287 | } | 287 | } |
288 | set_pte_vaddr(address, pfn_pte(phys >> PAGE_SHIFT, flags)); | 288 | set_pte_vaddr(address, pte); |
289 | fixmaps_set++; | 289 | fixmaps_set++; |
290 | } | 290 | } |
291 | |||
292 | void native_set_fixmap(enum fixed_addresses idx, unsigned long phys, pgprot_t flags) | ||
293 | { | ||
294 | __native_set_fixmap(idx, pfn_pte(phys >> PAGE_SHIFT, flags)); | ||
295 | } | ||
diff --git a/arch/x86/xen/enlighten.c b/arch/x86/xen/enlighten.c index c8a56e457d61..0ad8a64a2e05 100644 --- a/arch/x86/xen/enlighten.c +++ b/arch/x86/xen/enlighten.c | |||
@@ -960,6 +960,33 @@ static unsigned xen_patch(u8 type, u16 clobbers, void *insnbuf, | |||
960 | return ret; | 960 | return ret; |
961 | } | 961 | } |
962 | 962 | ||
963 | static void xen_set_fixmap(unsigned idx, unsigned long phys, pgprot_t prot) | ||
964 | { | ||
965 | pte_t pte; | ||
966 | |||
967 | phys >>= PAGE_SHIFT; | ||
968 | |||
969 | switch (idx) { | ||
970 | case FIX_BTMAP_END ... FIX_BTMAP_BEGIN: | ||
971 | #ifdef CONFIG_X86_F00F_BUG | ||
972 | case FIX_F00F_IDT: | ||
973 | #endif | ||
974 | case FIX_WP_TEST: | ||
975 | case FIX_VDSO: | ||
976 | #ifdef CONFIG_X86_LOCAL_APIC | ||
977 | case FIX_APIC_BASE: /* maps dummy local APIC */ | ||
978 | #endif | ||
979 | pte = pfn_pte(phys, prot); | ||
980 | break; | ||
981 | |||
982 | default: | ||
983 | pte = mfn_pte(phys, prot); | ||
984 | break; | ||
985 | } | ||
986 | |||
987 | __native_set_fixmap(idx, pte); | ||
988 | } | ||
989 | |||
963 | static const struct pv_info xen_info __initdata = { | 990 | static const struct pv_info xen_info __initdata = { |
964 | .paravirt_enabled = 1, | 991 | .paravirt_enabled = 1, |
965 | .shared_kernel_pmd = 0, | 992 | .shared_kernel_pmd = 0, |
@@ -1112,6 +1139,8 @@ static const struct pv_mmu_ops xen_mmu_ops __initdata = { | |||
1112 | .enter = paravirt_enter_lazy_mmu, | 1139 | .enter = paravirt_enter_lazy_mmu, |
1113 | .leave = xen_leave_lazy, | 1140 | .leave = xen_leave_lazy, |
1114 | }, | 1141 | }, |
1142 | |||
1143 | .set_fixmap = xen_set_fixmap, | ||
1115 | }; | 1144 | }; |
1116 | 1145 | ||
1117 | #ifdef CONFIG_SMP | 1146 | #ifdef CONFIG_SMP |