[Description]:
authorvanjeff <vanjeff@de2fecce-e211-0410-80a6-f3fac2684e05>
Tue, 24 Jun 2008 08:13:58 +0000 (08:13 +0000)
committervanjeff <vanjeff@de2fecce-e211-0410-80a6-f3fac2684e05>
Tue, 24 Jun 2008 08:13:58 +0000 (08:13 +0000)
 The Usb1.1 flash disk will hang for Bootable Image Support Test -> Bloack IO protocol Test -> Reset_Func.
[Solution]:
 Add a stall 20ms after set address when port reset for Usb hub.
[Impaction]:
 UsbBusDxe.
[Reference Info]:
 EDK tracker 1120 - USB flash disk hang or fail in the new SCT blockIo test.

git-svn-id: https://edk2.tianocore.org/svn/edk2/trunk@5365 de2fecce-e211-0410-80a6-f3fac2684e05

edk2/MdeModulePkg/Bus/Usb/UsbBusDxe/UsbBus.c

index 332871a..5c4d402 100644 (file)
@@ -840,7 +840,8 @@ UsbIoPortReset (
   Address       = Dev->Address;\r
   Dev->Address  = 0;\r
   Status        = UsbSetAddress (Dev, Address);\r
-\r
+  Dev->Address  = Address;\r
+  \r
   if (EFI_ERROR (Status)) {\r
     DEBUG (( EFI_D_ERROR, "UsbIoPortReset: failed to set address for device %d - %r\n",\r
                 Address, Status));\r
@@ -848,8 +849,10 @@ UsbIoPortReset (
     goto ON_EXIT;\r
   }\r
 \r
-  Dev->Address  = Address;\r
+  gBS->Stall (USB_SET_DEVICE_ADDRESS_STALL);\r
 \r
+  DEBUG (( EFI_D_INFO, "UsbIoPortReset: device is now ADDRESSED at %d\n", Address));\r
+  \r
   //\r
   // Reset the current active configure, after this device\r
   // is in CONFIGURED state.\r