watchdog: omap_wdt: Fix WDT target reset when booted from emmc

AM335X based beaglebone black target gets reset by DM converted watchdog
if booted from emmc around 60sec. Fixed this by moving driver's private struct
variable initialization at different places in the driver to driver's probe.
Tested on Beaglebone Black.

Cc: Grygorii Strashko <grygorii.strashko@ti.com>
Fixes: 7659ea32 ("watchdog: omap_wdt: Convert watchdog driver to use DT and DM")
Reported-by: Sam Protsenko <semen.protsenko@linaro.org>
Signed-off-by: Suniel Mahesh <sunil.m@techveda.org>
Acked-by: Grygorii Strashko <grygorii.strashko@ti.com>
Reviewed-by: Sam Protsenko <semen.protsenko@linaro.org>
This commit is contained in:
Suniel Mahesh 2019-09-16 13:39:17 +05:30 committed by Tom Rini
parent 4a7cf0fd2b
commit 1e3966394a

View file

@ -150,7 +150,6 @@ static int omap3_wdt_reset(struct udevice *dev)
{ {
struct omap3_wdt_priv *priv = dev_get_priv(dev); struct omap3_wdt_priv *priv = dev_get_priv(dev);
priv->wdt_trgr_pattern = 0x1234;
/* /*
* Somebody just triggered watchdog reset and write to WTGR register * Somebody just triggered watchdog reset and write to WTGR register
* is in progress. It is resetting right now, no need to trigger it * is in progress. It is resetting right now, no need to trigger it
@ -231,6 +230,7 @@ static int omap3_wdt_probe(struct udevice *dev)
if (!priv->regs) if (!priv->regs)
return -EINVAL; return -EINVAL;
priv->wdt_trgr_pattern = 0x1234;
debug("%s: Probing wdt%u\n", __func__, dev->seq); debug("%s: Probing wdt%u\n", __func__, dev->seq);
return 0; return 0;
} }