.png)
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