.png)
Я подключаю свою плату разработки ARM64 с портом USB, настроенным как периферийное устройство, и необходимыми драйверами для гаджета USB Ethernet к моему хост-компьютеру Ubuntu 20.04.1. Я подключаю свою плату к хост-компьютеру с помощью кабеля USB Male-Male. После этого ifconfig -a показывает мне интерфейс 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
когда я отключаю кабель и подключаю его снова, ifconfig -a интерфейс имеет новое имя:
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
Когда я настраиваю интерфейс (ifconfig), подключение к плате, кажется, происходит намного быстрее, когда имя интерфейса usb0. На плате имя интерфейса также usb0, и отключение и повторное подключение ничего не меняет на плате. dmesg показывает мне следующий вывод:
[ 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
Почему интерфейс переименован и как избежать такого поведения?
РЕДАКТИРОВАТЬ Я выяснил, что удаление драйвера cdc_ether (sudo rmmod cdc_ether) перед повторным подключением кабеля решает проблему. Но я думаю, что это не очень красивое решение, и я хотел бы понять, почему он переименован и почему это влияет на производительность.
решение1
Попробуйте удалить устройство и создать этот файл.
/etc/systemd/network/10-usb0.link
со следующим содержанием
[Match]
Driver=cdc_ether
[Link]
Name=usb0
Пусть udev заново прочитает правила
sudo udevadm control -R