diff options
Diffstat (limited to 'arch/x86/xen/mmu_pv.c')
| -rw-r--r-- | arch/x86/xen/mmu_pv.c | 15 | 
1 files changed, 5 insertions, 10 deletions
| diff --git a/arch/x86/xen/mmu_pv.c b/arch/x86/xen/mmu_pv.c index 509f560bd0c6..71495f1a86d7 100644 --- a/arch/x86/xen/mmu_pv.c +++ b/arch/x86/xen/mmu_pv.c @@ -1238,21 +1238,16 @@ static void __init xen_pagetable_cleanhighmap(void)  	 * from _brk_limit way up to the max_pfn_mapped (which is the end of  	 * the ramdisk). We continue on, erasing PMD entries that point to page  	 * tables - do note that they are accessible at this stage via __va. -	 * For good measure we also round up to the PMD - which means that if +	 * As Xen is aligning the memory end to a 4MB boundary, for good +	 * measure we also round up to PMD_SIZE * 2 - which means that if  	 * anybody is using __ka address to the initial boot-stack - and try  	 * to use it - they are going to crash. The xen_start_info has been  	 * taken care of already in xen_setup_kernel_pagetable. */  	addr = xen_start_info->pt_base; -	size = roundup(xen_start_info->nr_pt_frames * PAGE_SIZE, PMD_SIZE); +	size = xen_start_info->nr_pt_frames * PAGE_SIZE; -	xen_cleanhighmap(addr, addr + size); +	xen_cleanhighmap(addr, roundup(addr + size, PMD_SIZE * 2));  	xen_start_info->pt_base = (unsigned long)__va(__pa(xen_start_info->pt_base)); -#ifdef DEBUG -	/* This is superfluous and is not necessary, but you know what -	 * lets do it. The MODULES_VADDR -> MODULES_END should be clear of -	 * anything at this stage. */ -	xen_cleanhighmap(MODULES_VADDR, roundup(MODULES_VADDR, PUD_SIZE) - 1); -#endif  }  #endif @@ -2220,7 +2215,7 @@ static void __init xen_write_cr3_init(unsigned long cr3)   * not the first page table in the page table pool.   * Iterate through the initial page tables to find the real page table base.   */ -static phys_addr_t xen_find_pt_base(pmd_t *pmd) +static phys_addr_t __init xen_find_pt_base(pmd_t *pmd)  {  	phys_addr_t pt_base, paddr;  	unsigned pmdidx; |