Sign Up
Log In
Log In
or
Sign Up
Places
All Projects
Status Monitor
Collapse sidebar
SUSE:SLE-12:Update
xen.787
53df727b-x86-HVM-extend-LAPIC-shortcuts-around-...
Overview
Repositories
Revisions
Requests
Users
Attributes
Meta
File 53df727b-x86-HVM-extend-LAPIC-shortcuts-around-P2M-lookups.patch of Package xen.787
References: bnc#882089 # Commit fd1863847af15c3676348447755e1a1801f9d394 # Date 2014-08-04 13:46:03 +0200 # Author Jan Beulich <jbeulich@suse.com> # Committer Jan Beulich <jbeulich@suse.com> x86/HVM: extend LAPIC shortcuts around P2M lookups ... to all internally handled MMIO regions. It is in particular the HPET page that, e.g. on Windows Server 2012 R2, can get heavily accessed, and hence avoiding the unnecessary lookups is rather beneficial (in the reported case a 40+-vCPU guest would previously not have booted at all while with hvm_hap_nested_page_fault() shortcut alone it was able to boot up in 18 minutes [i.e. still room for improvement]). Note the apparently unrelated addition of a is_hvm_vcpu() check to the __hvm_copy() code: Afaict for PVH this shortcut should never have taken effect (since there's no LAPIC in that case). Signed-off-by: Jan Beulich <jbeulich@suse.com> Reviewed-by: Tim Deegan <tim@xen.org> Index: xen-4.4.2-testing/xen/arch/x86/hvm/hvm.c =================================================================== --- xen-4.4.2-testing.orig/xen/arch/x86/hvm/hvm.c +++ xen-4.4.2-testing/xen/arch/x86/hvm/hvm.c @@ -1530,11 +1530,14 @@ int hvm_hap_nested_page_fault(paddr_t gp } } - /* For the benefit of 32-bit WinXP (& older Windows) on AMD CPUs, - * a fast path for LAPIC accesses, skipping the p2m lookup. */ + /* + * No need to do the P2M lookup for internally handled MMIO, benefiting + * - 32-bit WinXP (& older Windows) on AMD CPUs for LAPIC accesses, + * - newer Windows (like Server 2012) for HPET accesses. + */ if ( !nestedhvm_vcpu_in_guestmode(v) && is_hvm_vcpu(v) - && gfn == PFN_DOWN(vlapic_base_address(vcpu_vlapic(v))) ) + && hvm_mmio_internal(gpa) ) { if ( !handle_mmio() ) hvm_inject_hw_exception(TRAP_gp_fault, 0); @@ -2653,7 +2656,9 @@ static enum hvm_copy_result __hvm_copy( while ( todo > 0 ) { - count = min_t(int, PAGE_SIZE - (addr & ~PAGE_MASK), todo); + paddr_t gpa = addr & ~PAGE_MASK; + + count = min_t(int, PAGE_SIZE - gpa, todo); if ( flags & HVMCOPY_virt ) { @@ -2668,16 +2673,22 @@ static enum hvm_copy_result __hvm_copy( hvm_inject_page_fault(pfec, addr); return HVMCOPY_bad_gva_to_gfn; } + gpa |= (paddr_t)gfn << PAGE_SHIFT; } else { gfn = addr >> PAGE_SHIFT; + gpa = addr; } - /* For the benefit of 32-bit WinXP (& older Windows) on AMD CPUs, - * a fast path for LAPIC accesses, skipping the p2m lookup. */ + /* + * No need to do the P2M lookup for internally handled MMIO, benefiting + * - 32-bit WinXP (& older Windows) on AMD CPUs for LAPIC accesses, + * - newer Windows (like Server 2012) for HPET accesses. + */ if ( !nestedhvm_vcpu_in_guestmode(curr) - && gfn == PFN_DOWN(vlapic_base_address(vcpu_vlapic(curr))) ) + && is_hvm_vcpu(curr) + && hvm_mmio_internal(gpa) ) return HVMCOPY_bad_gfn_to_mfn; page = get_page_from_gfn(curr->domain, gfn, &p2mt, P2M_UNSHARE); Index: xen-4.4.2-testing/xen/arch/x86/hvm/intercept.c =================================================================== --- xen-4.4.2-testing.orig/xen/arch/x86/hvm/intercept.c +++ xen-4.4.2-testing/xen/arch/x86/hvm/intercept.c @@ -163,6 +163,18 @@ static int hvm_mmio_access(struct vcpu * return rc; } +bool_t hvm_mmio_internal(paddr_t gpa) +{ + struct vcpu *curr = current; + unsigned int i; + + for ( i = 0; i < HVM_MMIO_HANDLER_NR; ++i ) + if ( hvm_mmio_handlers[i]->check_handler(curr, gpa) ) + return 1; + + return 0; +} + int hvm_mmio_intercept(ioreq_t *p) { struct vcpu *v = current; Index: xen-4.4.2-testing/xen/include/asm-x86/hvm/io.h =================================================================== --- xen-4.4.2-testing.orig/xen/include/asm-x86/hvm/io.h +++ xen-4.4.2-testing/xen/include/asm-x86/hvm/io.h @@ -91,6 +91,7 @@ static inline int hvm_buffered_io_interc return hvm_io_intercept(p, HVM_BUFFERED_IO); } +bool_t hvm_mmio_internal(paddr_t gpa); int hvm_mmio_intercept(ioreq_t *p); int hvm_buffered_io_send(ioreq_t *p);
Locations
Projects
Search
Status Monitor
Help
OpenBuildService.org
Documentation
API Documentation
Code of Conduct
Contact
Support
@OBShq
Terms
openSUSE Build Service is sponsored by
The Open Build Service is an
openSUSE project
.
Sign Up
Log In
Places
Places
All Projects
Status Monitor