On Tue, Mar 01, 2016 at 04:45:02PM +0300, Denis V. Lunev wrote:
> On 02/22/2016 12:13 PM, Denis V. Lunev wrote:
> >With Hyper-V enabled CPU hotplug stops working. The CPU appears in device
> >manager on Windows but does not appear in peformance monitor and control
> >panel.
> >
> >The root of the problem is the following. Windows checks
> >HV_X64_CPU_DYNAMIC_PARTITIONING_AVAILABLE bit in CPUID. The presence of
> >this bit is enough to cure the situation.
> >
> >The bit should be set when CPU hotplug is allowed for HyperV VM. The check
> >that hot_add_cpu callback is defined is enough from the protocol point
> >of view. Though this callback is defined almost always thus there is no
> >need to export that knowledge in the other way.
> >
> >Signed-off-by: Denis V. Lunev <d...@openvz.org>
> >Reviewed-by: Roman Kagan <rka...@virtuozzo.com>
> >CC: Paolo Bonzini <pbonz...@redhat.com>
> >CC: Richard Henderson <r...@twiddle.net>
> >CC: Eduardo Habkost <ehabk...@redhat.com>
> >CC: "Andreas Färber" <afaer...@suse.de>
> >---
> >Changes from v2:
> >- bit set unconditionally upon the discussion
> >
> >Changes from v1:
> >- dropped command line option and set the bit if HyperV is enabled and
> >   hot_add_cpu callback is present
> >
> >  target-i386/kvm.c | 1 +
> >  1 file changed, 1 insertion(+)
> >
> >diff --git a/target-i386/kvm.c b/target-i386/kvm.c
> >index 7974acb..08d6444 100644
> >--- a/target-i386/kvm.c
> >+++ b/target-i386/kvm.c
> >@@ -639,6 +639,7 @@ int kvm_arch_init_vcpu(CPUState *cs)
> >          if (cpu->hyperv_crash && has_msr_hv_crash) {
> >              c->edx |= HV_X64_GUEST_CRASH_MSR_AVAILABLE;
> >          }
> >+        c->edx |= HV_X64_CPU_DYNAMIC_PARTITIONING_AVAILABLE;
> >          if (cpu->hyperv_reset && has_msr_hv_reset) {
> >              c->eax |= HV_X64_MSR_RESET_AVAILABLE;
> >          }
> ping

Reviewed-by: Eduardo Habkost <ehabk...@redhat.com>

Applied to x86 branch.

Thanks!

-- 
Eduardo

Reply via email to