Hi Alan, On Fri, Aug 04, 2023, Alan Stern wrote: > An outstanding syzbot bug report has been traced to a race between the > routine that reads in the device descriptor for a device being > reinitialized and the routine that writes the descriptors to a sysfs > attribute file. The problem is that reinitializing a device, like > initializing it for the first time, stores the device descriptor > directly in the usb_device structure, where it may be accessed > concurrently as part of sending the descriptors to the sysfs reader. > > This three-part series fixes the problem: > > The first patch unites the code paths responsible for first > reading the device descriptor in hub.c's old scheme and new > scheme, so that neither of them will call > usb_get_device_descriptor(). > > The second patch changes usb_get_device_descriptor(), making > it return the descriptor in a dynamically allocated buffer > rather than storing it directly in the device structure. > > The third patch changes hub_port_init(), adding a new argument > that specifies a buffer in which to store the device > descriptor for devices being reinitialized. > > As a result of these changes, the copy of the device descriptor stored > in the usb_device structure will never be overwritten once it has been > initialized. This eliminates the data race causing the bug identified > by syzbot. > > It would be nice at some point to make a similar change to the code > that reads the device's BOS descriptor; reinitialization should not > overwrite its existing data either. This series doesn't attempt to do > that, but it would be a good thing to do. > Testing from Greg's usb-next branch, this series causes problem with device enumeration: [ 31.650759] usb 2-1: new SuperSpeed Plus Gen 2x1 USB device number 2 using xhci_hcd [ 31.663107] usb 2-1: device descriptor read/8, error -71 [ 31.952697] usb 2-1: new SuperSpeed Plus Gen 2x1 USB device number 3 using xhci_hcd [ 31.965122] usb 2-1: device descriptor read/8, error -71 [ 32.080991] usb usb2-port1: attempt power cycle [ 34.826893] usb 2-1: new SuperSpeed Plus Gen 2x1 USB device number 5 using xhci_hcd [ 34.839241] usb 2-1: device descriptor read/8, error -71 [ 35.129908] usb 2-1: new SuperSpeed Plus Gen 2x1 USB device number 6 using xhci_hcd [ 35.142264] usb 2-1: device descriptor read/8, error -71 [ 35.257155] usb usb2-port1: attempt power cycle [ 37.258922] usb 1-1: new high-speed USB device number 5 using xhci_hcd [ 38.115053] usb 2-1: new SuperSpeed Plus Gen 2x1 USB device number 8 using xhci_hcd [ 38.127407] usb 2-1: device descriptor read/8, error -71 [ 38.417066] usb 2-1: new SuperSpeed Plus Gen 2x1 USB device number 9 using xhci_hcd [ 38.429428] usb 2-1: device descriptor read/8, error -71 [ 38.545315] usb usb2-port1: attempt power cycle [ 43.347312] usb 2-2: new SuperSpeed Plus Gen 2x1 USB device number 11 using xhci_hcd [ 43.359659] usb 2-2: device descriptor read/8, error -71 [ 43.649323] usb 2-2: new SuperSpeed Plus Gen 2x1 USB device number 12 using xhci_hcd [ 43.661681] usb 2-2: device descriptor read/8, error -71 [ 43.777566] usb usb2-port2: attempt power cycle I was testing with our host along with other common vendor hosts with a few 3.x devices. Reverting this series resolves the issue. I didn't do extensive tests for various speeds or debug it. I just want to notify this first perhaps you can figure out the issue right away. I can look into it and provide more info later this week. If you want to print any debug, let me know and I can provide later this week. Thanks, Thinh