]> git.proxmox.com Git - mirror_qemu.git/commitdiff
hw/core/ptimer: Support ptimer being disabled by timer callback
authorPeter Maydell <peter.maydell@linaro.org>
Thu, 15 Oct 2020 15:18:28 +0000 (16:18 +0100)
committerPeter Maydell <peter.maydell@linaro.org>
Tue, 27 Oct 2020 11:15:31 +0000 (11:15 +0000)
In ptimer_reload(), we call the callback function provided by the
timer device that is using the ptimer.  This callback might disable
the ptimer.  The code mostly handles this correctly, except that
we'll still print the warning about "Timer with delta zero,
disabling" if the now-disabled timer happened to be set such that it
would fire again immediately if it were enabled (eg because the
limit/reload value is zero).

Suppress the spurious warning message and the unnecessary
repeat-deletion of the underlying timer in this case.

Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com>
Message-id: 20201015151829.14656-2-peter.maydell@linaro.org

hw/core/ptimer.c

index c6d2beb1dacebfbc2afe6942c29c11f84e6aea78..2aa97cb665c55562798bd39bdd558435c01b135c 100644 (file)
@@ -117,6 +117,10 @@ static void ptimer_reload(ptimer_state *s, int delta_adjust)
     }
 
     if (delta == 0) {
+        if (s->enabled == 0) {
+            /* trigger callback disabled the timer already */
+            return;
+        }
         if (!qtest_enabled()) {
             fprintf(stderr, "Timer with delta zero, disabling\n");
         }