Skip to content

Commit

Permalink
[WATCHDOG 39/57] sbc8360: clean up
Browse files Browse the repository at this point in the history
Review and switch to unlocked_ioctl

Signed-off-by: Alan Cox <alan@redhat.com>
Signed-off-by: Wim Van Sebroeck <wim@iguana.be>
  • Loading branch information
Alan Cox authored and Wim Van Sebroeck committed Jun 21, 2008
1 parent 619a8a2 commit 9f53c8d
Showing 1 changed file with 12 additions and 18 deletions.
30 changes: 12 additions & 18 deletions drivers/watchdog/sbc8360.c
Original file line number Diff line number Diff line change
Expand Up @@ -48,13 +48,12 @@
#include <linux/init.h>
#include <linux/spinlock.h>
#include <linux/moduleparam.h>
#include <linux/io.h>
#include <linux/uaccess.h>

#include <asm/io.h>
#include <asm/uaccess.h>
#include <asm/system.h>

static unsigned long sbc8360_is_open;
static DEFINE_SPINLOCK(sbc8360_lock);
static char expect_close;

#define PFX "sbc8360: "
Expand Down Expand Up @@ -204,7 +203,8 @@ module_param(timeout, int, 0);
MODULE_PARM_DESC(timeout, "Index into timeout table (0-63) (default=27 (60s))");
module_param(nowayout, int, 0);
MODULE_PARM_DESC(nowayout,
"Watchdog cannot be stopped once started (default=" __MODULE_STRING(WATCHDOG_NOWAYOUT) ")");
"Watchdog cannot be stopped once started (default="
__MODULE_STRING(WATCHDOG_NOWAYOUT) ")");

/*
* Kernel methods.
Expand Down Expand Up @@ -232,8 +232,8 @@ static void sbc8360_ping(void)
}

/* Userspace pings kernel driver, or requests clean close */
static ssize_t sbc8360_write(struct file *file, const char __user * buf,
size_t count, loff_t * ppos)
static ssize_t sbc8360_write(struct file *file, const char __user *buf,
size_t count, loff_t *ppos)
{
if (count) {
if (!nowayout) {
Expand All @@ -257,33 +257,27 @@ static ssize_t sbc8360_write(struct file *file, const char __user * buf,

static int sbc8360_open(struct inode *inode, struct file *file)
{
spin_lock(&sbc8360_lock);
if (test_and_set_bit(0, &sbc8360_is_open)) {
spin_unlock(&sbc8360_lock);
if (test_and_set_bit(0, &sbc8360_is_open))
return -EBUSY;
}
if (nowayout)
__module_get(THIS_MODULE);

/* Activate and ping once to start the countdown */
spin_unlock(&sbc8360_lock);
sbc8360_activate();
sbc8360_ping();
return nonseekable_open(inode, file);
}

static int sbc8360_close(struct inode *inode, struct file *file)
{
spin_lock(&sbc8360_lock);
if (expect_close == 42)
outb(0, SBC8360_ENABLE);
else
printk(KERN_CRIT PFX
"SBC8360 device closed unexpectedly. SBC8360 will not stop!\n");
"SBC8360 device closed unexpectedly. SBC8360 will not stop!\n");

clear_bit(0, &sbc8360_is_open);
expect_close = 0;
spin_unlock(&sbc8360_lock);
return 0;
}

Expand Down Expand Up @@ -382,13 +376,13 @@ static int __init sbc8360_init(void)

return 0;

out_nomisc:
out_nomisc:
unregister_reboot_notifier(&sbc8360_notifier);
out_noreboot:
out_noreboot:
release_region(SBC8360_BASETIME, 1);
out_nobasetimereg:
out_nobasetimereg:
release_region(SBC8360_ENABLE, 1);
out:
out:
return res;
}

Expand Down

0 comments on commit 9f53c8d

Please sign in to comment.