diff options
Diffstat (limited to 'drivers/char')
-rw-r--r-- | drivers/char/watchdog/advantechwdt.c | 26 |
1 files changed, 18 insertions, 8 deletions
diff --git a/drivers/char/watchdog/advantechwdt.c b/drivers/char/watchdog/advantechwdt.c index 6c919797591a..216af0d67fd2 100644 --- a/drivers/char/watchdog/advantechwdt.c +++ b/drivers/char/watchdog/advantechwdt.c | |||
@@ -95,6 +95,16 @@ advwdt_disable(void) | |||
95 | inb_p(wdt_stop); | 95 | inb_p(wdt_stop); |
96 | } | 96 | } |
97 | 97 | ||
98 | static int | ||
99 | advwdt_set_heartbeat(int t) | ||
100 | { | ||
101 | if ((t < 1) || (t > 63)) | ||
102 | return -EINVAL; | ||
103 | |||
104 | timeout = t; | ||
105 | return 0; | ||
106 | } | ||
107 | |||
98 | /* | 108 | /* |
99 | * /dev/watchdog handling | 109 | * /dev/watchdog handling |
100 | */ | 110 | */ |
@@ -151,9 +161,8 @@ advwdt_ioctl(struct inode *inode, struct file *file, unsigned int cmd, | |||
151 | case WDIOC_SETTIMEOUT: | 161 | case WDIOC_SETTIMEOUT: |
152 | if (get_user(new_timeout, p)) | 162 | if (get_user(new_timeout, p)) |
153 | return -EFAULT; | 163 | return -EFAULT; |
154 | if ((new_timeout < 1) || (new_timeout > 63)) | 164 | if (advwdt_set_heartbeat(new_timeout)) |
155 | return -EINVAL; | 165 | return -EINVAL; |
156 | timeout = new_timeout; | ||
157 | advwdt_ping(); | 166 | advwdt_ping(); |
158 | /* Fall */ | 167 | /* Fall */ |
159 | 168 | ||
@@ -267,12 +276,6 @@ advwdt_init(void) | |||
267 | 276 | ||
268 | printk(KERN_INFO "WDT driver for Advantech single board computer initialising.\n"); | 277 | printk(KERN_INFO "WDT driver for Advantech single board computer initialising.\n"); |
269 | 278 | ||
270 | if (timeout < 1 || timeout > 63) { | ||
271 | timeout = WATCHDOG_TIMEOUT; | ||
272 | printk (KERN_INFO PFX "timeout value must be 1<=x<=63, using %d\n", | ||
273 | timeout); | ||
274 | } | ||
275 | |||
276 | if (wdt_stop != wdt_start) { | 279 | if (wdt_stop != wdt_start) { |
277 | if (!request_region(wdt_stop, 1, WATCHDOG_NAME)) { | 280 | if (!request_region(wdt_stop, 1, WATCHDOG_NAME)) { |
278 | printk (KERN_ERR PFX "I/O address 0x%04x already in use\n", | 281 | printk (KERN_ERR PFX "I/O address 0x%04x already in use\n", |
@@ -289,6 +292,13 @@ advwdt_init(void) | |||
289 | goto unreg_stop; | 292 | goto unreg_stop; |
290 | } | 293 | } |
291 | 294 | ||
295 | /* Check that the heartbeat value is within it's range ; if not reset to the default */ | ||
296 | if (advwdt_set_heartbeat(timeout)) { | ||
297 | advwdt_set_heartbeat(WATCHDOG_TIMEOUT); | ||
298 | printk (KERN_INFO PFX "timeout value must be 1<=x<=63, using %d\n", | ||
299 | timeout); | ||
300 | } | ||
301 | |||
292 | ret = register_reboot_notifier(&advwdt_notifier); | 302 | ret = register_reboot_notifier(&advwdt_notifier); |
293 | if (ret != 0) { | 303 | if (ret != 0) { |
294 | printk (KERN_ERR PFX "cannot register reboot notifier (err=%d)\n", | 304 | printk (KERN_ERR PFX "cannot register reboot notifier (err=%d)\n", |