]> git.itanic.dy.fi Git - linux-stable/commitdiff
watchdog: armada_37xx_wdt: Fix .set_timeout callback
authorPali Rohár <pali@kernel.org>
Tue, 26 Jul 2022 08:56:12 +0000 (10:56 +0200)
committerWim Van Sebroeck <wim@linux-watchdog.org>
Sun, 2 Oct 2022 10:55:40 +0000 (12:55 +0200)
ioctl(WDIOC_SETTIMEOUT) calls .set_timeout and .ping callbacks and it is
expected that it changes current watchdog timeout.

armada_37xx_wdt's .ping callback just reping counter 0 and does not touch
counter 1 used for timeout. So it is needed to set counter 1 to the new
value in .set_timeout callback to ensure ioctl(WDIOC_SETTIMEOUT)
functionality. Fix it.

Fixes: 54e3d9b518c8 ("watchdog: Add support for Armada 37xx CPU watchdog")
Signed-off-by: Pali Rohár <pali@kernel.org>
Reviewed-by: Guenter Roeck <linux@roeck-us.net>
Reviewed-by: Marek Behún <kabel@kernel.org>
Link: https://lore.kernel.org/r/20220726085612.10672-1-pali@kernel.org
Signed-off-by: Guenter Roeck <linux@roeck-us.net>
Signed-off-by: Wim Van Sebroeck <wim@linux-watchdog.org>
drivers/watchdog/armada_37xx_wdt.c

index 854b1cc723cb602a070c903e8a2dc13d76cc979c..ac9fed1ef681b39ea0c4bd53cc08927cc88716a8 100644 (file)
@@ -179,6 +179,8 @@ static int armada_37xx_wdt_set_timeout(struct watchdog_device *wdt,
        dev->timeout = (u64)dev->clk_rate * timeout;
        do_div(dev->timeout, CNTR_CTRL_PRESCALE_MIN);
 
+       set_counter_value(dev, CNTR_ID_WDOG, dev->timeout);
+
        return 0;
 }