aboutsummaryrefslogtreecommitdiffstats
path: root/arch
diff options
context:
space:
mode:
authorJeremy Fitzhardinge <jeremy@goop.org>2008-07-08 18:06:57 -0400
committerIngo Molnar <mingo@elte.hu>2008-07-16 05:01:45 -0400
commit8745f8b0b914cf1d617ecc49726c24011858c74e (patch)
tree1e4460fc2bb5f9da5bf66370a0fd388f78be0649 /arch
parent4560a2947e32670fc6ede108c2b032c396180649 (diff)
xen64: defer setting pagetable alloc/release ops
We need to wait until the page structure is available to use the proper pagetable page alloc/release operations, since they use struct page to determine if a pagetable is pinned. This happened to work in 32bit because nobody allocated new pagetable pages in the interim between xen_pagetable_setup_done and xen_post_allocator_init, but the 64-bit kenrel needs to allocate more pagetable levels. Signed-off-by: Jeremy Fitzhardinge <jeremy.fitzhardinge@citrix.com> Cc: Stephen Tweedie <sct@redhat.com> Cc: Eduardo Habkost <ehabkost@redhat.com> Cc: Mark McLoughlin <markmc@redhat.com> Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'arch')
-rw-r--r--arch/x86/xen/enlighten.c25
1 files changed, 12 insertions, 13 deletions
diff --git a/arch/x86/xen/enlighten.c b/arch/x86/xen/enlighten.c
index 19c12a6c7311..da91404fc66c 100644
--- a/arch/x86/xen/enlighten.c
+++ b/arch/x86/xen/enlighten.c
@@ -878,30 +878,29 @@ void xen_setup_shared_info(void)
878 878
879static __init void xen_pagetable_setup_done(pgd_t *base) 879static __init void xen_pagetable_setup_done(pgd_t *base)
880{ 880{
881 /* This will work as long as patching hasn't happened yet
882 (which it hasn't) */
883 pv_mmu_ops.alloc_pte = xen_alloc_pte;
884 pv_mmu_ops.alloc_pmd = xen_alloc_pmd;
885 pv_mmu_ops.release_pte = xen_release_pte;
886 pv_mmu_ops.release_pmd = xen_release_pmd;
887#if PAGETABLE_LEVELS == 4
888 pv_mmu_ops.alloc_pud = xen_alloc_pud;
889 pv_mmu_ops.release_pud = xen_release_pud;
890#endif
891
892 pv_mmu_ops.set_pte = xen_set_pte;
893
894 xen_setup_shared_info(); 881 xen_setup_shared_info();
895} 882}
896 883
897static __init void xen_post_allocator_init(void) 884static __init void xen_post_allocator_init(void)
898{ 885{
886 pv_mmu_ops.set_pte = xen_set_pte;
899 pv_mmu_ops.set_pmd = xen_set_pmd; 887 pv_mmu_ops.set_pmd = xen_set_pmd;
900 pv_mmu_ops.set_pud = xen_set_pud; 888 pv_mmu_ops.set_pud = xen_set_pud;
901#if PAGETABLE_LEVELS == 4 889#if PAGETABLE_LEVELS == 4
902 pv_mmu_ops.set_pgd = xen_set_pgd; 890 pv_mmu_ops.set_pgd = xen_set_pgd;
903#endif 891#endif
904 892
893 /* This will work as long as patching hasn't happened yet
894 (which it hasn't) */
895 pv_mmu_ops.alloc_pte = xen_alloc_pte;
896 pv_mmu_ops.alloc_pmd = xen_alloc_pmd;
897 pv_mmu_ops.release_pte = xen_release_pte;
898 pv_mmu_ops.release_pmd = xen_release_pmd;
899#if PAGETABLE_LEVELS == 4
900 pv_mmu_ops.alloc_pud = xen_alloc_pud;
901 pv_mmu_ops.release_pud = xen_release_pud;
902#endif
903
905 xen_mark_init_mm_pinned(); 904 xen_mark_init_mm_pinned();
906} 905}
907 906