On (Fri) 18 Jul 2014 [10:48:40], Paolo Bonzini wrote:
> Il 17/07/2014 15:25, Marcin Gibuła ha scritto:
> >+static void do_kvm_cpu_synchronize_state_always(void *arg)
> >+{
> >+    CPUState *cpu = arg;
> >+
> >+    kvm_arch_get_registers(cpu);
> >+}
> >+
> 
> The name of the hack^Wfunction is tricky, because compared to
> do_kvm_cpu_synchronize_state there are three things you change:
> 
> 1) you always synchronize the state
> 
> 2) the next call to do_kvm_cpu_synchronize_state will do
> kvm_arch_get_registers
> 
> 3) the next CPU entry will call kvm_arch_put_registers:
> 
>         if (cpu->kvm_vcpu_dirty) {
>             kvm_arch_put_registers(cpu, KVM_PUT_RUNTIME_STATE);
>             cpu->kvm_vcpu_dirty = false;
>         }
> 
> It is easy to find out if the "fix" is related to 1 or 2/3: just write
> 
>      if (cpu->kvm_vcpu_dirty) {
>          printf ("do_kvm_cpu_synchronize_state_always: look at 2/3\n");
>          kvm_arch_get_registers(cpu);
>      } else {
>          printf ("do_kvm_cpu_synchronize_state_always: look at 1\n");
>      }
> 
> To further refine between 2 and 3, I suppose you can set a breakpoint on
> cpu_synchronize_all_states and kvm_cpu_exec, and see which is called first
> after cpu_synchronize_all_states_always.
> 
> I still lean very much towards reverting the patches now.  We can reapply
> them, fixed, in 2.1.1.

FWIW I agree with this plan.

                Amit

Reply via email to