diff options
Diffstat (limited to 'drivers/sbus/char')
-rw-r--r-- | drivers/sbus/char/rtc.c | 22 |
1 files changed, 22 insertions, 0 deletions
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 | }; |