Commit ce039bd4 authored by Johan Hovold's avatar Johan Hovold

USB: serial: mos7840: drop paranoid port checks

Drop the paranoid port structure sanity checks which are confusing at
best.

The driver data port pointer is set at port probe and never cleared,
while USB serial core sets the tty driver data at install and won't call
any driver functions with a NULL port pointer.
Reviewed-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: default avatarJohan Hovold <johan@kernel.org>
parent 3ec9fb6f
...@@ -446,21 +446,6 @@ static void mos7840_led_activity(struct usb_serial_port *port) ...@@ -446,21 +446,6 @@ static void mos7840_led_activity(struct usb_serial_port *port)
jiffies + msecs_to_jiffies(LED_ON_MS)); jiffies + msecs_to_jiffies(LED_ON_MS));
} }
static int mos7840_port_paranoia_check(struct usb_serial_port *port,
const char *function)
{
if (!port) {
pr_debug("%s - port == NULL\n", function);
return -1;
}
if (!port->serial) {
pr_debug("%s - port->serial == NULL\n", function);
return -1;
}
return 0;
}
/* Inline functions to check the sanity of a pointer that is passed to us */ /* Inline functions to check the sanity of a pointer that is passed to us */
static int mos7840_serial_paranoia_check(struct usb_serial *serial, static int mos7840_serial_paranoia_check(struct usb_serial *serial,
const char *function) const char *function)
...@@ -482,7 +467,6 @@ static struct usb_serial *mos7840_get_usb_serial(struct usb_serial_port *port, ...@@ -482,7 +467,6 @@ static struct usb_serial *mos7840_get_usb_serial(struct usb_serial_port *port,
{ {
/* if no port was specified, or it fails a paranoia check */ /* if no port was specified, or it fails a paranoia check */
if (!port || if (!port ||
mos7840_port_paranoia_check(port, function) ||
mos7840_serial_paranoia_check(port->serial, function)) { mos7840_serial_paranoia_check(port->serial, function)) {
/* then say that we don't have a valid usb_serial thing, /* then say that we don't have a valid usb_serial thing,
* which will end up genrating -ENODEV return values */ * which will end up genrating -ENODEV return values */
...@@ -501,10 +485,10 @@ static struct usb_serial *mos7840_get_usb_serial(struct usb_serial_port *port, ...@@ -501,10 +485,10 @@ static struct usb_serial *mos7840_get_usb_serial(struct usb_serial_port *port,
static void mos7840_bulk_in_callback(struct urb *urb) static void mos7840_bulk_in_callback(struct urb *urb)
{ {
struct moschip_port *mos7840_port = urb->context; struct moschip_port *mos7840_port = urb->context;
struct usb_serial_port *port = mos7840_port->port;
int retval; int retval;
unsigned char *data; unsigned char *data;
struct usb_serial *serial; struct usb_serial *serial;
struct usb_serial_port *port;
int status = urb->status; int status = urb->status;
if (status) { if (status) {
...@@ -513,12 +497,6 @@ static void mos7840_bulk_in_callback(struct urb *urb) ...@@ -513,12 +497,6 @@ static void mos7840_bulk_in_callback(struct urb *urb)
return; return;
} }
port = mos7840_port->port;
if (mos7840_port_paranoia_check(port, __func__)) {
mos7840_port->read_urb_busy = false;
return;
}
serial = mos7840_get_usb_serial(port, __func__); serial = mos7840_get_usb_serial(port, __func__);
if (!serial) { if (!serial) {
mos7840_port->read_urb_busy = false; mos7840_port->read_urb_busy = false;
...@@ -562,14 +540,12 @@ static void mos7840_bulk_in_callback(struct urb *urb) ...@@ -562,14 +540,12 @@ static void mos7840_bulk_in_callback(struct urb *urb)
static void mos7840_bulk_out_data_callback(struct urb *urb) static void mos7840_bulk_out_data_callback(struct urb *urb)
{ {
struct moschip_port *mos7840_port; struct moschip_port *mos7840_port = urb->context;
struct usb_serial_port *port; struct usb_serial_port *port = mos7840_port->port;
int status = urb->status; int status = urb->status;
unsigned long flags; unsigned long flags;
int i; int i;
mos7840_port = urb->context;
port = mos7840_port->port;
spin_lock_irqsave(&mos7840_port->pool_lock, flags); spin_lock_irqsave(&mos7840_port->pool_lock, flags);
for (i = 0; i < NUM_URBS; i++) { for (i = 0; i < NUM_URBS; i++) {
if (urb == mos7840_port->write_urb_pool[i]) { if (urb == mos7840_port->write_urb_pool[i]) {
...@@ -584,9 +560,6 @@ static void mos7840_bulk_out_data_callback(struct urb *urb) ...@@ -584,9 +560,6 @@ static void mos7840_bulk_out_data_callback(struct urb *urb)
return; return;
} }
if (mos7840_port_paranoia_check(port, __func__))
return;
if (mos7840_port->open) if (mos7840_port->open)
tty_port_tty_wakeup(&port->port); tty_port_tty_wakeup(&port->port);
...@@ -605,19 +578,14 @@ static void mos7840_bulk_out_data_callback(struct urb *urb) ...@@ -605,19 +578,14 @@ static void mos7840_bulk_out_data_callback(struct urb *urb)
static int mos7840_open(struct tty_struct *tty, struct usb_serial_port *port) static int mos7840_open(struct tty_struct *tty, struct usb_serial_port *port)
{ {
struct usb_serial *serial = port->serial;
int response; int response;
int j; int j;
struct usb_serial *serial;
struct urb *urb; struct urb *urb;
__u16 Data; __u16 Data;
int status; int status;
struct moschip_port *mos7840_port; struct moschip_port *mos7840_port;
if (mos7840_port_paranoia_check(port, __func__))
return -ENODEV;
serial = port->serial;
if (mos7840_serial_paranoia_check(serial, __func__)) if (mos7840_serial_paranoia_check(serial, __func__))
return -ENODEV; return -ENODEV;
...@@ -850,9 +818,6 @@ static int mos7840_chars_in_buffer(struct tty_struct *tty) ...@@ -850,9 +818,6 @@ static int mos7840_chars_in_buffer(struct tty_struct *tty)
unsigned long flags; unsigned long flags;
struct moschip_port *mos7840_port; struct moschip_port *mos7840_port;
if (mos7840_port_paranoia_check(port, __func__))
return 0;
mos7840_port = mos7840_get_port_private(port); mos7840_port = mos7840_get_port_private(port);
if (mos7840_port == NULL) if (mos7840_port == NULL)
return 0; return 0;
...@@ -882,9 +847,6 @@ static void mos7840_close(struct usb_serial_port *port) ...@@ -882,9 +847,6 @@ static void mos7840_close(struct usb_serial_port *port)
int j; int j;
__u16 Data; __u16 Data;
if (mos7840_port_paranoia_check(port, __func__))
return;
serial = mos7840_get_usb_serial(port, __func__); serial = mos7840_get_usb_serial(port, __func__);
if (!serial) if (!serial)
return; return;
...@@ -927,9 +889,6 @@ static void mos7840_break(struct tty_struct *tty, int break_state) ...@@ -927,9 +889,6 @@ static void mos7840_break(struct tty_struct *tty, int break_state)
struct usb_serial *serial; struct usb_serial *serial;
struct moschip_port *mos7840_port; struct moschip_port *mos7840_port;
if (mos7840_port_paranoia_check(port, __func__))
return;
serial = mos7840_get_usb_serial(port, __func__); serial = mos7840_get_usb_serial(port, __func__);
if (!serial) if (!serial)
return; return;
...@@ -967,9 +926,6 @@ static int mos7840_write_room(struct tty_struct *tty) ...@@ -967,9 +926,6 @@ static int mos7840_write_room(struct tty_struct *tty)
unsigned long flags; unsigned long flags;
struct moschip_port *mos7840_port; struct moschip_port *mos7840_port;
if (mos7840_port_paranoia_check(port, __func__))
return -1;
mos7840_port = mos7840_get_port_private(port); mos7840_port = mos7840_get_port_private(port);
if (mos7840_port == NULL) if (mos7840_port == NULL)
return -1; return -1;
...@@ -998,6 +954,7 @@ static int mos7840_write_room(struct tty_struct *tty) ...@@ -998,6 +954,7 @@ static int mos7840_write_room(struct tty_struct *tty)
static int mos7840_write(struct tty_struct *tty, struct usb_serial_port *port, static int mos7840_write(struct tty_struct *tty, struct usb_serial_port *port,
const unsigned char *data, int count) const unsigned char *data, int count)
{ {
struct usb_serial *serial = port->serial;
int status; int status;
int i; int i;
int bytes_sent = 0; int bytes_sent = 0;
...@@ -1005,15 +962,10 @@ static int mos7840_write(struct tty_struct *tty, struct usb_serial_port *port, ...@@ -1005,15 +962,10 @@ static int mos7840_write(struct tty_struct *tty, struct usb_serial_port *port,
unsigned long flags; unsigned long flags;
struct moschip_port *mos7840_port; struct moschip_port *mos7840_port;
struct usb_serial *serial;
struct urb *urb; struct urb *urb;
/* __u16 Data; */ /* __u16 Data; */
const unsigned char *current_position = data; const unsigned char *current_position = data;
if (mos7840_port_paranoia_check(port, __func__))
return -1;
serial = port->serial;
if (mos7840_serial_paranoia_check(serial, __func__)) if (mos7840_serial_paranoia_check(serial, __func__))
return -1; return -1;
...@@ -1104,9 +1056,6 @@ static void mos7840_throttle(struct tty_struct *tty) ...@@ -1104,9 +1056,6 @@ static void mos7840_throttle(struct tty_struct *tty)
struct moschip_port *mos7840_port; struct moschip_port *mos7840_port;
int status; int status;
if (mos7840_port_paranoia_check(port, __func__))
return;
mos7840_port = mos7840_get_port_private(port); mos7840_port = mos7840_get_port_private(port);
if (mos7840_port == NULL) if (mos7840_port == NULL)
...@@ -1146,9 +1095,6 @@ static void mos7840_unthrottle(struct tty_struct *tty) ...@@ -1146,9 +1095,6 @@ static void mos7840_unthrottle(struct tty_struct *tty)
int status; int status;
struct moschip_port *mos7840_port = mos7840_get_port_private(port); struct moschip_port *mos7840_port = mos7840_get_port_private(port);
if (mos7840_port_paranoia_check(port, __func__))
return;
if (mos7840_port == NULL) if (mos7840_port == NULL)
return; return;
...@@ -1296,18 +1242,11 @@ static int mos7840_calc_baud_rate_divisor(struct usb_serial_port *port, ...@@ -1296,18 +1242,11 @@ static int mos7840_calc_baud_rate_divisor(struct usb_serial_port *port,
static int mos7840_send_cmd_write_baud_rate(struct moschip_port *mos7840_port, static int mos7840_send_cmd_write_baud_rate(struct moschip_port *mos7840_port,
int baudRate) int baudRate)
{ {
struct usb_serial_port *port = mos7840_port->port;
int divisor = 0; int divisor = 0;
int status; int status;
__u16 Data; __u16 Data;
__u16 clk_sel_val; __u16 clk_sel_val;
struct usb_serial_port *port;
if (mos7840_port == NULL)
return -1;
port = mos7840_port->port;
if (mos7840_port_paranoia_check(port, __func__))
return -1;
if (mos7840_serial_paranoia_check(port->serial, __func__)) if (mos7840_serial_paranoia_check(port->serial, __func__))
return -1; return -1;
...@@ -1399,6 +1338,7 @@ static int mos7840_send_cmd_write_baud_rate(struct moschip_port *mos7840_port, ...@@ -1399,6 +1338,7 @@ static int mos7840_send_cmd_write_baud_rate(struct moschip_port *mos7840_port,
static void mos7840_change_port_settings(struct tty_struct *tty, static void mos7840_change_port_settings(struct tty_struct *tty,
struct moschip_port *mos7840_port, struct ktermios *old_termios) struct moschip_port *mos7840_port, struct ktermios *old_termios)
{ {
struct usb_serial_port *port = mos7840_port->port;
int baud; int baud;
unsigned cflag; unsigned cflag;
__u8 lData; __u8 lData;
...@@ -1406,15 +1346,6 @@ static void mos7840_change_port_settings(struct tty_struct *tty, ...@@ -1406,15 +1346,6 @@ static void mos7840_change_port_settings(struct tty_struct *tty,
__u8 lStop; __u8 lStop;
int status; int status;
__u16 Data; __u16 Data;
struct usb_serial_port *port;
if (mos7840_port == NULL)
return;
port = mos7840_port->port;
if (mos7840_port_paranoia_check(port, __func__))
return;
if (mos7840_serial_paranoia_check(port->serial, __func__)) if (mos7840_serial_paranoia_check(port->serial, __func__))
return; return;
...@@ -1557,14 +1488,10 @@ static void mos7840_set_termios(struct tty_struct *tty, ...@@ -1557,14 +1488,10 @@ static void mos7840_set_termios(struct tty_struct *tty,
struct usb_serial_port *port, struct usb_serial_port *port,
struct ktermios *old_termios) struct ktermios *old_termios)
{ {
struct usb_serial *serial = port->serial;
int status; int status;
struct usb_serial *serial;
struct moschip_port *mos7840_port; struct moschip_port *mos7840_port;
if (mos7840_port_paranoia_check(port, __func__))
return;
serial = port->serial;
if (mos7840_serial_paranoia_check(serial, __func__)) if (mos7840_serial_paranoia_check(serial, __func__))
return; return;
...@@ -1659,9 +1586,6 @@ static int mos7840_ioctl(struct tty_struct *tty, ...@@ -1659,9 +1586,6 @@ static int mos7840_ioctl(struct tty_struct *tty,
void __user *argp = (void __user *)arg; void __user *argp = (void __user *)arg;
struct moschip_port *mos7840_port; struct moschip_port *mos7840_port;
if (mos7840_port_paranoia_check(port, __func__))
return -1;
mos7840_port = mos7840_get_port_private(port); mos7840_port = mos7840_get_port_private(port);
if (mos7840_port == NULL) if (mos7840_port == NULL)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment