Commit c83f6438 authored by Jan Kiszka's avatar Jan Kiszka Committed by Wim Van Sebroeck

watchdog: rti_wdt: Fix calculation and evaluation of preset heartbeat

This ensures that the same value is read back as was eventually
programmed when using seconds as accuracy. Even then, comparing the more
precise heartbeat_ms against heartbeat in seconds will almost never
provide a match and will needlessly raise a warning. Fix by comparing
apples to apples.

Tested in combination with U-Boot as watchdog starter.
Signed-off-by: default avatarJan Kiszka <jan.kiszka@siemens.com>
Reviewed-by: default avatarGuenter Roeck <linux@roeck-us.net>
Link: https://lore.kernel.org/r/6a4b54ac-9588-e172-c4c7-b91d524a851e@siemens.comSigned-off-by: default avatarGuenter Roeck <linux@roeck-us.net>
Signed-off-by: default avatarWim Van Sebroeck <wim@linux-watchdog.org>
parent 95d0eee9
...@@ -253,6 +253,7 @@ static int rti_wdt_probe(struct platform_device *pdev) ...@@ -253,6 +253,7 @@ static int rti_wdt_probe(struct platform_device *pdev)
} }
if (readl(wdt->base + RTIDWDCTRL) == WDENABLE_KEY) { if (readl(wdt->base + RTIDWDCTRL) == WDENABLE_KEY) {
int preset_heartbeat;
u32 time_left_ms; u32 time_left_ms;
u64 heartbeat_ms; u64 heartbeat_ms;
u32 wsize; u32 wsize;
...@@ -263,11 +264,12 @@ static int rti_wdt_probe(struct platform_device *pdev) ...@@ -263,11 +264,12 @@ static int rti_wdt_probe(struct platform_device *pdev)
heartbeat_ms <<= WDT_PRELOAD_SHIFT; heartbeat_ms <<= WDT_PRELOAD_SHIFT;
heartbeat_ms *= 1000; heartbeat_ms *= 1000;
do_div(heartbeat_ms, wdt->freq); do_div(heartbeat_ms, wdt->freq);
if (heartbeat_ms != heartbeat * 1000) preset_heartbeat = heartbeat_ms + 500;
preset_heartbeat /= 1000;
if (preset_heartbeat != heartbeat)
dev_warn(dev, "watchdog already running, ignoring heartbeat config!\n"); dev_warn(dev, "watchdog already running, ignoring heartbeat config!\n");
heartbeat = heartbeat_ms; heartbeat = preset_heartbeat;
heartbeat /= 1000;
wsize = readl(wdt->base + RTIWWDSIZECTRL); wsize = readl(wdt->base + RTIWWDSIZECTRL);
ret = rti_wdt_setup_hw_hb(wdd, wsize); ret = rti_wdt_setup_hw_hb(wdd, wsize);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment