]> rtime.felk.cvut.cz Git - zynq/linux.git/commitdiff
clockevents: Adjust timer interval when frequency changes
authorSoren Brinkmann <soren.brinkmann@xilinx.com>
Fri, 11 Apr 2014 16:24:02 +0000 (09:24 -0700)
committerMichal Simek <michal.simek@xilinx.com>
Tue, 22 Apr 2014 07:06:36 +0000 (09:06 +0200)
clockevent devices in periodic mode are not updated when the frequency
of the device changes. Issue a dev->set_mode() callback which forces
the device to reevaluate the timer settings.

Signed-off-by: Soren Brinkmann <soren.brinkmann@xilinx.com>
Cc: linux-arm-kernel@lists.infradead.org
Cc: Daniel Lezcano <daniel.lezcano@linaro.org>
Cc: Michal Simek <michal.simek@xilinx.com>
Link: http://lkml.kernel.org/r/1391466877-28908-3-git-send-email-soren.brinkmann@xilinx.com
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
(cherry picked from commit fe79a9ba11962a603fb6af68fcb476e64031e46c)
Signed-off-by: Michal Simek <michal.simek@xilinx.com>
kernel/time/clockevents.c

index 641d91003a45a424aa4586c54c7b9e96cf9ca57a..f85e5fda9c664854015a7e6257f7b6fa5889bb9d 100644 (file)
@@ -443,10 +443,13 @@ int __clockevents_update_freq(struct clock_event_device *dev, u32 freq)
 {
        clockevents_config(dev, freq);
 
-       if (dev->mode != CLOCK_EVT_MODE_ONESHOT)
-               return 0;
+       if (dev->mode == CLOCK_EVT_MODE_ONESHOT)
+               return clockevents_program_event(dev, dev->next_event, false);
+
+       if (dev->mode == CLOCK_EVT_MODE_PERIODIC)
+               dev->set_mode(CLOCK_EVT_MODE_PERIODIC, dev);
 
-       return clockevents_program_event(dev, dev->next_event, false);
+       return 0;
 }
 
 /**