From: Yasushi Asano <yasano@xxxxxxxxxxxxxx> According to 6.7.22 A-UUT "Device No Response" for connection timeout of USB OTG and EH automated compliance plan v1.2, the enumeration failure has to be detected within 30 seconds. However, the old and new enumeration schemes made a total of 16 attempts, and each attempt can take 5 seconds to timeout, so it failed with PET test. Modify it to reduce the number of attempts to 5 and pass PET test. in case of old_schene_first=N and use_both_schemes=Y attempt 3 * new scheme, then 2 * old scheme in case of old_schene_first=Y and use_both_schemes=Y attempt 2 * old scheme, then 3 * new scheme Before applying the patch. please see [2]-[1]. The PETtest fails during device enumeration procedure[3] because the device enumeration failure[4] can not be detected within 30 seconds of starting the test. [ 99.864751] *** Ready OK Test Start*** [ 102.806542] usb 1-1.1: new full-speed USB device number 7 using ehci-platform ...[1] [ 118.608538] usb 1-1.1: device descriptor read/64, error -110 [ 134.480542] usb 1-1.1: device descriptor read/64, error -110 [ 134.669542] usb 1-1.1: new full-speed USB device number 8 using ehci-platform [ 150.352537] usb 1-1.1: device descriptor read/64, error -110 ...[2] [ 152.071247] *** End of Test *** ...[3] [ 154.290867] usb 1-1-port1: unable to enumerate USB device ...[4] After applying this patch. please see [6]-[5]. device enumeration failure[6] is detected within 30 seconds after starting the PETtest. The test passed. [ 134.632165] *** Ready OK Test Start*** [ 137.880705] usb 1-1.1: new full-speed USB device number 11 using ehci-platform ..[5] [ 143.184698] usb 1-1.1: device descriptor read/64, error -110 [ 148.815699] usb 1-1.1: device descriptor read/64, error -110 [ 149.005691] usb 1-1.1: new full-speed USB device number 12 using ehci-platform [ 154.448695] usb 1-1.1: device descriptor read/64, error -110 [ 154.561696] usb 1-1.1: Invalid ep0 maxpacket: 0 [ 154.567354] usb 1-1-port1: attempt power cycle [ 156.445704] usb 1-1.1: new full-speed USB device number 13 using ehci-platform [ 161.745697] usb 1-1.1: device not accepting address 13, error -110 [ 161.827694] usb 1-1.1: new full-speed USB device number 14 using ehci-platform [ 167.377693] usb 1-1.1: device not accepting address 14, error -110 [ 167.395415] usb 1-1-port1: unable to enumerate USB device ..[6] [ 176.678418] *** End of Test *** ------ [7] https://www.usb.org/sites/default/files/otgeh_compliance_plan_1_2.pdf 6.7.22 A-UUT "Device No Response" for connection timeout 6.7.22.2 Test Procedure for A-UUT which does not support sessions 1. Start with cable still attached, PET applying 10 micro F capacitance and 10K Ohm pull-down resistance between VBUS and ground, data lines not pulled up. 2. Wait 1s. 3. PET connects using D+. 4. Display Message "Click OK when 'Device No Response' indication displayed on UUT". 5. If operator clicks OK before 30s elapses since VBUS went on, then UUT passes test. 6. If 30s elapses first, then UUT fails test. 7. PET leaves 10 micro F capacitance and 10K Ohm pull-down resistance across VBUS. 8. PET disconnects D+. 9. Wait 2s. to allow disconnection to be recognized. Reported-by: kernel test robot <rong.a.chen@xxxxxxxxx> Signed-off-by: Yasushi Asano <yasano@xxxxxxxxxxxxxx> --- drivers/usb/core/hub.c | 23 ++++------------------- 1 file changed, 4 insertions(+), 19 deletions(-) diff --git a/drivers/usb/core/hub.c b/drivers/usb/core/hub.c index 052d5ac..725e5b6 100644 --- a/drivers/usb/core/hub.c +++ b/drivers/usb/core/hub.c @@ -2706,7 +2706,6 @@ static unsigned hub_is_wusb(struct usb_hub *hub) #define PORT_RESET_TRIES 5 -#define SET_ADDRESS_TRIES 2 #define GET_DESCRIPTOR_TRIES 2 #define SET_CONFIG_TRIES (2 * (use_both_schemes + 1)) #define USE_NEW_SCHEME(i, scheme) ((i) / 2 == (int)(scheme)) @@ -4539,7 +4538,7 @@ hub_port_init(struct usb_hub *hub, struct usb_device *udev, int port1, struct usb_device *hdev = hub->hdev; struct usb_hcd *hcd = bus_to_hcd(hdev->bus); struct usb_port *port_dev = hub->ports[port1 - 1]; - int retries, operations, retval, i; + int retries, retval, i; unsigned delay = HUB_SHORT_RESET_TIME; enum usb_device_speed oldspeed = udev->speed; const char *speed; @@ -4684,7 +4683,7 @@ hub_port_init(struct usb_hub *hub, struct usb_device *udev, int port1, * 255 is for WUSB devices, we actually need to use * 512 (WUSB1.0[4.8.1]). */ - for (operations = 0; operations < 3; ++operations) { + if (!((retry_counter % 2 != 0) && (retries != 0))) { buf->bMaxPacketSize0 = 0; r = usb_control_msg(udev, usb_rcvaddr0pipe(), USB_REQ_GET_DESCRIPTOR, USB_DIR_IN, @@ -4704,16 +4703,6 @@ hub_port_init(struct usb_hub *hub, struct usb_device *udev, int port1, r = -EPROTO; break; } - /* - * Some devices time out if they are powered on - * when already connected. They need a second - * reset. But only on the first attempt, - * lest we get into a time out/reset loop - */ - if (r == 0 || (r == -ETIMEDOUT && - retries == 0 && - udev->speed > USB_SPEED_FULL)) - break; } udev->descriptor.bMaxPacketSize0 = buf->bMaxPacketSize0; @@ -4744,12 +4733,8 @@ hub_port_init(struct usb_hub *hub, struct usb_device *udev, int port1, * authorization will assign the final address. */ if (udev->wusb == 0) { - for (operations = 0; operations < SET_ADDRESS_TRIES; ++operations) { - retval = hub_set_address(udev, devnum); - if (retval >= 0) - break; - msleep(200); - } + retval = hub_set_address(udev, devnum); + msleep(200); if (retval < 0) { if (retval != -ENODEV) dev_err(&udev->dev, "device not accepting address %d, error %d\n", -- 2.7.4