提交 0197c1c4 编写于 作者: W Wim Van Sebroeck

watchdog: fix set_timeout operations

Since we changed the behaviour of the set_timeout operation in the
watchdog API, we need to change the allready converted drivers so
that they update the timeout field at the end of the set_timeout
operation.
Signed-off-by: NWim Van Sebroeck <wim@iguana.be>
上级 b10f7c12
...@@ -323,6 +323,7 @@ static int mei_wd_ops_set_timeout(struct watchdog_device *wd_dev, unsigned int t ...@@ -323,6 +323,7 @@ static int mei_wd_ops_set_timeout(struct watchdog_device *wd_dev, unsigned int t
mutex_lock(&dev->device_lock); mutex_lock(&dev->device_lock);
dev->wd_timeout = timeout; dev->wd_timeout = timeout;
wd_dev->timeout = timeout;
mei_wd_set_start_timeout(dev, dev->wd_timeout); mei_wd_set_start_timeout(dev, dev->wd_timeout);
mutex_unlock(&dev->device_lock); mutex_unlock(&dev->device_lock);
......
...@@ -109,6 +109,7 @@ static int jz4740_wdt_set_timeout(struct watchdog_device *wdt_dev, ...@@ -109,6 +109,7 @@ static int jz4740_wdt_set_timeout(struct watchdog_device *wdt_dev,
writeb(0x1, drvdata->base + JZ_REG_WDT_COUNTER_ENABLE); writeb(0x1, drvdata->base + JZ_REG_WDT_COUNTER_ENABLE);
wdt_dev->timeout = new_timeout;
return 0; return 0;
} }
......
...@@ -121,6 +121,7 @@ static int pnx4008_wdt_stop(struct watchdog_device *wdd) ...@@ -121,6 +121,7 @@ static int pnx4008_wdt_stop(struct watchdog_device *wdd)
static int pnx4008_wdt_set_timeout(struct watchdog_device *wdd, static int pnx4008_wdt_set_timeout(struct watchdog_device *wdd,
unsigned int new_timeout) unsigned int new_timeout)
{ {
wdd->timeout = new_timeout;
return 0; return 0;
} }
......
...@@ -201,6 +201,8 @@ static int s3c2410wdt_set_heartbeat(struct watchdog_device *wdd, unsigned timeou ...@@ -201,6 +201,8 @@ static int s3c2410wdt_set_heartbeat(struct watchdog_device *wdd, unsigned timeou
writel(count, wdt_base + S3C2410_WTDAT); writel(count, wdt_base + S3C2410_WTDAT);
writel(wtcon, wdt_base + S3C2410_WTCON); writel(wtcon, wdt_base + S3C2410_WTCON);
wdd->timeout = timeout;
return 0; return 0;
} }
......
...@@ -101,7 +101,7 @@ static void wdt_timer_tick(unsigned long data) ...@@ -101,7 +101,7 @@ static void wdt_timer_tick(unsigned long data)
static int wdt_ping(struct watchdog_device *wdd) static int wdt_ping(struct watchdog_device *wdd)
{ {
/* calculate when the next userspace timeout will be */ /* calculate when the next userspace timeout will be */
next_heartbeat = jiffies + timeout * HZ; next_heartbeat = jiffies + wdd->timeout * HZ;
return 0; return 0;
} }
...@@ -109,7 +109,7 @@ static int wdt_start(struct watchdog_device *wdd) ...@@ -109,7 +109,7 @@ static int wdt_start(struct watchdog_device *wdd)
{ {
unsigned int ctl = readl(wdt_mem); unsigned int ctl = readl(wdt_mem);
writel(timeout, wdt_mem + VIA_WDT_COUNT); writel(wdd->timeout, wdt_mem + VIA_WDT_COUNT);
writel(ctl | VIA_WDT_RUNNING | VIA_WDT_TRIGGER, wdt_mem); writel(ctl | VIA_WDT_RUNNING | VIA_WDT_TRIGGER, wdt_mem);
wdt_ping(wdd); wdt_ping(wdd);
mod_timer(&timer, jiffies + WDT_HEARTBEAT); mod_timer(&timer, jiffies + WDT_HEARTBEAT);
...@@ -128,7 +128,7 @@ static int wdt_set_timeout(struct watchdog_device *wdd, ...@@ -128,7 +128,7 @@ static int wdt_set_timeout(struct watchdog_device *wdd,
unsigned int new_timeout) unsigned int new_timeout)
{ {
writel(new_timeout, wdt_mem + VIA_WDT_COUNT); writel(new_timeout, wdt_mem + VIA_WDT_COUNT);
timeout = new_timeout; wdd->timeout = new_timeout;
return 0; return 0;
} }
......
...@@ -163,6 +163,8 @@ static int wm831x_wdt_set_timeout(struct watchdog_device *wdt_dev, ...@@ -163,6 +163,8 @@ static int wm831x_wdt_set_timeout(struct watchdog_device *wdt_dev,
ret); ret);
} }
wdt_dev->timeout = timeout;
return ret; return ret;
} }
......
...@@ -60,6 +60,7 @@ static int wm8350_wdt_set_timeout(struct watchdog_device *wdt_dev, ...@@ -60,6 +60,7 @@ static int wm8350_wdt_set_timeout(struct watchdog_device *wdt_dev,
wm8350_reg_lock(wm8350); wm8350_reg_lock(wm8350);
mutex_unlock(&wdt_mutex); mutex_unlock(&wdt_mutex);
wdt_dev->timeout = timeout;
return ret; return ret;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册