When calculating the actual length for requests, we don't want to include the
8 byte request header. It was included in the case of outgoing request transfers before. In fact we always just want the length of the data phase, which for non-requests just happens to be the whole transfer. git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@26508 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
2415100444
commit
2fc7e292e5
@ -1089,11 +1089,10 @@ EHCI::FinishTransfers()
|
||||
transfer->data_descriptor,
|
||||
vector, vectorCount,
|
||||
&nextDataToggle);
|
||||
} else {
|
||||
} else if (transfer->data_descriptor) {
|
||||
// calculate transfered length
|
||||
actualLength = ReadActualLength(
|
||||
(ehci_qtd *)transfer->queue_head->element_log,
|
||||
&nextDataToggle);
|
||||
transfer->data_descriptor, &nextDataToggle);
|
||||
}
|
||||
|
||||
transfer->transfer->TransferPipe()->SetDataToggle(nextDataToggle);
|
||||
|
@ -1029,10 +1029,10 @@ OHCI::_FinishTransfers()
|
||||
actualLength = _ReadDescriptorChain(
|
||||
transfer->data_descriptor,
|
||||
vector, vectorCount);
|
||||
} else {
|
||||
} else if (transfer->data_descriptor) {
|
||||
// read the actual length that was sent
|
||||
actualLength = _ReadActualLength(
|
||||
transfer->first_descriptor);
|
||||
transfer->data_descriptor);
|
||||
}
|
||||
|
||||
if (transfer->transfer->IsFragmented()) {
|
||||
|
@ -1225,10 +1225,10 @@ UHCI::FinishTransfers()
|
||||
transfer->data_descriptor,
|
||||
vector, vectorCount,
|
||||
&lastDataToggle);
|
||||
} else {
|
||||
} else if (transfer->data_descriptor) {
|
||||
// read the actual length that was sent
|
||||
actualLength = ReadActualLength(
|
||||
transfer->first_descriptor, &lastDataToggle);
|
||||
transfer->data_descriptor, &lastDataToggle);
|
||||
}
|
||||
|
||||
transfer->transfer->TransferPipe()->SetDataToggle(lastDataToggle == 0);
|
||||
|
Loading…
x
Reference in New Issue
Block a user