diff options
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/char/watchdog/ib700wdt.c | 32 |
1 files changed, 26 insertions, 6 deletions
diff --git a/drivers/char/watchdog/ib700wdt.c b/drivers/char/watchdog/ib700wdt.c index 3cec6790893e..be61e4755891 100644 --- a/drivers/char/watchdog/ib700wdt.c +++ b/drivers/char/watchdog/ib700wdt.c | |||
@@ -128,14 +128,20 @@ MODULE_PARM_DESC(nowayout, "Watchdog cannot be stopped once started (default=" _ | |||
128 | static void | 128 | static void |
129 | ibwdt_ping(void) | 129 | ibwdt_ping(void) |
130 | { | 130 | { |
131 | spin_lock(&ibwdt_lock); | ||
132 | |||
131 | /* Write a watchdog value */ | 133 | /* Write a watchdog value */ |
132 | outb_p(wd_margin, WDT_START); | 134 | outb_p(wd_margin, WDT_START); |
135 | |||
136 | spin_unlock(&ibwdt_lock); | ||
133 | } | 137 | } |
134 | 138 | ||
135 | static void | 139 | static void |
136 | ibwdt_disable(void) | 140 | ibwdt_disable(void) |
137 | { | 141 | { |
142 | spin_lock(&ibwdt_lock); | ||
138 | outb_p(0, WDT_STOP); | 143 | outb_p(0, WDT_STOP); |
144 | spin_unlock(&ibwdt_lock); | ||
139 | } | 145 | } |
140 | 146 | ||
141 | static int | 147 | static int |
@@ -218,7 +224,26 @@ ibwdt_ioctl(struct inode *inode, struct file *file, unsigned int cmd, | |||
218 | 224 | ||
219 | case WDIOC_GETTIMEOUT: | 225 | case WDIOC_GETTIMEOUT: |
220 | return put_user(wd_times[wd_margin], p); | 226 | return put_user(wd_times[wd_margin], p); |
221 | break; | 227 | |
228 | case WDIOC_SETOPTIONS: | ||
229 | { | ||
230 | int options, retval = -EINVAL; | ||
231 | |||
232 | if (get_user(options, p)) | ||
233 | return -EFAULT; | ||
234 | |||
235 | if (options & WDIOS_DISABLECARD) { | ||
236 | ibwdt_disable(); | ||
237 | retval = 0; | ||
238 | } | ||
239 | |||
240 | if (options & WDIOS_ENABLECARD) { | ||
241 | ibwdt_ping(); | ||
242 | retval = 0; | ||
243 | } | ||
244 | |||
245 | return retval; | ||
246 | } | ||
222 | 247 | ||
223 | default: | 248 | default: |
224 | return -ENOTTY; | 249 | return -ENOTTY; |
@@ -229,9 +254,7 @@ ibwdt_ioctl(struct inode *inode, struct file *file, unsigned int cmd, | |||
229 | static int | 254 | static int |
230 | ibwdt_open(struct inode *inode, struct file *file) | 255 | ibwdt_open(struct inode *inode, struct file *file) |
231 | { | 256 | { |
232 | spin_lock(&ibwdt_lock); | ||
233 | if (test_and_set_bit(0, &ibwdt_is_open)) { | 257 | if (test_and_set_bit(0, &ibwdt_is_open)) { |
234 | spin_unlock(&ibwdt_lock); | ||
235 | return -EBUSY; | 258 | return -EBUSY; |
236 | } | 259 | } |
237 | if (nowayout) | 260 | if (nowayout) |
@@ -239,14 +262,12 @@ ibwdt_open(struct inode *inode, struct file *file) | |||
239 | 262 | ||
240 | /* Activate */ | 263 | /* Activate */ |
241 | ibwdt_ping(); | 264 | ibwdt_ping(); |
242 | spin_unlock(&ibwdt_lock); | ||
243 | return nonseekable_open(inode, file); | 265 | return nonseekable_open(inode, file); |
244 | } | 266 | } |
245 | 267 | ||
246 | static int | 268 | static int |
247 | ibwdt_close(struct inode *inode, struct file *file) | 269 | ibwdt_close(struct inode *inode, struct file *file) |
248 | { | 270 | { |
249 | spin_lock(&ibwdt_lock); | ||
250 | if (expect_close == 42) { | 271 | if (expect_close == 42) { |
251 | ibwdt_disable(); | 272 | ibwdt_disable(); |
252 | } else { | 273 | } else { |
@@ -255,7 +276,6 @@ ibwdt_close(struct inode *inode, struct file *file) | |||
255 | } | 276 | } |
256 | clear_bit(0, &ibwdt_is_open); | 277 | clear_bit(0, &ibwdt_is_open); |
257 | expect_close = 0; | 278 | expect_close = 0; |
258 | spin_unlock(&ibwdt_lock); | ||
259 | return 0; | 279 | return 0; |
260 | } | 280 | } |
261 | 281 | ||