tty: now phase out the ioctl file pointer for good
authorAlan Cox <alan@linux.intel.com>
Mon, 14 Feb 2011 16:27:22 +0000 (16:27 +0000)
committerGreg Kroah-Hartman <gregkh@suse.de>
Thu, 17 Feb 2011 19:59:56 +0000 (11:59 -0800)
Only oddities here are a couple of drivers that bogusly called the ldisc
helpers instead of returning -ENOIOCTLCMD. Fix the bug and the rest goes
away.

Signed-off-by: Alan Cox <alan@linux.intel.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
41 files changed:
drivers/char/amiserial.c
drivers/char/cyclades.c
drivers/char/epca.c
drivers/char/ip2/ip2main.c
drivers/char/isicom.c
drivers/char/istallion.c
drivers/char/moxa.c
drivers/char/mxser.c
drivers/char/nozomi.c
drivers/char/pcmcia/ipwireless/tty.c
drivers/char/riscom8.c
drivers/char/rocket.c
drivers/char/ser_a2232.c
drivers/char/serial167.c
drivers/char/specialix.c
drivers/char/stallion.c
drivers/char/sx.c
drivers/char/synclink.c
drivers/char/synclink_gt.c
drivers/char/synclinkmp.c
drivers/char/ttyprintk.c
drivers/char/vme_scc.c
drivers/isdn/capi/capi.c
drivers/isdn/gigaset/interface.c
drivers/isdn/i4l/isdn_tty.c
drivers/net/usb/hso.c
drivers/tty/n_gsm.c
drivers/tty/pty.c
drivers/tty/serial/68328serial.c
drivers/tty/serial/68360serial.c
drivers/tty/serial/crisv10.c
drivers/tty/serial/serial_core.c
drivers/tty/tty_io.c
drivers/tty/vt/vt_ioctl.c
drivers/usb/class/cdc-acm.c
drivers/usb/serial/usb-serial.c
include/linux/tty.h
include/linux/tty_driver.h
include/net/irda/ircomm_tty.h
net/bluetooth/rfcomm/tty.c
net/irda/ircomm/ircomm_tty_ioctl.c

index 5c15fad71ad29cf00a871876baa385eecf63e9d3..f214e5022472e6c02f8f6ff788b596c40238a3ee 100644 (file)
@@ -1293,7 +1293,7 @@ static int rs_get_icount(struct tty_struct *tty,
        return 0;
 }
 
-static int rs_ioctl(struct tty_struct *tty, struct file * file,
+static int rs_ioctl(struct tty_struct *tty,
                    unsigned int cmd, unsigned long arg)
 {
        struct async_struct * info = tty->driver_data;
index 942b6f2b70a484ff13ae6b2c0963a8a165b10564..c99728f0cd9f004d15e687b99b4db937ee870ed9 100644 (file)
@@ -2680,7 +2680,7 @@ static int cy_cflags_changed(struct cyclades_port *info, unsigned long arg,
  * not recognized by the driver, it should return ENOIOCTLCMD.
  */
 static int
-cy_ioctl(struct tty_struct *tty, struct file *file,
+cy_ioctl(struct tty_struct *tty,
         unsigned int cmd, unsigned long arg)
 {
        struct cyclades_port *info = tty->driver_data;
index e5872b59f9cddfb95f9f0ebc744dec1f87343bd3..7ad3638967aeb1519c6fc09d9bd5b00958660fdc 100644 (file)
@@ -175,9 +175,9 @@ static unsigned termios2digi_i(struct channel *ch, unsigned);
 static unsigned termios2digi_c(struct channel *ch, unsigned);
 static void epcaparam(struct tty_struct *, struct channel *);
 static void receive_data(struct channel *, struct tty_struct *tty);
-static int pc_ioctl(struct tty_struct *, struct file *,
+static int pc_ioctl(struct tty_struct *,
                        unsigned int, unsigned long);
-static int info_ioctl(struct tty_struct *, struct file *,
+static int info_ioctl(struct tty_struct *,
                        unsigned int, unsigned long);
 static void pc_set_termios(struct tty_struct *, struct ktermios *);
 static void do_softint(struct work_struct *work);
@@ -1919,7 +1919,7 @@ static void receive_data(struct channel *ch, struct tty_struct *tty)
        tty_schedule_flip(tty);
 }
 
-static int info_ioctl(struct tty_struct *tty, struct file *file,
+static int info_ioctl(struct tty_struct *tty,
                    unsigned int cmd, unsigned long arg)
 {
        switch (cmd) {
@@ -2057,7 +2057,7 @@ static int pc_tiocmset(struct tty_struct *tty,
        return 0;
 }
 
-static int pc_ioctl(struct tty_struct *tty, struct file *file,
+static int pc_ioctl(struct tty_struct *tty,
                                        unsigned int cmd, unsigned long arg)
 {
        digiflow_t dflow;
index d5f866c7c6726732bf471e51498e2d4dcb53cbc0..ea7a8fb082832c903e5a3f8475d7f9afe7d69a6f 100644 (file)
@@ -173,7 +173,7 @@ static void ip2_flush_chars(PTTY);
 static int  ip2_write_room(PTTY);
 static int  ip2_chars_in_buf(PTTY);
 static void ip2_flush_buffer(PTTY);
-static int  ip2_ioctl(PTTY, struct file *, UINT, ULONG);
+static int  ip2_ioctl(PTTY, UINT, ULONG);
 static void ip2_set_termios(PTTY, struct ktermios *);
 static void ip2_set_line_discipline(PTTY);
 static void ip2_throttle(PTTY);
@@ -2127,7 +2127,7 @@ static int ip2_tiocmset(struct tty_struct *tty,
 /*                                                                            */
 /******************************************************************************/
 static int
-ip2_ioctl ( PTTY tty, struct file *pFile, UINT cmd, ULONG arg )
+ip2_ioctl ( PTTY tty, UINT cmd, ULONG arg )
 {
        wait_queue_t wait;
        i2ChanStrPtr pCh = DevTable[tty->index];
index 60f4d8ae7a495f06e6080055660e01213da04f53..db1cf9c328d86d8bc5ec62e91e3a8a721853892f 100644 (file)
@@ -1167,7 +1167,7 @@ static int isicom_get_serial_info(struct isi_port *port,
        return 0;
 }
 
-static int isicom_ioctl(struct tty_struct *tty, struct file *filp,
+static int isicom_ioctl(struct tty_struct *tty,
        unsigned int cmd, unsigned long arg)
 {
        struct isi_port *port = tty->driver_data;
index 763b58d582551c0dea49b6f316025a53aad1d25e..0b266272cccd5f6a6edbab2c79c067adb178e75a 100644 (file)
@@ -603,7 +603,7 @@ static int  stli_putchar(struct tty_struct *tty, unsigned char ch);
 static void    stli_flushchars(struct tty_struct *tty);
 static int     stli_writeroom(struct tty_struct *tty);
 static int     stli_charsinbuffer(struct tty_struct *tty);
-static int     stli_ioctl(struct tty_struct *tty, struct file *file, unsigned int cmd, unsigned long arg);
+static int     stli_ioctl(struct tty_struct *tty, unsigned int cmd, unsigned long arg);
 static void    stli_settermios(struct tty_struct *tty, struct ktermios *old);
 static void    stli_throttle(struct tty_struct *tty);
 static void    stli_unthrottle(struct tty_struct *tty);
@@ -1556,7 +1556,7 @@ static int stli_tiocmset(struct tty_struct *tty,
                            sizeof(asysigs_t), 0);
 }
 
-static int stli_ioctl(struct tty_struct *tty, struct file *file, unsigned int cmd, unsigned long arg)
+static int stli_ioctl(struct tty_struct *tty, unsigned int cmd, unsigned long arg)
 {
        struct stliport *portp;
        struct stlibrd *brdp;
index 9f4cd8968a5a1b44186d559a642de85d2865aeb9..35b0c38590e6b641aabdb45383030bebce31c3bd 100644 (file)
@@ -287,7 +287,7 @@ static void moxa_low_water_check(void __iomem *ofsAddr)
  * TTY operations
  */
 
-static int moxa_ioctl(struct tty_struct *tty, struct file *file,
+static int moxa_ioctl(struct tty_struct *tty,
                      unsigned int cmd, unsigned long arg)
 {
        struct moxa_port *ch = tty->driver_data;
index 150a862c498901b28c11581e75040a59fd59487f..d188f378684dfc695dfe724d839a259ca73fd644 100644 (file)
@@ -1655,7 +1655,7 @@ static int mxser_cflags_changed(struct mxser_port *info, unsigned long arg,
        return ret;
 }
 
-static int mxser_ioctl(struct tty_struct *tty, struct file *file,
+static int mxser_ioctl(struct tty_struct *tty,
                unsigned int cmd, unsigned long arg)
 {
        struct mxser_port *info = tty->driver_data;
index 1b74c48c40167f242c1072b7e3fda1fbf78459c9..513ba12064ead814520071d7a4c095cc9776f5b4 100644 (file)
@@ -1824,7 +1824,7 @@ static int ntty_tiocgicount(struct tty_struct *tty,
        return 0;
 }
 
-static int ntty_ioctl(struct tty_struct *tty, struct file *file,
+static int ntty_ioctl(struct tty_struct *tty,
                      unsigned int cmd, unsigned long arg)
 {
        struct port *port = tty->driver_data;
index 748190dfbab0c19da8a68448237080c81cb43efb..ef92869502a707dc856ade814e0fe82e8ca5008a 100644 (file)
@@ -425,7 +425,7 @@ ipw_tiocmset(struct tty_struct *linux_tty,
        return set_control_lines(tty, set, clear);
 }
 
-static int ipw_ioctl(struct tty_struct *linux_tty, struct file *file,
+static int ipw_ioctl(struct tty_struct *linux_tty,
                     unsigned int cmd, unsigned long arg)
 {
        struct ipw_tty *tty = linux_tty->driver_data;
@@ -484,7 +484,7 @@ static int ipw_ioctl(struct tty_struct *linux_tty, struct file *file,
                        return tty_perform_flush(linux_tty, arg);
                }
        }
-       return tty_mode_ioctl(linux_tty, file, cmd , arg);
+       return -ENOIOCTLCMD;
 }
 
 static int add_tty(int j,
index 3666decc6438964db6346f9345a5a2a8cd9b4dba..602643a40b4bf13dbef2917e638f82cd2620630d 100644 (file)
@@ -1236,7 +1236,7 @@ static int rc_get_serial_info(struct riscom_port *port,
        return copy_to_user(retinfo, &tmp, sizeof(tmp)) ? -EFAULT : 0;
 }
 
-static int rc_ioctl(struct tty_struct *tty, struct file *filp,
+static int rc_ioctl(struct tty_struct *tty,
                    unsigned int cmd, unsigned long arg)
 {
        struct riscom_port *port = tty->driver_data;
index 36c108811a81c22abb0123085791b4b3e6e7117e..3780da8ad12d931762b4fca52409bfde5f074eba 100644 (file)
@@ -1326,7 +1326,7 @@ static int get_version(struct r_port *info, struct rocket_version __user *retver
 }
 
 /*  IOCTL call handler into the driver */
-static int rp_ioctl(struct tty_struct *tty, struct file *file,
+static int rp_ioctl(struct tty_struct *tty,
                    unsigned int cmd, unsigned long arg)
 {
        struct r_port *info = tty->driver_data;
index 9610861d1f5f5b091a26a214050351785f1c47ba..3f47c2ead8e51790bc7dc14686ec5776d6dd28b9 100644 (file)
@@ -133,8 +133,8 @@ static void a2232_hungup(void *ptr);
 /* END GENERIC_SERIAL PROTOTYPES */
 
 /* Functions that the TTY driver struct expects */
-static int  a2232_ioctl(struct tty_struct *tty, struct file *file,
-                                                                               unsigned int cmd, unsigned long arg);
+static int  a2232_ioctl(struct tty_struct *tty,
+                               unsigned int cmd, unsigned long arg);
 static void a2232_throttle(struct tty_struct *tty);
 static void a2232_unthrottle(struct tty_struct *tty);
 static int  a2232_open(struct tty_struct * tty, struct file * filp);
@@ -447,7 +447,7 @@ static void a2232_hungup(void *ptr)
 /*** END   OF REAL_DRIVER FUNCTIONS ***/
 
 /*** BEGIN  FUNCTIONS EXPECTED BY TTY DRIVER STRUCTS ***/
-static int a2232_ioctl(        struct tty_struct *tty, struct file *file,
+static int a2232_ioctl(        struct tty_struct *tty,
                        unsigned int cmd, unsigned long arg)
 {
        return -ENOIOCTLCMD;
index 89ac542ffff26f002d046f19461e3ff33f3c5510..674af693397881963c0c55cfc50d2976ce501302 100644 (file)
@@ -1492,7 +1492,7 @@ get_default_timeout(struct cyclades_port *info, unsigned long __user * value)
 }
 
 static int
-cy_ioctl(struct tty_struct *tty, struct file *file,
+cy_ioctl(struct tty_struct *tty,
         unsigned int cmd, unsigned long arg)
 {
        struct cyclades_port *info = tty->driver_data;
index a6b23847e4a75de114214ff140208ab530a93f86..47e5753f732adec47eaa4ccef3b7dab42894041f 100644 (file)
@@ -1928,7 +1928,7 @@ static int sx_get_serial_info(struct specialix_port *port,
 }
 
 
-static int sx_ioctl(struct tty_struct *tty, struct file *filp,
+static int sx_ioctl(struct tty_struct *tty,
                                unsigned int cmd, unsigned long arg)
 {
        struct specialix_port *port = tty->driver_data;
index c42dbffbed16b47caea6cecfd29466e88171ff2f..4fff5cd3b163ac315bba6a0e7f28553fcce0da54 100644 (file)
@@ -1132,14 +1132,13 @@ static int stl_tiocmset(struct tty_struct *tty,
        return 0;
 }
 
-static int stl_ioctl(struct tty_struct *tty, struct file *file, unsigned int cmd, unsigned long arg)
+static int stl_ioctl(struct tty_struct *tty, unsigned int cmd, unsigned long arg)
 {
        struct stlport  *portp;
        int             rc;
        void __user *argp = (void __user *)arg;
 
-       pr_debug("stl_ioctl(tty=%p,file=%p,cmd=%x,arg=%lx)\n", tty, file, cmd,
-                       arg);
+       pr_debug("stl_ioctl(tty=%p,cmd=%x,arg=%lx)\n", tty, cmd, arg);
 
        portp = tty->driver_data;
        if (portp == NULL)
index 342c6ae67da56e1cc276b48d28b4895acde812c5..1291462bcddb2a257808d47408fcd0c030353893 100644 (file)
@@ -1899,7 +1899,7 @@ static int sx_tiocmset(struct tty_struct *tty,
        return 0;
 }
 
-static int sx_ioctl(struct tty_struct *tty, struct file *filp,
+static int sx_ioctl(struct tty_struct *tty,
                unsigned int cmd, unsigned long arg)
 {
        int rc;
index 691e1094c20b2a33d3dd85c4eab3f210f264d688..18888d005a0aeac870dcc001e24891fca5a80877 100644 (file)
@@ -2962,13 +2962,12 @@ static int msgl_get_icount(struct tty_struct *tty,
  * Arguments:
  * 
  *     tty     pointer to tty instance data
- *     file    pointer to associated file object for device
  *     cmd     IOCTL command code
  *     arg     command argument/context
  *     
  * Return Value:       0 if success, otherwise error code
  */
-static int mgsl_ioctl(struct tty_struct *tty, struct file * file,
+static int mgsl_ioctl(struct tty_struct *tty,
                    unsigned int cmd, unsigned long arg)
 {
        struct mgsl_struct * info = tty->driver_data;
index 04da6d61dc4f1c87dc6dcf1a2f15eb2ef6a3a74f..a35dd549a00833739df7c4264ec018381a2183ff 100644 (file)
@@ -154,7 +154,7 @@ static void flush_buffer(struct tty_struct *tty);
 static void tx_hold(struct tty_struct *tty);
 static void tx_release(struct tty_struct *tty);
 
-static int  ioctl(struct tty_struct *tty, struct file *file, unsigned int cmd, unsigned long arg);
+static int  ioctl(struct tty_struct *tty, unsigned int cmd, unsigned long arg);
 static int  chars_in_buffer(struct tty_struct *tty);
 static void throttle(struct tty_struct * tty);
 static void unthrottle(struct tty_struct * tty);
@@ -1030,13 +1030,12 @@ static void tx_release(struct tty_struct *tty)
  * Arguments
  *
  *     tty     pointer to tty instance data
- *     file    pointer to associated file object for device
  *     cmd     IOCTL command code
  *     arg     command argument/context
  *
  * Return 0 if success, otherwise error code
  */
-static int ioctl(struct tty_struct *tty, struct file *file,
+static int ioctl(struct tty_struct *tty,
                 unsigned int cmd, unsigned long arg)
 {
        struct slgt_info *info = tty->driver_data;
@@ -1200,7 +1199,7 @@ static long set_params32(struct slgt_info *info, struct MGSL_PARAMS32 __user *ne
        return 0;
 }
 
-static long slgt_compat_ioctl(struct tty_struct *tty, struct file *file,
+static long slgt_compat_ioctl(struct tty_struct *tty,
                         unsigned int cmd, unsigned long arg)
 {
        struct slgt_info *info = tty->driver_data;
@@ -1239,7 +1238,7 @@ static long slgt_compat_ioctl(struct tty_struct *tty, struct file *file,
        case MGSL_IOCSIF:
        case MGSL_IOCSXSYNC:
        case MGSL_IOCSXCTRL:
-               rc = ioctl(tty, file, cmd, arg);
+               rc = ioctl(tty, cmd, arg);
                break;
        }
 
index 1f9de97e8cfcdf2293476b901923a3f0c8f1d82d..327343694473de0ffb5156bbd876f615e670e690 100644 (file)
@@ -520,7 +520,7 @@ static void flush_buffer(struct tty_struct *tty);
 static void tx_hold(struct tty_struct *tty);
 static void tx_release(struct tty_struct *tty);
 
-static int  ioctl(struct tty_struct *tty, struct file *file, unsigned int cmd, unsigned long arg);
+static int  ioctl(struct tty_struct *tty, unsigned int cmd, unsigned long arg);
 static int  chars_in_buffer(struct tty_struct *tty);
 static void throttle(struct tty_struct * tty);
 static void unthrottle(struct tty_struct * tty);
@@ -1248,13 +1248,12 @@ static void tx_release(struct tty_struct *tty)
  * Arguments:
  *
  *     tty     pointer to tty instance data
- *     file    pointer to associated file object for device
  *     cmd     IOCTL command code
  *     arg     command argument/context
  *
  * Return Value:       0 if success, otherwise error code
  */
-static int ioctl(struct tty_struct *tty, struct file *file,
+static int ioctl(struct tty_struct *tty,
                 unsigned int cmd, unsigned long arg)
 {
        SLMP_INFO *info = tty->driver_data;
index c40c1612c8a72d5a4a4e7a07fcbe953fac7fe059..a1f68af4ccf476b5e58dd3942c08337e55303d81 100644 (file)
@@ -144,7 +144,7 @@ static int tpk_write_room(struct tty_struct *tty)
 /*
  * TTY operations ioctl function.
  */
-static int tpk_ioctl(struct tty_struct *tty, struct file *file,
+static int tpk_ioctl(struct tty_struct *tty,
                        unsigned int cmd, unsigned long arg)
 {
        struct ttyprintk_port *tpkp = tty->driver_data;
index 12de1202d22cc5b02dabd7362864d5120741cefc..96838640f5750d3c9d654f80b7065cf1ab754cbb 100644 (file)
@@ -75,7 +75,7 @@ static void scc_hungup(void  *ptr);
 static void scc_close(void  *ptr);
 static int scc_chars_in_buffer(void * ptr);
 static int scc_open(struct tty_struct * tty, struct file * filp);
-static int scc_ioctl(struct tty_struct * tty, struct file * filp,
+static int scc_ioctl(struct tty_struct * tty,
                      unsigned int cmd, unsigned long arg);
 static void scc_throttle(struct tty_struct *tty);
 static void scc_unthrottle(struct tty_struct *tty);
@@ -1046,7 +1046,7 @@ static void scc_unthrottle (struct tty_struct * tty)
 }
 
 
-static int scc_ioctl(struct tty_struct *tty, struct file *file,
+static int scc_ioctl(struct tty_struct *tty,
                     unsigned int cmd, unsigned long arg)
 {
        return -ENOIOCTLCMD;
index f80a7c48a35f852f4d5912f42a6af846769c9fa4..0d7088367038d2bf579696523bedaca49f247b03 100644 (file)
@@ -1219,16 +1219,10 @@ static int capinc_tty_chars_in_buffer(struct tty_struct *tty)
        return mp->outbytes;
 }
 
-static int capinc_tty_ioctl(struct tty_struct *tty, struct file * file,
+static int capinc_tty_ioctl(struct tty_struct *tty,
                    unsigned int cmd, unsigned long arg)
 {
-       int error = 0;
-       switch (cmd) {
-       default:
-               error = n_tty_ioctl_helper(tty, file, cmd, arg);
-               break;
-       }
-       return error;
+       return -ENOIOCTLCMD;
 }
 
 static void capinc_tty_set_termios(struct tty_struct *tty, struct ktermios * old)
index 9b2bb491c614dbb8967d313c7a46d9bc8ed15b58..59de638225fe4b30b71bcddc1cdf4ff8b50a4fa5 100644 (file)
@@ -115,7 +115,7 @@ static int if_config(struct cardstate *cs, int *arg)
 
 static int  if_open(struct tty_struct *tty, struct file *filp);
 static void if_close(struct tty_struct *tty, struct file *filp);
-static int  if_ioctl(struct tty_struct *tty, struct file *file,
+static int  if_ioctl(struct tty_struct *tty,
                     unsigned int cmd, unsigned long arg);
 static int  if_write_room(struct tty_struct *tty);
 static int  if_chars_in_buffer(struct tty_struct *tty);
@@ -205,7 +205,7 @@ static void if_close(struct tty_struct *tty, struct file *filp)
        module_put(cs->driver->owner);
 }
 
-static int if_ioctl(struct tty_struct *tty, struct file *file,
+static int if_ioctl(struct tty_struct *tty,
                    unsigned int cmd, unsigned long arg)
 {
        struct cardstate *cs;
index 0341c69eb1529ff44b6040d947bca79b3bf3dcfa..3d88f15aa218bc318d9a4e5c790d5c0029edf703 100644 (file)
@@ -1413,8 +1413,7 @@ isdn_tty_tiocmset(struct tty_struct *tty,
 }
 
 static int
-isdn_tty_ioctl(struct tty_struct *tty, struct file *file,
-              uint cmd, ulong arg)
+isdn_tty_ioctl(struct tty_struct *tty, uint cmd, ulong arg)
 {
        modem_info *info = (modem_info *) tty->driver_data;
        int retval;
index 956e1d6e72a5564105a61cd2ed52b7f3a1eab9df..2ad58a0377b7e12cbb6f5ed49bd7658839cb8c76 100644 (file)
@@ -1730,7 +1730,7 @@ static int hso_serial_tiocmset(struct tty_struct *tty,
                               USB_CTRL_SET_TIMEOUT);
 }
 
-static int hso_serial_ioctl(struct tty_struct *tty, struct file *file,
+static int hso_serial_ioctl(struct tty_struct *tty,
                            unsigned int cmd, unsigned long arg)
 {
        struct hso_serial *serial =  get_serial_by_tty(tty);
index 88477d16b8b7b7db837a251b3dd02139f922ca6a..50f3ffd610b70929353b3a353f265f9db8f0ddc3 100644 (file)
@@ -2671,7 +2671,7 @@ static int gsmtty_tiocmset(struct tty_struct *tty,
 }
 
 
-static int gsmtty_ioctl(struct tty_struct *tty, struct file *filp,
+static int gsmtty_ioctl(struct tty_struct *tty,
                        unsigned int cmd, unsigned long arg)
 {
        return -ENOIOCTLCMD;
index 923a48585501494f8b0bcae77aa562a1104bd7dd..c88029af84dd2a4f3dc95a9a6cabdc5f74fa9c03 100644 (file)
@@ -334,7 +334,7 @@ free_mem_out:
        return -ENOMEM;
 }
 
-static int pty_bsd_ioctl(struct tty_struct *tty, struct file *file,
+static int pty_bsd_ioctl(struct tty_struct *tty,
                         unsigned int cmd, unsigned long arg)
 {
        switch (cmd) {
@@ -489,7 +489,7 @@ static struct ctl_table pty_root_table[] = {
 };
 
 
-static int pty_unix98_ioctl(struct tty_struct *tty, struct file *file,
+static int pty_unix98_ioctl(struct tty_struct *tty,
                            unsigned int cmd, unsigned long arg)
 {
        switch (cmd) {
index a9d99856c8925e1460e389fb291b689448e8914d..1de0e8d4bde15aef094f8cace0de7306fcf73a42 100644 (file)
@@ -945,7 +945,7 @@ static void send_break(struct m68k_serial * info, unsigned int duration)
         local_irq_restore(flags);
 }
 
-static int rs_ioctl(struct tty_struct *tty, struct file * file,
+static int rs_ioctl(struct tty_struct *tty,
                    unsigned int cmd, unsigned long arg)
 {
        int error;
index 217fe1c299e0567fe23947e7a5cd17cf1af984e9..514a356d8d6454c60dba07957fa8cc3795c17533 100644 (file)
@@ -1405,7 +1405,7 @@ static int rs_360_get_icount(struct tty_struct *tty,
        return 0;
 }
 
-static int rs_360_ioctl(struct tty_struct *tty, struct file * file,
+static int rs_360_ioctl(struct tty_struct *tty,
                    unsigned int cmd, unsigned long arg)
 {
        int error;
index b9fcd0bda60c44696b3298b49df4c27128a35c53..225123b37f190de6ea448cba50be732ea20c3885 100644 (file)
@@ -3647,7 +3647,7 @@ rs_tiocmget(struct tty_struct *tty)
 
 
 static int
-rs_ioctl(struct tty_struct *tty, struct file * file,
+rs_ioctl(struct tty_struct *tty,
         unsigned int cmd, unsigned long arg)
 {
        struct e100_serial * info = (struct e100_serial *)tty->driver_data;
index 623d6bd911d71b0cf21fba9b9c1441b046530ee3..733fe8e73f0fcf4782f544d3c8205da88848a37b 100644 (file)
@@ -1099,7 +1099,7 @@ static int uart_get_icount(struct tty_struct *tty,
  * Called via sys_ioctl.  We can use spin_lock_irq() here.
  */
 static int
-uart_ioctl(struct tty_struct *tty, struct file *filp, unsigned int cmd,
+uart_ioctl(struct tty_struct *tty, unsigned int cmd,
           unsigned long arg)
 {
        struct uart_state *state = tty->driver_data;
@@ -1152,7 +1152,7 @@ uart_ioctl(struct tty_struct *tty, struct file *filp, unsigned int cmd,
 
        mutex_lock(&port->mutex);
 
-       if (tty_hung_up_p(filp)) {
+       if (tty->flags & (1 << TTY_IO_ERROR)) {
                ret = -EIO;
                goto out_up;
        }
index 83af24ca1e5e2ff683e757707a15955f8a19f436..20a862a2a0c28cd8e45a139672a874d83080b29c 100644 (file)
@@ -2676,7 +2676,7 @@ long tty_ioctl(struct file *file, unsigned int cmd, unsigned long arg)
                break;
        }
        if (tty->ops->ioctl) {
-               retval = (tty->ops->ioctl)(tty, file, cmd, arg);
+               retval = (tty->ops->ioctl)(tty, cmd, arg);
                if (retval != -ENOIOCTLCMD)
                        return retval;
        }
@@ -2704,7 +2704,7 @@ static long tty_compat_ioctl(struct file *file, unsigned int cmd,
                return -EINVAL;
 
        if (tty->ops->compat_ioctl) {
-               retval = (tty->ops->compat_ioctl)(tty, file, cmd, arg);
+               retval = (tty->ops->compat_ioctl)(tty, cmd, arg);
                if (retval != -ENOIOCTLCMD)
                        return retval;
        }
index 9e9a901442a35cd4b16ae7b78b766884beba8b72..b64804965316e4209fd4141cf2c25a1cf1b2cfdf 100644 (file)
@@ -495,7 +495,7 @@ do_unimap_ioctl(int cmd, struct unimapdesc __user *user_ud, int perm, struct vc_
  * We handle the console-specific ioctl's here.  We allow the
  * capability to modify any console, not just the fg_console. 
  */
-int vt_ioctl(struct tty_struct *tty, struct file * file,
+int vt_ioctl(struct tty_struct *tty,
             unsigned int cmd, unsigned long arg)
 {
        struct vc_data *vc = tty->driver_data;
@@ -1495,7 +1495,7 @@ compat_unimap_ioctl(unsigned int cmd, struct compat_unimapdesc __user *user_ud,
        return 0;
 }
 
-long vt_compat_ioctl(struct tty_struct *tty, struct file * file,
+long vt_compat_ioctl(struct tty_struct *tty,
             unsigned int cmd, unsigned long arg)
 {
        struct vc_data *vc = tty->driver_data;
@@ -1581,7 +1581,7 @@ out:
 
 fallback:
        tty_unlock();
-       return vt_ioctl(tty, file, cmd, arg);
+       return vt_ioctl(tty, cmd, arg);
 }
 
 
index e9a26fbd079cea6cd9cd43927d1fba5cd99ed4f5..8d994a8bdc9079fc795fa4129608da067ed7b49a 100644 (file)
@@ -813,7 +813,7 @@ static int acm_tty_tiocmset(struct tty_struct *tty,
        return acm_set_control(acm, acm->ctrlout = newctrl);
 }
 
-static int acm_tty_ioctl(struct tty_struct *tty, struct file *file,
+static int acm_tty_ioctl(struct tty_struct *tty,
                                        unsigned int cmd, unsigned long arg)
 {
        struct acm *acm = tty->driver_data;
index b1110e136c333ea56ba8b3e7c1ff6060c11cdad4..a72575349744bd4081a9540ee18f4a3decb68c5a 100644 (file)
@@ -406,7 +406,7 @@ static void serial_unthrottle(struct tty_struct *tty)
                port->serial->type->unthrottle(tty);
 }
 
-static int serial_ioctl(struct tty_struct *tty, struct file *file,
+static int serial_ioctl(struct tty_struct *tty,
                                        unsigned int cmd, unsigned long arg)
 {
        struct usb_serial_port *port = tty->driver_data;
index 54e4eaaa05610d8b101a97f1c3faa11d11399861..483df15146d25793cd707b9af11bea53df7be76e 100644 (file)
@@ -584,7 +584,7 @@ extern int pcxe_open(struct tty_struct *tty, struct file *filp);
 
 /* vt.c */
 
-extern int vt_ioctl(struct tty_struct *tty, struct file *file,
+extern int vt_ioctl(struct tty_struct *tty,
                    unsigned int cmd, unsigned long arg);
 
 extern long vt_compat_ioctl(struct tty_struct *tty, struct file * file,
index 5dabaa2e6da3c8e8b4b886677b9192073d4569d7..9deeac85524078f0ef97b140f270c39391509f51 100644 (file)
@@ -98,8 +98,7 @@
  *
  *     Note: Do not call this function directly, call tty_write_room
  * 
- * int  (*ioctl)(struct tty_struct *tty, struct file * file,
- *         unsigned int cmd, unsigned long arg);
+ * int  (*ioctl)(struct tty_struct *tty, unsigned int cmd, unsigned long arg);
  *
  *     This routine allows the tty driver to implement
  *     device-specific ioctls.  If the ioctl number passed in cmd
  *
  *     Optional
  *
- * long (*compat_ioctl)(struct tty_struct *tty, struct file * file,
+ * long (*compat_ioctl)(struct tty_struct *tty,,
  *                     unsigned int cmd, unsigned long arg);
  *
  *     implement ioctl processing for 32 bit process on 64 bit system
@@ -256,9 +255,9 @@ struct tty_operations {
        void (*flush_chars)(struct tty_struct *tty);
        int  (*write_room)(struct tty_struct *tty);
        int  (*chars_in_buffer)(struct tty_struct *tty);
-       int  (*ioctl)(struct tty_struct *tty, struct file * file,
+       int  (*ioctl)(struct tty_struct *tty,
                    unsigned int cmd, unsigned long arg);
-       long (*compat_ioctl)(struct tty_struct *tty, struct file * file,
+       long (*compat_ioctl)(struct tty_struct *tty,
                             unsigned int cmd, unsigned long arg);
        void (*set_termios)(struct tty_struct *tty, struct ktermios * old);
        void (*throttle)(struct tty_struct * tty);
index 980ccb66e1b4b662779953fdf7064c5d1ca4f469..59ba38bc400f43d3e87c1502395cef9a54e5811c 100644 (file)
@@ -123,7 +123,7 @@ void ircomm_tty_check_modem_status(struct ircomm_tty_cb *self);
 extern int ircomm_tty_tiocmget(struct tty_struct *tty);
 extern int ircomm_tty_tiocmset(struct tty_struct *tty,
                               unsigned int set, unsigned int clear);
-extern int ircomm_tty_ioctl(struct tty_struct *tty, struct file *file, 
+extern int ircomm_tty_ioctl(struct tty_struct *tty, 
                            unsigned int cmd, unsigned long arg);
 extern void ircomm_tty_set_termios(struct tty_struct *tty, 
                                   struct ktermios *old_termios);
index 8e78e7447726a11cd891b020a808fd3a7ba991cb..b1805ff954159c1dcc4d33248ff89864614430a7 100644 (file)
@@ -830,7 +830,7 @@ static int rfcomm_tty_write_room(struct tty_struct *tty)
        return room;
 }
 
-static int rfcomm_tty_ioctl(struct tty_struct *tty, struct file *filp, unsigned int cmd, unsigned long arg)
+static int rfcomm_tty_ioctl(struct tty_struct *tty, unsigned int cmd, unsigned long arg)
 {
        BT_DBG("tty %p cmd 0x%02x", tty, cmd);
 
index 5e0e718c930a9f94dbe4e13e656ac187283d8cf2..77c5e6499f8fe133ace935f2e90c7bb265ed248b 100644 (file)
@@ -365,12 +365,12 @@ static int ircomm_tty_set_serial_info(struct ircomm_tty_cb *self,
 }
 
 /*
- * Function ircomm_tty_ioctl (tty, file, cmd, arg)
+ * Function ircomm_tty_ioctl (tty, cmd, arg)
  *
  *
  *
  */
-int ircomm_tty_ioctl(struct tty_struct *tty, struct file *file,
+int ircomm_tty_ioctl(struct tty_struct *tty,
                     unsigned int cmd, unsigned long arg)
 {
        struct ircomm_tty_cb *self = (struct ircomm_tty_cb *) tty->driver_data;