Re: [PATCH] Cleanup cpu loop

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 06/18/2009 03:22 PM, Gleb Natapov wrote:
Rearrange cpu loop to be (hopefully) more readable. Put difference
between kernel/userspace irqchip in one place.


  static void flush_queued_work(CPUState *env)
@@ -1877,6 +1871,8 @@ static void update_regs_for_init(CPUState *env)
  #endif

      cpu_reset(env);
+    /* cpu_reset() clears env->halted, cpu should be halted after init */
+    env->halted = 1;

How does that work for the boot cpu?

  static int kvm_main_loop_cpu(CPUState *env)
  {
      setup_kernel_sigmask(env);
@@ -1935,19 +1941,14 @@ static int kvm_main_loop_cpu(CPUState *env)
      kvm_arch_load_regs(env);

      while (1) {
-	while (!has_work(env))
-	    kvm_main_loop_wait(env, 1000);
-	if (env->interrupt_request&  (CPU_INTERRUPT_HARD | CPU_INTERRUPT_NMI))
-	    env->halted = 0;
-        if (!kvm_irqchip_in_kernel(kvm_context)) {
-	    if (env->kvm_cpu_state.init)
-	        update_regs_for_init(env);
-	    if (env->kvm_cpu_state.sipi_needed)
-	        update_regs_for_sipi(env);
+        int run_cpu = is_cpu_stopped(env) ? 0 : 1;

run_cpu = !is_cpu_stopped()

+        if (run_cpu&&  !kvm_irqchip_in_kernel(kvm_context)) {
+            process_irqchip_events(env);
+            run_cpu = !env->halted;
          }
-	if (!env->halted || kvm_irqchip_in_kernel(kvm_context))
-	    kvm_cpu_exec(env);
-	kvm_main_loop_wait(env, 0);
+        kvm_main_loop_wait(env, run_cpu ? 0 : 1000);
+        if (run_cpu)
+            kvm_cpu_exec(env);
      }

A single conditional may be clearer:

if (run_cpu)
kvm_main_loop_wait(0)
kvm_cpu_exec()
else
kvm_main_loop_wait(1000)

--
error compiling committee.c: too many arguments to function

--
To unsubscribe from this list: send the line "unsubscribe kvm" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [KVM ARM]     [KVM ia64]     [KVM ppc]     [Virtualization Tools]     [Spice Development]     [Libvirt]     [Libvirt Users]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite Questions]     [Linux Kernel]     [Linux SCSI]     [XFree86]
  Powered by Linux