123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114 |
- /* $Id: ia32_ioctl.c,v 1.25 2002/10/11 07:17:06 ak Exp $
- * ioctl32.c: Conversion between 32bit and 64bit native ioctls.
- *
- * Copyright (C) 1997-2000 Jakub Jelinek (jakub@redhat.com)
- * Copyright (C) 1998 Eddie C. Dost (ecd@skynet.be)
- * Copyright (C) 2001,2002 Andi Kleen, SuSE Labs
- *
- * These routines maintain argument size conversion between 32bit and 64bit
- * ioctls.
- */
- #define INCLUDES
- #include <linux/syscalls.h>
- #include "compat_ioctl.c"
- #include <asm/ia32.h>
- #define CODE
- #include "compat_ioctl.c"
-
- #ifndef TIOCGDEV
- #define TIOCGDEV _IOR('T',0x32, unsigned int)
- #endif
- static int tiocgdev(unsigned fd, unsigned cmd, unsigned int __user *ptr)
- {
- struct file *file;
- struct tty_struct *real_tty;
- int fput_needed, ret;
- file = fget_light(fd, &fput_needed);
- if (!file)
- return -EBADF;
- ret = -EINVAL;
- if (file->f_op->ioctl != tty_ioctl)
- goto out;
- real_tty = (struct tty_struct *)file->private_data;
- if (!real_tty)
- goto out;
- ret = put_user(new_encode_dev(tty_devnum(real_tty)), ptr);
- out:
- fput_light(file, fput_needed);
- return ret;
- }
- #define RTC_IRQP_READ32 _IOR('p', 0x0b, unsigned int) /* Read IRQ rate */
- #define RTC_IRQP_SET32 _IOW('p', 0x0c, unsigned int) /* Set IRQ rate */
- #define RTC_EPOCH_READ32 _IOR('p', 0x0d, unsigned) /* Read epoch */
- #define RTC_EPOCH_SET32 _IOW('p', 0x0e, unsigned) /* Set epoch */
- static int rtc32_ioctl(unsigned fd, unsigned cmd, unsigned long arg)
- {
- unsigned long val;
- mm_segment_t oldfs = get_fs();
- int ret;
-
- switch (cmd) {
- case RTC_IRQP_READ32:
- set_fs(KERNEL_DS);
- ret = sys_ioctl(fd, RTC_IRQP_READ, (unsigned long)&val);
- set_fs(oldfs);
- if (!ret)
- ret = put_user(val, (unsigned int __user *) arg);
- return ret;
- case RTC_IRQP_SET32:
- cmd = RTC_IRQP_SET;
- break;
- case RTC_EPOCH_READ32:
- set_fs(KERNEL_DS);
- ret = sys_ioctl(fd, RTC_EPOCH_READ, (unsigned long) &val);
- set_fs(oldfs);
- if (!ret)
- ret = put_user(val, (unsigned int __user *) arg);
- return ret;
- case RTC_EPOCH_SET32:
- cmd = RTC_EPOCH_SET;
- break;
- }
- return sys_ioctl(fd,cmd,arg);
- }
- #define HANDLE_IOCTL(cmd,handler) { (cmd), (ioctl_trans_handler_t)(handler) },
- #define COMPATIBLE_IOCTL(cmd) HANDLE_IOCTL(cmd,sys_ioctl)
- struct ioctl_trans ioctl_start[] = {
- #include <linux/compat_ioctl.h>
- #define DECLARES
- #include "compat_ioctl.c"
- COMPATIBLE_IOCTL(HDIO_SET_KEEPSETTINGS)
- COMPATIBLE_IOCTL(HDIO_SCAN_HWIF)
- COMPATIBLE_IOCTL(BLKRASET)
- COMPATIBLE_IOCTL(0x4B50) /* KDGHWCLK - not in the kernel, but don't complain */
- COMPATIBLE_IOCTL(0x4B51) /* KDSHWCLK - not in the kernel, but don't complain */
- COMPATIBLE_IOCTL(FIOQSIZE)
- /* And these ioctls need translation */
- HANDLE_IOCTL(TIOCGDEV, tiocgdev)
- /* realtime device */
- HANDLE_IOCTL(RTC_IRQP_READ, rtc32_ioctl)
- HANDLE_IOCTL(RTC_IRQP_READ32,rtc32_ioctl)
- HANDLE_IOCTL(RTC_IRQP_SET32, rtc32_ioctl)
- HANDLE_IOCTL(RTC_EPOCH_READ32, rtc32_ioctl)
- HANDLE_IOCTL(RTC_EPOCH_SET32, rtc32_ioctl)
- /* take care of sizeof(sizeof()) breakage */
- };
- int ioctl_table_size = ARRAY_SIZE(ioctl_start);
|