XHCI: Handle fragmented transfers failing to submit the next fragment.
Previously they would just get "lost" and never signal completion. (Considering how rare fragmented transfers are, this may not fix any real problems.)
This commit is contained in:
parent
6711786ccc
commit
7c97a7846f
@ -2986,13 +2986,16 @@ XHCI::FinishTransfers()
|
|||||||
FreeDescriptor(td);
|
FreeDescriptor(td);
|
||||||
|
|
||||||
// this transfer may still have data left
|
// this transfer may still have data left
|
||||||
|
bool finished = true;
|
||||||
transfer->AdvanceByFragment(actualLength);
|
transfer->AdvanceByFragment(actualLength);
|
||||||
if (completionCode == COMP_SUCCESS
|
if (completionCode == COMP_SUCCESS
|
||||||
&& transfer->FragmentLength() > 0) {
|
&& transfer->FragmentLength() > 0) {
|
||||||
TRACE("still %" B_PRIuSIZE " bytes left on transfer\n",
|
TRACE("still %" B_PRIuSIZE " bytes left on transfer\n",
|
||||||
transfer->FragmentLength());
|
transfer->FragmentLength());
|
||||||
SubmitTransfer(transfer);
|
callbackStatus = SubmitTransfer(transfer);
|
||||||
} else {
|
finished = (callbackStatus != B_OK);
|
||||||
|
}
|
||||||
|
if (finished) {
|
||||||
// The actualLength was already handled in AdvanceByFragment.
|
// The actualLength was already handled in AdvanceByFragment.
|
||||||
transfer->Finished(callbackStatus, 0);
|
transfer->Finished(callbackStatus, 0);
|
||||||
delete transfer;
|
delete transfer;
|
||||||
|
Loading…
Reference in New Issue
Block a user