From 4146ce7bb8fd11f8d965ac685c3ae383ad803723 Mon Sep 17 00:00:00 2001 From: Arnd Bergmann Date: Tue, 20 May 2008 19:16:03 +0200 Subject: [PATCH] --- yaml --- r: 100353 b: refs/heads/master c: b0e54f7c477ad24fa0d49baed942c5a5909c748b h: refs/heads/master i: 100351: 8a46db1dffaf095df2ccc5b3a9f89370139a46f2 v: v3 --- [refs] | 2 +- trunk/drivers/char/ip27-rtc.c | 4 ++++ 2 files changed, 5 insertions(+), 1 deletion(-) diff --git a/[refs] b/[refs] index 66aff9b0b243..8cc94fd9ba6c 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 6b0ee363b294c3724224909dcb0b80f7dac3dfd6 +refs/heads/master: b0e54f7c477ad24fa0d49baed942c5a5909c748b diff --git a/trunk/drivers/char/ip27-rtc.c b/trunk/drivers/char/ip27-rtc.c index 86e6538a77b0..ec9d0443d92c 100644 --- a/trunk/drivers/char/ip27-rtc.c +++ b/trunk/drivers/char/ip27-rtc.c @@ -27,6 +27,7 @@ #include #include #include +#include #include #include #include @@ -163,15 +164,18 @@ static long rtc_ioctl(struct file *filp, unsigned int cmd, unsigned long arg) static int rtc_open(struct inode *inode, struct file *file) { + lock_kernel(); spin_lock_irq(&rtc_lock); if (rtc_status & RTC_IS_OPEN) { spin_unlock_irq(&rtc_lock); + unlock_kernel(); return -EBUSY; } rtc_status |= RTC_IS_OPEN; spin_unlock_irq(&rtc_lock); + unlock_kernel(); return 0; }