mx7ulp: wdog: Wait for WDOG unlock and reconfiguration to complete
authorBreno Lima <breno.lima@nxp.com>
Tue, 29 Jun 2021 02:32:35 +0000 (10:32 +0800)
committerStefano Babic <sbabic@denx.de>
Sat, 17 Jul 2021 12:59:56 +0000 (14:59 +0200)
commitedf95bdeddeab8f0fd7b88d4865fbc6e99071c73
treee1a42b31742fa6a352a1cd7fb756a56d1c25815c
parentc6ae713c7ccf2a6a30b6bffb47d7806c43d9d05f
mx7ulp: wdog: Wait for WDOG unlock and reconfiguration to complete

According to i.MX7ULP Reference Manual we should wait for WDOG unlock
and reconfiguration to complete.

Section "59.5.3 Configure Watchdog" provides the following example:

DisableInterrupts; //disable global interrupt
WDOG_CNT = 0xD928C520; //unlock watchdog
while(WDOG_CS[ULK]==0); //wait until registers are unlocked
WDOG_TOVAL = 256; //set timeout value
WDOG_CS = WDOG_CS_EN(1) | WDOG_CS_CLK(1) | WDOG_CS_INT(1) |
  WDOG_CS_WIN(0) | WDOG_CS_UPDATE(1);
while(WDOG_CS[RCS]==0); //wait until new configuration takes effect
EnableInterrupts; //enable global interrupt

Update U-Boot WDOG driver to align with i.MX7ULP reference manual.

Use 32 bits accessing to CS register. According to RM, the bits in
this register only can write once after unlock. So using 8 bits access
will cause problem.

Reviewed-by: Ye Li <ye.li@nxp.com>
Signed-off-by: Breno Lima <breno.lima@nxp.com>
Signed-off-by: Peng Fan <peng.fan@nxp.com>
drivers/watchdog/ulp_wdog.c