From mboxrd@z Thu Jan 1 00:00:00 1970 From: Arun Sharma Subject: [PATCH][VT][2/15] Add a hook to support CPU migration for VMX domains Date: Thu, 11 Aug 2005 12:24:06 -0700 Message-ID: <20050811192406.GA15237@intel.com> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Return-path: Content-Disposition: inline List-Unsubscribe: , List-Post: List-Help: List-Subscribe: , Sender: xen-devel-bounces@lists.xensource.com Errors-To: xen-devel-bounces@lists.xensource.com To: Ian Pratt , Keir Fraser Cc: xen-devel@lists.xensource.com List-Id: xen-devel@lists.xenproject.org Add a hook to support CPU migration for VMX domains Signed-off-by: Yunhong Jiang Signed-off-by: Arun Sharma diff -r 6a87d79f9ee0 -r d481d2776e89 xen/arch/x86/domain.c --- a/xen/arch/x86/domain.c Tue Aug 9 19:06:44 2005 +++ b/xen/arch/x86/domain.c Tue Aug 9 19:06:44 2005 @@ -297,6 +297,15 @@ l1e_from_page(virt_to_page(gdt_table), PAGE_HYPERVISOR); } +void +arch_migrate_cpu(struct vcpu *v, int newcpu) +{ + if ( VMX_DOMAIN(v) && (v->processor != newcpu) ){ + u64 vmcs_phys_ptr = (u64) virt_to_phys(v->arch.arch_vmx.vmcs); + __vmpclear(vmcs_phys_ptr); + } +} + #ifdef CONFIG_VMX static int vmx_switch_on; diff -r 6a87d79f9ee0 -r d481d2776e89 xen/common/dom0_ops.c --- a/xen/common/dom0_ops.c Tue Aug 9 19:06:44 2005 +++ b/xen/common/dom0_ops.c Tue Aug 9 19:06:44 2005 @@ -300,8 +300,10 @@ int new_cpu = (int)find_first_set_bit(cpumap) % num_online_cpus(); vcpu_pause(v); - if ( v->processor != new_cpu ) + if ( v->processor != new_cpu ){ set_bit(_VCPUF_cpu_migrated, &v->vcpu_flags); + arch_migrate_cpu(v, new_cpu); + } set_bit(_VCPUF_cpu_pinned, &v->vcpu_flags); v->processor = new_cpu; vcpu_unpause(v); diff -r 6a87d79f9ee0 -r d481d2776e89 xen/include/xen/domain.h --- a/xen/include/xen/domain.h Tue Aug 9 19:06:44 2005 +++ b/xen/include/xen/domain.h Tue Aug 9 19:06:44 2005 @@ -14,6 +14,8 @@ extern void arch_do_boot_vcpu(struct vcpu *v); +void arch_migrate_cpu(struct vcpu *v, int newcpu); + extern int arch_set_info_guest( struct vcpu *d, struct vcpu_guest_context *c);