[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [Xen-devel] [RFC PATCH 65/84] x86: fix some wrong assumptions on direct map. Increase PMAP slots to 8.
On Thu, Sep 26, 2019 at 10:46:28AM +0100, hongyax@xxxxxxxxxx wrote: > From: Hongyan Xia <hongyax@xxxxxxxxxx> > > Signed-off-by: Hongyan Xia <hongyax@xxxxxxxxxx> > --- > xen/arch/x86/domain_page.c | 8 -------- > xen/arch/x86/x86_64/mm.c | 3 ++- > xen/include/asm-x86/pmap.h | 4 ++-- > 3 files changed, 4 insertions(+), 11 deletions(-) > > diff --git a/xen/arch/x86/domain_page.c b/xen/arch/x86/domain_page.c > index 4a3995ccef..f4f53a2a33 100644 > --- a/xen/arch/x86/domain_page.c > +++ b/xen/arch/x86/domain_page.c > @@ -328,11 +328,6 @@ void *map_domain_page_global(mfn_t mfn) > system_state < SYS_STATE_active) || > local_irq_is_enabled())); > > -#ifdef NDEBUG > - if ( mfn_x(mfn) <= PFN_DOWN(__pa(HYPERVISOR_VIRT_END - 1)) ) > - return mfn_to_virt(mfn_x(mfn)); > -#endif > - I wouldn't call this a wrong assumption. This path is a fast path. The problem is it is not longer applicable in the new world. I would change the commit message to something like: Drop fast paths in map_domain_page_global API pair, because Xen will no longer have a direct map. > return vmap(&mfn, 1); > } > > @@ -340,9 +335,6 @@ void unmap_domain_page_global(const void *ptr) > { > unsigned long va = (unsigned long)ptr; > > - if ( va >= DIRECTMAP_VIRT_START ) > - return; > - > ASSERT(va >= VMAP_VIRT_START && va < VMAP_VIRT_END); > > vunmap(ptr); > diff --git a/xen/arch/x86/x86_64/mm.c b/xen/arch/x86/x86_64/mm.c > index 37e8d59e5d..40f29f8ddc 100644 > --- a/xen/arch/x86/x86_64/mm.c > +++ b/xen/arch/x86/x86_64/mm.c > @@ -712,7 +712,8 @@ void __init paging_init(void) > if ( mfn_eq(l2_ro_mpt_mfn, INVALID_MFN) ) > goto nomem; > l2_ro_mpt = map_xen_pagetable(l2_ro_mpt_mfn); > - compat_idle_pg_table_l2 = l2_ro_mpt; > + /* compat_idle_pg_table_l2 is used globally. */ > + compat_idle_pg_table_l2 = map_domain_page_global(l2_ro_mpt_mfn); Again, if this is a bug in a previous patch, it should be fixed there. > clear_page(l2_ro_mpt); > l3e_write(&l3_ro_mpt[l3_table_offset(HIRO_COMPAT_MPT_VIRT_START)], > l3e_from_mfn(l2_ro_mpt_mfn, __PAGE_HYPERVISOR_RO)); > diff --git a/xen/include/asm-x86/pmap.h b/xen/include/asm-x86/pmap.h > index feab1e9170..34d4f2bb38 100644 > --- a/xen/include/asm-x86/pmap.h > +++ b/xen/include/asm-x86/pmap.h > @@ -1,8 +1,8 @@ > #ifndef __X86_PMAP_H__ > #define __X86_PMAP_H__ > > -/* Large enough for mapping 5 levels of page tables */ > -#define NUM_FIX_PMAP 5 > +/* Large enough for mapping 5 levels of page tables with some headroom */ > +#define NUM_FIX_PMAP 8 > This looks rather arbitrary to me. Can you specify why extra slots are needed? The original justification for 5 is for page tables. Now obviously it is used for more than just mapping page tables. I'm worried that even 8 may not be enough. Also, this change should either be in a separate patch or folded into PMAP patch itself. Wei. > void pmap_lock(void); > void pmap_unlock(void); > -- > 2.17.1 > _______________________________________________ Xen-devel mailing list Xen-devel@xxxxxxxxxxxxxxxxxxxx https://lists.xenproject.org/mailman/listinfo/xen-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |