aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/watchdog/txx9wdt.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/watchdog/txx9wdt.c')
-rw-r--r--drivers/watchdog/txx9wdt.c18
1 files changed, 10 insertions, 8 deletions
diff --git a/drivers/watchdog/txx9wdt.c b/drivers/watchdog/txx9wdt.c
index 53f1b17429c6..98e16373e640 100644
--- a/drivers/watchdog/txx9wdt.c
+++ b/drivers/watchdog/txx9wdt.c
@@ -22,10 +22,13 @@
22#include <linux/io.h> 22#include <linux/io.h>
23#include <asm/txx9tmr.h> 23#include <asm/txx9tmr.h>
24 24
25#define WD_TIMER_CCD 7 /* 1/256 */
26#define WD_TIMER_CLK (clk_get_rate(txx9_imclk) / (2 << WD_TIMER_CCD))
27#define WD_MAX_TIMEOUT ((0xffffffff >> (32 - TXX9_TIMER_BITS)) / WD_TIMER_CLK)
25#define TIMER_MARGIN 60 /* Default is 60 seconds */ 28#define TIMER_MARGIN 60 /* Default is 60 seconds */
26 29
27static int timeout = TIMER_MARGIN; /* in seconds */ 30static unsigned int timeout = TIMER_MARGIN; /* in seconds */
28module_param(timeout, int, 0); 31module_param(timeout, uint, 0);
29MODULE_PARM_DESC(timeout, 32MODULE_PARM_DESC(timeout,
30 "Watchdog timeout in seconds. " 33 "Watchdog timeout in seconds. "
31 "(0<timeout<((2^" __MODULE_STRING(TXX9_TIMER_BITS) ")/(IMCLK/256)), " 34 "(0<timeout<((2^" __MODULE_STRING(TXX9_TIMER_BITS) ")/(IMCLK/256)), "
@@ -37,10 +40,6 @@ MODULE_PARM_DESC(nowayout,
37 "Watchdog cannot be stopped once started " 40 "Watchdog cannot be stopped once started "
38 "(default=" __MODULE_STRING(WATCHDOG_NOWAYOUT) ")"); 41 "(default=" __MODULE_STRING(WATCHDOG_NOWAYOUT) ")");
39 42
40#define WD_TIMER_CCD 7 /* 1/256 */
41#define WD_TIMER_CLK (clk_get_rate(txx9_imclk) / (2 << WD_TIMER_CCD))
42#define WD_MAX_TIMEOUT ((0xffffffff >> (32 - TXX9_TIMER_BITS)) / WD_TIMER_CLK)
43
44static struct txx9_tmr_reg __iomem *txx9wdt_reg; 43static struct txx9_tmr_reg __iomem *txx9wdt_reg;
45static struct clk *txx9_imclk; 44static struct clk *txx9_imclk;
46static DEFINE_SPINLOCK(txx9_lock); 45static DEFINE_SPINLOCK(txx9_lock);
@@ -56,7 +55,7 @@ static int txx9wdt_ping(struct watchdog_device *wdt_dev)
56static int txx9wdt_start(struct watchdog_device *wdt_dev) 55static int txx9wdt_start(struct watchdog_device *wdt_dev)
57{ 56{
58 spin_lock(&txx9_lock); 57 spin_lock(&txx9_lock);
59 __raw_writel(WD_TIMER_CLK * timeout, &txx9wdt_reg->cpra); 58 __raw_writel(WD_TIMER_CLK * wdt_dev->timeout, &txx9wdt_reg->cpra);
60 __raw_writel(WD_TIMER_CCD, &txx9wdt_reg->ccdr); 59 __raw_writel(WD_TIMER_CCD, &txx9wdt_reg->ccdr);
61 __raw_writel(0, &txx9wdt_reg->tisr); /* clear pending interrupt */ 60 __raw_writel(0, &txx9wdt_reg->tisr); /* clear pending interrupt */
62 __raw_writel(TXx9_TMTCR_TCE | TXx9_TMTCR_CCDE | TXx9_TMTCR_TMODE_WDOG, 61 __raw_writel(TXx9_TMTCR_TCE | TXx9_TMTCR_CCDE | TXx9_TMTCR_TMODE_WDOG,
@@ -79,7 +78,7 @@ static int txx9wdt_stop(struct watchdog_device *wdt_dev)
79static int txx9wdt_set_timeout(struct watchdog_device *wdt_dev, 78static int txx9wdt_set_timeout(struct watchdog_device *wdt_dev,
80 unsigned int new_timeout) 79 unsigned int new_timeout)
81{ 80{
82 timeout = new_timeout; 81 wdt_dev->timeout = new_timeout;
83 txx9wdt_stop(wdt_dev); 82 txx9wdt_stop(wdt_dev);
84 txx9wdt_start(wdt_dev); 83 txx9wdt_start(wdt_dev);
85 return 0; 84 return 0;
@@ -128,6 +127,9 @@ static int __init txx9wdt_probe(struct platform_device *dev)
128 goto exit; 127 goto exit;
129 } 128 }
130 129
130 if (timeout < 1 || timeout > WD_MAX_TIMEOUT)
131 timeout = TIMER_MARGIN;
132 txx9wdt.timeout = timeout;
131 txx9wdt.min_timeout = 1; 133 txx9wdt.min_timeout = 1;
132 txx9wdt.max_timeout = WD_MAX_TIMEOUT; 134 txx9wdt.max_timeout = WD_MAX_TIMEOUT;
133 watchdog_set_nowayout(&txx9wdt, nowayout); 135 watchdog_set_nowayout(&txx9wdt, nowayout);