[PATCH] ext3: sparse fixes
[linux-3.10.git] / arch / x86_64 / ia32 / ia32_ioctl.c
1 /* $Id: ia32_ioctl.c,v 1.25 2002/10/11 07:17:06 ak Exp $
2  * ioctl32.c: Conversion between 32bit and 64bit native ioctls.
3  *
4  * Copyright (C) 1997-2000  Jakub Jelinek  (jakub@redhat.com)
5  * Copyright (C) 1998  Eddie C. Dost  (ecd@skynet.be)
6  * Copyright (C) 2001,2002  Andi Kleen, SuSE Labs 
7  *
8  * These routines maintain argument size conversion between 32bit and 64bit
9  * ioctls.
10  */
11
12 #define INCLUDES
13 #include <linux/syscalls.h>
14 #include "compat_ioctl.c"
15 #include <asm/ia32.h>
16
17 #define CODE
18 #include "compat_ioctl.c"
19   
20 #ifndef TIOCGDEV
21 #define TIOCGDEV       _IOR('T',0x32, unsigned int)
22 #endif
23 static int tiocgdev(unsigned fd, unsigned cmd,  unsigned int __user *ptr) 
24
25
26         struct file *file;
27         struct tty_struct *real_tty;
28         int fput_needed, ret;
29
30         file = fget_light(fd, &fput_needed);
31         if (!file)
32                 return -EBADF;
33
34         ret = -EINVAL;
35         if (file->f_op->ioctl != tty_ioctl)
36                 goto out;
37         real_tty = (struct tty_struct *)file->private_data;
38         if (!real_tty)  
39                 goto out;
40
41         ret = put_user(new_encode_dev(tty_devnum(real_tty)), ptr); 
42
43 out:
44         fput_light(file, fput_needed);
45         return ret;
46
47
48 #define RTC_IRQP_READ32 _IOR('p', 0x0b, unsigned int)    /* Read IRQ rate   */
49 #define RTC_IRQP_SET32  _IOW('p', 0x0c, unsigned int)    /* Set IRQ rate    */
50 #define RTC_EPOCH_READ32        _IOR('p', 0x0d, unsigned)        /* Read epoch      */
51 #define RTC_EPOCH_SET32         _IOW('p', 0x0e, unsigned)        /* Set epoch       */
52
53 static int rtc32_ioctl(unsigned fd, unsigned cmd, unsigned long arg) 
54
55         unsigned long val;
56         mm_segment_t oldfs = get_fs(); 
57         int ret; 
58         
59         switch (cmd) { 
60         case RTC_IRQP_READ32: 
61                 set_fs(KERNEL_DS); 
62                 ret = sys_ioctl(fd, RTC_IRQP_READ, (unsigned long)&val); 
63                 set_fs(oldfs); 
64                 if (!ret)
65                         ret = put_user(val, (unsigned int __user *) arg); 
66                 return ret; 
67
68         case RTC_IRQP_SET32: 
69                 cmd = RTC_IRQP_SET; 
70                 break; 
71
72         case RTC_EPOCH_READ32:
73                 set_fs(KERNEL_DS); 
74                 ret = sys_ioctl(fd, RTC_EPOCH_READ, (unsigned long) &val); 
75                 set_fs(oldfs); 
76                 if (!ret)
77                         ret = put_user(val, (unsigned int __user *) arg); 
78                 return ret; 
79
80         case RTC_EPOCH_SET32:
81                 cmd = RTC_EPOCH_SET; 
82                 break; 
83         } 
84         return sys_ioctl(fd,cmd,arg); 
85
86
87
88 #define HANDLE_IOCTL(cmd,handler) { (cmd), (ioctl_trans_handler_t)(handler) }, 
89 #define COMPATIBLE_IOCTL(cmd) HANDLE_IOCTL(cmd,sys_ioctl)
90
91 struct ioctl_trans ioctl_start[] = { 
92 #include <linux/compat_ioctl.h>
93 #define DECLARES
94 #include "compat_ioctl.c"
95 COMPATIBLE_IOCTL(HDIO_SET_KEEPSETTINGS)
96 COMPATIBLE_IOCTL(HDIO_SCAN_HWIF)
97 COMPATIBLE_IOCTL(BLKRASET)
98 COMPATIBLE_IOCTL(0x4B50)   /* KDGHWCLK - not in the kernel, but don't complain */
99 COMPATIBLE_IOCTL(0x4B51)   /* KDSHWCLK - not in the kernel, but don't complain */
100 COMPATIBLE_IOCTL(FIOQSIZE)
101
102 /* And these ioctls need translation */
103 HANDLE_IOCTL(TIOCGDEV, tiocgdev)
104 /* realtime device */
105 HANDLE_IOCTL(RTC_IRQP_READ,  rtc32_ioctl)
106 HANDLE_IOCTL(RTC_IRQP_READ32,rtc32_ioctl)
107 HANDLE_IOCTL(RTC_IRQP_SET32, rtc32_ioctl)
108 HANDLE_IOCTL(RTC_EPOCH_READ32, rtc32_ioctl)
109 HANDLE_IOCTL(RTC_EPOCH_SET32, rtc32_ioctl)
110 /* take care of sizeof(sizeof()) breakage */
111 }; 
112
113 int ioctl_table_size = ARRAY_SIZE(ioctl_start);
114