]> xenbits.xensource.com Git - people/liuw/xen.git/commitdiff
x86/mm: switch to new APIs in arch_init_memory
authorWei Liu <wei.liu2@citrix.com>
Tue, 29 Jan 2019 14:15:47 +0000 (14:15 +0000)
committerWei Liu <wei.liu2@citrix.com>
Mon, 4 Feb 2019 15:46:46 +0000 (15:46 +0000)
Signed-off-by: Wei Liu <wei.liu2@citrix.com>
xen/arch/x86/mm.c

index 18bbac3fcc949e389f32b21e606aa015a770b5b4..7033cac462ff353fd2472e0d8da6c9a22c00cd85 100644 (file)
@@ -366,19 +366,20 @@ void __init arch_init_memory(void)
             ASSERT(root_pgt_pv_xen_slots < ROOT_PAGETABLE_PV_XEN_SLOTS);
             if ( l4_table_offset(split_va) == l4_table_offset(split_va - 1) )
             {
-                l3_pgentry_t *l3tab = alloc_xen_pagetable();
+                mfn_t l3tab_mfn = alloc_xen_pagetable_new();
 
-                if ( l3tab )
+                if ( !mfn_eq(l3tab_mfn, INVALID_MFN) )
                 {
                     const l3_pgentry_t *l3idle =
                         l4e_to_l3e(idle_pg_table[l4_table_offset(split_va)]);
+                    l3_pgentry_t *l3tab = map_xen_pagetable_new(l3tab_mfn);
 
                     for ( i = 0; i < l3_table_offset(split_va); ++i )
                         l3tab[i] = l3idle[i];
                     for ( ; i < L3_PAGETABLE_ENTRIES; ++i )
                         l3tab[i] = l3e_empty();
-                    split_l4e = l4e_from_mfn(virt_to_mfn(l3tab),
-                                             __PAGE_HYPERVISOR_RW);
+                    split_l4e = l4e_from_mfn(l3tab_mfn, __PAGE_HYPERVISOR_RW);
+                    unmap_xen_pagetable_new(l3tab);
                 }
                 else
                     ++root_pgt_pv_xen_slots;