mirror of https://github.com/acidanthera/audk.git
MdeModulePkg/Xhci: Fix TRT when data length is 0
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=3418 According to xhci spec, at USB packet level, a Control Transfer consists of multiple transactions partitioned into stages: a setup stage, an optional data stage, and a terminating status stage. If Data Stage does not exist, the Transfer Type flag(TRT) should be No Data Stage. So if data length equals to 0, TRT is set to 0. Cc: Jian J Wang <jian.j.wang@intel.com> Cc: Hao A Wu <hao.a.wu@intel.com> Cc: Ray Ni <ray.ni@intel.com> Signed-off-by: Wenyi Xie <xiewenyi2@huawei.com> Reviewed-by: Hao A Wu <hao.a.wu@intel.com>
This commit is contained in:
parent
b233eb1849
commit
b5379899b3
|
@ -298,10 +298,15 @@ XhcCreateTransferTrb (
|
|||
TrbStart->TrbCtrSetup.IOC = 1;
|
||||
TrbStart->TrbCtrSetup.IDT = 1;
|
||||
TrbStart->TrbCtrSetup.Type = TRB_TYPE_SETUP_STAGE;
|
||||
if (Urb->Ep.Direction == EfiUsbDataIn) {
|
||||
TrbStart->TrbCtrSetup.TRT = 3;
|
||||
} else if (Urb->Ep.Direction == EfiUsbDataOut) {
|
||||
TrbStart->TrbCtrSetup.TRT = 2;
|
||||
if (Urb->DataLen > 0) {
|
||||
if (Urb->Ep.Direction == EfiUsbDataIn) {
|
||||
TrbStart->TrbCtrSetup.TRT = 3;
|
||||
} else if (Urb->Ep.Direction == EfiUsbDataOut) {
|
||||
TrbStart->TrbCtrSetup.TRT = 2;
|
||||
} else {
|
||||
DEBUG ((DEBUG_ERROR, "XhcCreateTransferTrb: Direction sholud be IN or OUT when Data exists!\n"));
|
||||
ASSERT (FALSE);
|
||||
}
|
||||
} else {
|
||||
TrbStart->TrbCtrSetup.TRT = 0;
|
||||
}
|
||||
|
|
|
@ -291,10 +291,15 @@ XhcPeiCreateTransferTrb (
|
|||
TrbStart->TrbCtrSetup.IOC = 1;
|
||||
TrbStart->TrbCtrSetup.IDT = 1;
|
||||
TrbStart->TrbCtrSetup.Type = TRB_TYPE_SETUP_STAGE;
|
||||
if (Urb->Ep.Direction == EfiUsbDataIn) {
|
||||
TrbStart->TrbCtrSetup.TRT = 3;
|
||||
} else if (Urb->Ep.Direction == EfiUsbDataOut) {
|
||||
TrbStart->TrbCtrSetup.TRT = 2;
|
||||
if (Urb->DataLen > 0) {
|
||||
if (Urb->Ep.Direction == EfiUsbDataIn) {
|
||||
TrbStart->TrbCtrSetup.TRT = 3;
|
||||
} else if (Urb->Ep.Direction == EfiUsbDataOut) {
|
||||
TrbStart->TrbCtrSetup.TRT = 2;
|
||||
} else {
|
||||
DEBUG ((DEBUG_ERROR, "XhcPeiCreateTransferTrb: Direction sholud be IN or OUT when Data exists!\n"));
|
||||
ASSERT (FALSE);
|
||||
}
|
||||
} else {
|
||||
TrbStart->TrbCtrSetup.TRT = 0;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue