ifconfig mostra interface diferente após desconectar e reconectar o cabo USB (Ethernet sobre USB)

ifconfig mostra interface diferente após desconectar e reconectar o cabo USB (Ethernet sobre USB)

Estou conectando minha placa de desenvolvimento ARM64 com uma porta USB configurada como periférica e com os drivers necessários para o gadget Ethernet USB ao meu PC host Ubuntu 20.04.1. Estou conectando minha placa ao meu PC host com um cabo USB macho para macho. Depois disso, ifconfig -a me mostra uma interface usb0:

usb0: flags=4098<BROADCAST,MULTICAST>  mtu 1500
        ether ae:1f:07:23:57:06  txqueuelen 1000  (Ethernet)
        RX packets 0  bytes 0 (0.0 B)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 0  bytes 0 (0.0 B)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

quando eu desconecto o cabo e reconecto-o, ifconfig -a a interface tem um novo nome:

enx7ef758273481: flags=4098<BROADCAST,MULTICAST>  mtu 1500
        ether 7e:f7:58:27:34:81  txqueuelen 1000  (Ethernet)
        RX packets 0  bytes 0 (0.0 B)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 0  bytes 0 (0.0 B)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

Quando configuro a interface (ifconfig ) a conexão com a placa parece ser muito mais rápida quando o nome da interface é usb0. Na placa, o nome da interface também é usb0 e desconectar e reconectar não altera nada na placa. dmesg me mostra a seguinte saída:

[   89.145321] usb 1-5: new high-speed USB device number 2 using xhci_hcd
[   89.295266] usb 1-5: New USB device found, idVendor=0525, idProduct=a4a2, bcdDevice= 5.15
[   89.295269] usb 1-5: New USB device strings: Mfr=1, Product=2, SerialNumber=0
[   89.295270] usb 1-5: Product: RNDIS/Ethernet Gadget
[   89.295271] usb 1-5: Manufacturer: Linux 5.15.32+gfa6c3168595c with dwc3-gadget
[   89.310530] cdc_subset: probe of 1-5:1.0 failed with error -22
[   89.311814] cdc_subset 1-5:1.1 usb0: register 'cdc_subset' at usb-0000:00:14.0-5, Linux Device, ae:1f:07:23:57:06
[   89.311829] usbcore: registered new interface driver cdc_subset
[   89.311846] cdc_ether: probe of 1-5:1.0 failed with error -16
[   89.311868] usbcore: registered new interface driver cdc_ether
[  213.382913] usb 1-5: USB disconnect, device number 2
[  213.382990] cdc_subset 1-5:1.1 usb0: unregister 'cdc_subset' usb-0000:00:14.0-5, Linux Device
[  215.220424] usb 1-5: new high-speed USB device number 3 using xhci_hcd
[  215.370333] usb 1-5: New USB device found, idVendor=0525, idProduct=a4a2, bcdDevice= 5.15
[  215.370337] usb 1-5: New USB device strings: Mfr=1, Product=2, SerialNumber=0
[  215.370338] usb 1-5: Product: RNDIS/Ethernet Gadget
[  215.370338] usb 1-5: Manufacturer: Linux 5.15.32+gfa6c3168595c with dwc3-gadget
[  215.371653] cdc_subset: probe of 1-5:1.0 failed with error -22
[  215.372954] cdc_ether 1-5:1.0 usb0: register 'cdc_ether' at usb-0000:00:14.0-5, CDC Ethernet Device, 7e:f7:58:27:34:81
[  215.379101] cdc_ether 1-5:1.0 enx7ef758273481: renamed from usb0

Por que a interface foi renomeada e como posso evitar esse comportamento?

EDITAR Eu descobri que remover o driver cdc_ether (sudo rmmod cdc_ether) antes de reconectar o cabo resolve o problema. Mas acho que essa não é uma solução bonita e gostaria de entender por que ela foi renomeada e por que isso afeta o desempenho.

Responder1

Por favor, tente remover seu dispositivo e criar este arquivo

/etc/systemd/network/10-usb0.link

com o seguinte conteúdo

[Match]
Driver=cdc_ether 

[Link]
Name=usb0

Deixe o udev ler as regras novamente com

sudo udevadm control -R

fonte

informação relacionada