watchdog: imx7ulp_wdt: keep already running watchdog enabled
BugLink: https://bugs.launchpad.net/bugs/2085849 [ Upstream commit b771d14f417e9d8030ab000b3341cf71266be90e ] When the bootloader enabled the watchdog before Kernel started then keep it enabled during initialization. Otherwise the time between the watchdog probing and the userspace taking over the watchdog won't be covered by the watchdog. When keeping the watchdog enabled inform the Kernel about this by setting the WDOG_HW_RUNNING so that the periodic watchdog feeder is started when desired. Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de> Reviewed-by: Guenter Roeck <linux@roeck-us.net> Link: https://lore.kernel.org/r/20240703111603.1096424-1-s.hauer@pengutronix.de Signed-off-by: Guenter Roeck <linux@roeck-us.net> Signed-off-by: Wim Van Sebroeck <wim@linux-watchdog.org> Signed-off-by: Sasha Levin <sashal@kernel.org> Signed-off-by: Manuel Diewald <manuel.diewald@canonical.com> Signed-off-by: Roxana Nicolescu <roxana.nicolescu@canonical.com>
This commit is contained in:
committed by
Mehmet Basaran
parent
2b2901f930
commit
8708d0d2ec
@@ -290,6 +290,11 @@ static int imx7ulp_wdt_init(struct imx7ulp_wdt_device *wdt, unsigned int timeout
|
||||
if (wdt->ext_reset)
|
||||
val |= WDOG_CS_INT_EN;
|
||||
|
||||
if (readl(wdt->base + WDOG_CS) & WDOG_CS_EN) {
|
||||
set_bit(WDOG_HW_RUNNING, &wdt->wdd.status);
|
||||
val |= WDOG_CS_EN;
|
||||
}
|
||||
|
||||
do {
|
||||
ret = _imx7ulp_wdt_init(wdt, timeout, val);
|
||||
toval = readl(wdt->base + WDOG_TOVAL);
|
||||
|
||||
Reference in New Issue
Block a user