Re: usb composition without class

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

 



On Thu, Jun 20, 2024 at 08:32:39AM +0200, Giacinto Cifelli wrote:
> On Thu, Jun 20, 2024 at 8:06 AM Greg KH <gregkh@xxxxxxxxxxxxxxxxxxx> wrote:
> > On Thu, Jun 20, 2024 at 07:58:13AM +0200, Giacinto Cifelli wrote:
> > > greetings,
> > >
> > > question:
> > >
> > > on a system (yocto), I have a usb composition that doesn't assign the
> > > class for the interfaces:
> > >     |__ Port 3: Dev 3, If 10, Class=, Driver=cdc_mbim, 480M
> > >     |__ Port 3: Dev 3, If 8, Class=, Driver=cdc_acm, 480M
> > >     |__ Port 3: Dev 3, If 6, Class=, Driver=cdc_acm, 480M
> > >     |__ Port 3: Dev 3, If 4, Class=, Driver=cdc_acm, 480M
> > >     |__ Port 3: Dev 3, If 2, Class=, Driver=cdc_acm, 480M
> > >     |__ Port 3: Dev 3, If 11, Class=, Driver=cdc_mbim, 480M
> > >     |__ Port 3: Dev 3, If 0, Class=, Driver=cdc_acm, 480M
> > >     |__ Port 3: Dev 3, If 9, Class=, Driver=cdc_acm, 480M
> > >     |__ Port 3: Dev 3, If 7, Class=, Driver=cdc_acm, 480M
> > >     |__ Port 3: Dev 3, If 5, Class=, Driver=cdc_acm, 480M
> > >     |__ Port 3: Dev 3, If 3, Class=, Driver=cdc_acm, 480M
> > >     |__ Port 3: Dev 3, If 1, Class=, Driver=cdc_acm, 480M
> > > Kernel: Linux version 6.1.35 (oe-user@oe-host) (x86_64-poky-linux-gcc
> > > (GCC) 11.4.0, GNU ld (GNU Binutils) 2.38.20220708) #1 SMP
> > > PREEMPT_DYNAMIC Thu Jun 22 18:03:13 UTC 2023
> > >
> > > instead of (arch):
> > >     |__ Port 004: Dev 004, If 0, Class=Communications, Driver=cdc_acm, 5000M
> > >     |__ Port 004: Dev 004, If 1, Class=CDC Data, Driver=cdc_acm, 5000M
> > >     |__ Port 004: Dev 004, If 2, Class=Communications, Driver=cdc_acm, 5000M
> > >     |__ Port 004: Dev 004, If 3, Class=CDC Data, Driver=cdc_acm, 5000M
> > >     |__ Port 004: Dev 004, If 4, Class=Communications, Driver=cdc_acm, 5000M
> > >     |__ Port 004: Dev 004, If 5, Class=CDC Data, Driver=cdc_acm, 5000M
> > >     |__ Port 004: Dev 004, If 6, Class=Communications, Driver=cdc_acm, 5000M
> > >     |__ Port 004: Dev 004, If 7, Class=CDC Data, Driver=cdc_acm, 5000M
> > >     |__ Port 004: Dev 004, If 8, Class=Communications, Driver=cdc_acm, 5000M
> > >     |__ Port 004: Dev 004, If 9, Class=CDC Data, Driver=cdc_acm, 5000M
> > >     |__ Port 004: Dev 004, If 10, Class=Communications, Driver=cdc_mbim, 5000M
> > >     |__ Port 004: Dev 004, If 11, Class=CDC Data, Driver=cdc_mbim, 5000M
> > > Kernel: Linux 6.6.34-1-lts #1 SMP PREEMPT_DYNAMIC Sun, 16 Jun 2024
> > > 14:45:31 +0000 x86_64 GNU/Linux
> > >
> > > This lack of class creates too many /dev/ttyACMx ports, and
> > > ModemManager tries to access them all, perhaps also blocking the
> > > device, and the whole system doesn't work.
> > >
> > > For completeness, the device is:
> > >     Bus 002 Device 004: ID 1e2d:0065 Gemalto M2M GmbH LTE Modem
> > > which is supported without any customs in the cdc-acm and cdc_mbim drivers.
> > >
> > > I spotted only two options not compiled-in in the yocto .config
> > > (compared with the arch one), but I strongly doubt this is related:
> > >     CONFIG_USB_G_MULTI
> > >     CONFIG_USB_G_MULTI_CDC
> > >
> > > Would you know why the class is not assigned?
> >
> > This is just a userspace issue, right?
> 
> I think the class is assigned by the kernel/driver.
> 
> > Or are you saying that somehow
> > the same device plugged into two different systems works differently?
> 
> correct: the same device works differently in the two systems...  in
> the sense of the class not assigned.

It's not that it is not assigned, it's that something isn't figuring it
out properly.

Can you provide the output of 'lsusb -v -d 1e2d:0065' for both systems?

> The device boots in the same way, the difference is not in the device.

True, but this type of device has had a lot of quirks added to it for
the cdc_ether driver for other ones by this vendor, but not for this
specific device from what I can tell.  So perhaps we got it right in
newer kernels, but not older ones?

thanks,

greg k-h




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

  Powered by Linux