提交 cf545093 编写于 作者: A Alan Cox 提交者: Linus Torvalds

tty: Fix leak in ti-usb

If the ti-usb adapter returns an zero data length frame (which happens)
then we leak a kref.  Found by Christoph Mair <christoph.mair@gmail.com>
who proposed a patch.  The patch here is different as Christoph's patch
didn't work for the case where tty = NULL and data arrived but Christoph
did all the hard work chasing it down.
Signed-off-by: NAlan Cox <alan@linux.intel.com>
Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
上级 7a9a65ce
...@@ -1215,20 +1215,22 @@ static void ti_bulk_in_callback(struct urb *urb) ...@@ -1215,20 +1215,22 @@ static void ti_bulk_in_callback(struct urb *urb)
} }
tty = tty_port_tty_get(&port->port); tty = tty_port_tty_get(&port->port);
if (tty && urb->actual_length) { if (tty) {
usb_serial_debug_data(debug, dev, __func__, if (urb->actual_length) {
urb->actual_length, urb->transfer_buffer); usb_serial_debug_data(debug, dev, __func__,
urb->actual_length, urb->transfer_buffer);
if (!tport->tp_is_open)
dbg("%s - port closed, dropping data", __func__); if (!tport->tp_is_open)
else dbg("%s - port closed, dropping data",
ti_recv(&urb->dev->dev, tty, __func__);
else
ti_recv(&urb->dev->dev, tty,
urb->transfer_buffer, urb->transfer_buffer,
urb->actual_length); urb->actual_length);
spin_lock(&tport->tp_lock);
spin_lock(&tport->tp_lock); tport->tp_icount.rx += urb->actual_length;
tport->tp_icount.rx += urb->actual_length; spin_unlock(&tport->tp_lock);
spin_unlock(&tport->tp_lock); }
tty_kref_put(tty); tty_kref_put(tty);
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册