diff options
Diffstat (limited to 'drivers/sbus/char')
-rw-r--r-- | drivers/sbus/char/cpwatchdog.c | 2 | ||||
-rw-r--r-- | drivers/sbus/char/display7seg.c | 4 | ||||
-rw-r--r-- | drivers/sbus/char/rtc.c | 22 |
3 files changed, 25 insertions, 3 deletions
diff --git a/drivers/sbus/char/cpwatchdog.c b/drivers/sbus/char/cpwatchdog.c index 071ae24be892..fd2cc7782f76 100644 --- a/drivers/sbus/char/cpwatchdog.c +++ b/drivers/sbus/char/cpwatchdog.c | |||
@@ -407,7 +407,7 @@ static long wd_compat_ioctl(struct file *file, unsigned int cmd, | |||
407 | case WIOCGSTAT: | 407 | case WIOCGSTAT: |
408 | lock_kernel(); | 408 | lock_kernel(); |
409 | rval = wd_ioctl(file->f_dentry->d_inode, file, cmd, arg); | 409 | rval = wd_ioctl(file->f_dentry->d_inode, file, cmd, arg); |
410 | lock_kernel(); | 410 | unlock_kernel(); |
411 | break; | 411 | break; |
412 | /* everything else is handled by the generic compat layer */ | 412 | /* everything else is handled by the generic compat layer */ |
413 | default: | 413 | default: |
diff --git a/drivers/sbus/char/display7seg.c b/drivers/sbus/char/display7seg.c index 39f54213a6d5..c3a51d1fae5d 100644 --- a/drivers/sbus/char/display7seg.c +++ b/drivers/sbus/char/display7seg.c | |||
@@ -119,7 +119,7 @@ static long d7s_ioctl(struct file *file, unsigned int cmd, unsigned long arg) | |||
119 | { | 119 | { |
120 | __u8 regs = readb(d7s_regs); | 120 | __u8 regs = readb(d7s_regs); |
121 | __u8 ireg = 0; | 121 | __u8 ireg = 0; |
122 | int error = 0 | 122 | int error = 0; |
123 | 123 | ||
124 | if (D7S_MINOR != iminor(file->f_dentry->d_inode)) | 124 | if (D7S_MINOR != iminor(file->f_dentry->d_inode)) |
125 | return -ENODEV; | 125 | return -ENODEV; |
@@ -161,7 +161,7 @@ static long d7s_ioctl(struct file *file, unsigned int cmd, unsigned long arg) | |||
161 | writeb(regs, d7s_regs); | 161 | writeb(regs, d7s_regs); |
162 | break; | 162 | break; |
163 | }; | 163 | }; |
164 | lock_kernel(); | 164 | unlock_kernel(); |
165 | 165 | ||
166 | return error; | 166 | return error; |
167 | } | 167 | } |
diff --git a/drivers/sbus/char/rtc.c b/drivers/sbus/char/rtc.c index 9b988baf0b51..5774bdd0e26f 100644 --- a/drivers/sbus/char/rtc.c +++ b/drivers/sbus/char/rtc.c | |||
@@ -210,6 +210,27 @@ static int rtc_ioctl(struct inode *inode, struct file *file, unsigned int cmd, | |||
210 | } | 210 | } |
211 | } | 211 | } |
212 | 212 | ||
213 | static long rtc_compat_ioctl(struct file *file, unsigned int cmd, | ||
214 | unsigned long arg) | ||
215 | { | ||
216 | int rval = -ENOIOCTLCMD; | ||
217 | |||
218 | switch (cmd) { | ||
219 | /* | ||
220 | * These two are specific to this driver, the generic rtc ioctls | ||
221 | * are hanlded elsewhere. | ||
222 | */ | ||
223 | case RTCGET: | ||
224 | case RTCSET: | ||
225 | lock_kernel(); | ||
226 | rval = rtc_ioctl(file->f_dentry->d_inode, file, cmd, arg); | ||
227 | unlock_kernel(); | ||
228 | break; | ||
229 | } | ||
230 | |||
231 | return rval; | ||
232 | } | ||
233 | |||
213 | static int rtc_open(struct inode *inode, struct file *file) | 234 | static int rtc_open(struct inode *inode, struct file *file) |
214 | { | 235 | { |
215 | int ret; | 236 | int ret; |
@@ -237,6 +258,7 @@ static struct file_operations rtc_fops = { | |||
237 | .owner = THIS_MODULE, | 258 | .owner = THIS_MODULE, |
238 | .llseek = no_llseek, | 259 | .llseek = no_llseek, |
239 | .ioctl = rtc_ioctl, | 260 | .ioctl = rtc_ioctl, |
261 | .compat_ioctl = rtc_compat_ioctl, | ||
240 | .open = rtc_open, | 262 | .open = rtc_open, |
241 | .release = rtc_release, | 263 | .release = rtc_release, |
242 | }; | 264 | }; |