[PATCH v3] USB: hub.c: decrease the number of attempts of enumeration scheme

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



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




[Index of Archives]     [Linux Media]     [Linux Input]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [Old Linux USB Devel Archive]

  Powered by Linux