Commit 5326a4ee authored by Peter Hurley's avatar Peter Hurley Committed by Marcel Holtmann

Bluetooth: Force -EIO from tty read/write if .activate() fails

If rfcomm_dlc_open() fails, set tty into error state which returns
-EIO from reads and writes.
Signed-off-by: default avatarPeter Hurley <peter@hurleysoftware.com>
Tested-By: default avatarAlexander Holler <holler@ahsoftware.de>
Signed-off-by: default avatarMarcel Holtmann <marcel@holtmann.org>
parent fb856e50
...@@ -111,8 +111,12 @@ static void rfcomm_dev_destruct(struct tty_port *port) ...@@ -111,8 +111,12 @@ static void rfcomm_dev_destruct(struct tty_port *port)
static int rfcomm_dev_activate(struct tty_port *port, struct tty_struct *tty) static int rfcomm_dev_activate(struct tty_port *port, struct tty_struct *tty)
{ {
struct rfcomm_dev *dev = container_of(port, struct rfcomm_dev, port); struct rfcomm_dev *dev = container_of(port, struct rfcomm_dev, port);
int err;
return rfcomm_dlc_open(dev->dlc, &dev->src, &dev->dst, dev->channel); err = rfcomm_dlc_open(dev->dlc, &dev->src, &dev->dst, dev->channel);
if (err)
set_bit(TTY_IO_ERROR, &tty->flags);
return err;
} }
/* we block the open until the dlc->state becomes BT_CONNECTED */ /* we block the open until the dlc->state becomes BT_CONNECTED */
......
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