[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-devel] [PATCH V2] x86/p2m: fixed p2m_change_type_range() start / end check
p2m_change_type_range() handles end > max_mapped_pfn, but not start > max_mapped_pfn. Check the latter just after grabbing the lock and bail if true. Signed-off-by: Razvan Cojocaru <rcojocaru@xxxxxxxxxxxxxxx> Suggested-by: George Dunlap <george.dunlap@xxxxxxxxxx> --- Changes since V1: - Added ASSERT()s. - Wrapped the new condition in an unlikely(). --- xen/arch/x86/mm/p2m.c | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/xen/arch/x86/mm/p2m.c b/xen/arch/x86/mm/p2m.c index c53cab4..e09b256 100644 --- a/xen/arch/x86/mm/p2m.c +++ b/xen/arch/x86/mm/p2m.c @@ -978,8 +978,19 @@ void p2m_change_type_range(struct domain *d, p2m_lock(p2m); p2m->defer_nested_flush = 1; + ASSERT(start < end); + + if ( unlikely(start > p2m->max_mapped_pfn) ) + { + ASSERT(!p2m_is_hostp2m(p2m)); + p2m_unlock(p2m); + return; + } + if ( unlikely(end > p2m->max_mapped_pfn) ) { + ASSERT(end == ~0UL || !p2m_is_hostp2m(p2m)); + if ( !gfn ) { p2m->change_entry_type_global(p2m, ot, nt); -- 2.7.4 _______________________________________________ Xen-devel mailing list Xen-devel@xxxxxxxxxxxxxxxxxxxx https://lists.xenproject.org/mailman/listinfo/xen-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |