On Thu, May 18, 2023 at 04:16:33PM +0200, Helge Deller wrote: > On 5/18/23 15:54, Alan Stern wrote: > > On Thu, May 18, 2023 at 09:34:24AM +0200, Helge Deller wrote: > > > I think this is an informational warning from the USB stack, > > > > It is not informational. It is a warning that the caller has a bug. > > I'm not a USB expert, so I searched for such bug reports, and it seems > people sometimes faced this warning with different USB devices. Yes. > > You can't fix a bug by changing the line that reports it from dev_WARN > > to printk! > > Of course this patch wasn't intended as "fix". > It was intended to see how the udlfb driver behaves in this situation, e.g. > if the driver then crashes afterwards. > > Furthermore, why does usb_submit_urb() prints this WARNING and then continues? > If it's a real bug, why doesn't it returns an error instead? > So, in principle I still think this warning is kind of informational, > which of course points to some kind of problem which should be fixed. Depending on the situation, the bug may or may not lead to an error. At the time the dev_WARN was added, we were less careful about these sorts of checks; I did not want to cause previously working devices to stop working by failing the URB submission. > > In this case it looks like dlfb_usb_probe() or one of the routines it > > calls is wrong; it assumes that an endpoint has the expected type > > without checking. More precisely, it thinks an endpoint is BULK when > > actually it is INTERRUPT. That's what needs to be fixed. > > Maybe usb_submit_urb() should return an error so that drivers can > react on it, instead of adding the same kind of checks to all drivers? Feel free to submit a patch doing this. But the checks should be added in any case; without them the drivers are simply wrong. Alan Stern