From afa8c5bb3d29f9fa4712e9d7f00122cbcdacb458 Mon Sep 17 00:00:00 2001 From: Ian Campbell Date: Thu, 9 Aug 2012 15:47:19 +0100 Subject: xen: only check for shared pages while any exist on teardown Avoids worst case behavour when guest has a large p2m. This is XSA-11 / CVE-2012-3433 Signed-off-by: Tim Deegan Signed-off-by: Ian Campbell Tested-by: Olaf Hering Committed-by: Ian Jackson --- xen/arch/x86/mm/p2m.c | 2 ++ 1 file changed, 2 insertions(+) diff --git a/xen/arch/x86/mm/p2m.c b/xen/arch/x86/mm/p2m.c index 51ef7116ca..787b4be6a3 100644 --- a/xen/arch/x86/mm/p2m.c +++ b/xen/arch/x86/mm/p2m.c @@ -1725,6 +1725,8 @@ void p2m_teardown(struct domain *d) #ifdef __x86_64__ for ( gfn=0; gfn < p2m->max_mapped_pfn; gfn++ ) { + if ( atomic_read(&d->shr_pages) == 0 ) + break; mfn = p2m->get_entry(d, gfn, &t, p2m_query); if ( mfn_valid(mfn) && (t == p2m_ram_shared) ) BUG_ON(mem_sharing_unshare_page(d, gfn, MEM_SHARING_DESTROY_GFN)); -- cgit v1.2.3