Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 81d5a672 authored by Johan Hovold's avatar Johan Hovold Committed by Greg Kroah-Hartman
Browse files

USB: opticon: fix abuse of interface data



Fix abuse of interface data which was used to signal device disconnect.

Use the usb_serial disconnect flag and mutex where appropriate.

Note that tiocmget does not need to check for disconnect as it does not
access the device.

Signed-off-by: default avatarJohan Hovold <jhovold@gmail.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 33f7a67e
Loading
Loading
Loading
Loading
+10 −5
Original line number Original line Diff line number Diff line
@@ -401,8 +401,6 @@ static int opticon_tiocmget(struct tty_struct *tty)
	int result = 0;
	int result = 0;


	dbg("%s - port %d", __func__, port->number);
	dbg("%s - port %d", __func__, port->number);
	if (!usb_get_intfdata(port->serial->interface))
		return -ENODEV;


	spin_lock_irqsave(&priv->lock, flags);
	spin_lock_irqsave(&priv->lock, flags);
	if (priv->rts)
	if (priv->rts)
@@ -419,13 +417,13 @@ static int opticon_tiocmset(struct tty_struct *tty,
			   unsigned int set, unsigned int clear)
			   unsigned int set, unsigned int clear)
{
{
	struct usb_serial_port *port = tty->driver_data;
	struct usb_serial_port *port = tty->driver_data;
	struct usb_serial *serial = port->serial;
	struct opticon_private *priv = usb_get_serial_data(port->serial);
	struct opticon_private *priv = usb_get_serial_data(port->serial);
	unsigned long flags;
	unsigned long flags;
	bool rts;
	bool rts;
	bool changed = false;
	bool changed = false;
	int ret;


	if (!usb_get_intfdata(port->serial->interface))
		return -ENODEV;
	/* We only support RTS so we only handle that */
	/* We only support RTS so we only handle that */
	spin_lock_irqsave(&priv->lock, flags);
	spin_lock_irqsave(&priv->lock, flags);


@@ -441,7 +439,14 @@ static int opticon_tiocmset(struct tty_struct *tty,
		return 0;
		return 0;


	/* Send the new RTS state to the connected device */
	/* Send the new RTS state to the connected device */
	return send_control_msg(port, CONTROL_RTS, !rts);
	mutex_lock(&serial->disc_mutex);
	if (!serial->disconnected)
		ret = send_control_msg(port, CONTROL_RTS, !rts);
	else
		ret = -ENODEV;
	mutex_unlock(&serial->disc_mutex);

	return ret;
}
}


static int get_serial_info(struct opticon_private *priv,
static int get_serial_info(struct opticon_private *priv,