提交 5090ecea 编写于 作者: T Thomas Pugliese 提交者: Greg Kroah-Hartman

usb: wusbcore: don't mark WA_SEG_DTI_PENDING segs as done in urb_dequeue

Data for transfer segments in the WA_SEG_DTI_PENDING state is actively
being read by the driver.  Let the buffer read callback handle the
transfer cleanup since cleaning it up in wa_urb_dequeue will cause the
read callback to access invalid memory if the transfer is completed.
Signed-off-by: NThomas Pugliese <thomas.pugliese@gmail.com>
Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
上级 2a6da97f
...@@ -2005,6 +2005,16 @@ int wa_urb_dequeue(struct wahc *wa, struct urb *urb, int status) ...@@ -2005,6 +2005,16 @@ int wa_urb_dequeue(struct wahc *wa, struct urb *urb, int status)
case WA_SEG_DONE: case WA_SEG_DONE:
case WA_SEG_ERROR: case WA_SEG_ERROR:
case WA_SEG_ABORTED: case WA_SEG_ABORTED:
break;
/*
* The buf_in data for a segment in the
* WA_SEG_DTI_PENDING state is actively being read.
* Let wa_buf_in_cb handle it since it will be called
* and will increment xfer->segs_done. Cleaning up
* here could cause wa_buf_in_cb to access the xfer
* after it has been completed/freed.
*/
case WA_SEG_DTI_PENDING:
break; break;
/* /*
* In the states below, the HWA device already knows * In the states below, the HWA device already knows
...@@ -2015,7 +2025,6 @@ int wa_urb_dequeue(struct wahc *wa, struct urb *urb, int status) ...@@ -2015,7 +2025,6 @@ int wa_urb_dequeue(struct wahc *wa, struct urb *urb, int status)
*/ */
case WA_SEG_SUBMITTED: case WA_SEG_SUBMITTED:
case WA_SEG_PENDING: case WA_SEG_PENDING:
case WA_SEG_DTI_PENDING:
/* /*
* Check if the abort was successfully sent. This could * Check if the abort was successfully sent. This could
* be false if the HWA has been removed but we haven't * be false if the HWA has been removed but we haven't
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册