x86: drop setup_idle_pagetable() With vcpu->domain->arch.perdomain_l3_pg no longer getting set up for the idle domain, this creates an invalid L4 entry (due to translating a NULL struct page_info pointer to a physical address). Signed-off-by: Jan Beulich --- a/xen/arch/x86/setup.c +++ b/xen/arch/x86/setup.c @@ -185,7 +185,6 @@ static void __init init_idle_domain(void scheduler_init(); set_current(idle_vcpu[0]); this_cpu(curr_vcpu) = current; - setup_idle_pagetable(); } void __devinit srat_detect_node(int cpu) --- a/xen/arch/x86/x86_64/mm.c +++ b/xen/arch/x86/x86_64/mm.c @@ -810,14 +810,6 @@ void __init paging_init(void) panic("Not enough memory for m2p table\n"); } -void __init setup_idle_pagetable(void) -{ - /* Install per-domain mappings for idle domain. */ - l4e_write(&idle_pg_table[l4_table_offset(PERDOMAIN_VIRT_START)], - l4e_from_page(idle_vcpu[0]->domain->arch.perdomain_l3_pg, - __PAGE_HYPERVISOR)); -} - void __init zap_low_mappings(void) { BUG_ON(num_online_cpus() != 1); --- a/xen/include/asm-x86/page.h +++ b/xen/include/asm-x86/page.h @@ -286,7 +286,6 @@ extern l2_pgentry_t l2_identmap[4*L2_PAG extern l1_pgentry_t l1_identmap[L1_PAGETABLE_ENTRIES], l1_fixmap[L1_PAGETABLE_ENTRIES]; void paging_init(void); -void setup_idle_pagetable(void); #endif /* !defined(__ASSEMBLY__) */ #define _PAGE_PRESENT _AC(0x001,U)