【Linux】解决两个USB设备VID/PID/序列号全一样无法区分的问题 (udev物理端口绑定)

1. 问题描述

最近在搞机器人开发,买了一个 IMU 和一个 RTK 模块。插到电脑上发现一件很崩溃的事:

这俩货用的 USB 转串口芯片一模一样,导致:

  • idVendor 一样

  • idProduct 一样

  • Serial Number 也一样(全是空或者默认值)

这就导致没法用常规的 ATTRS{idVendor} 或 ATTRS{serial} 来写 udev rules 固定设备名(比如 /dev/ttyimu)。每次重启或重插拔,/dev/ttyUSB0 和 /dev/ttyUSB1 就会随机互换,程序经常读错设备。

2. 解决方案

既然软件层面的 ID 无法区分,只能使用 物理端口绑定 (Physical Port Binding)

也就是说:通过识别设备插在电脑的哪个 USB 孔上,来给它命名。

注意 :这种方法的缺点是,一旦配置好,USB 线就不能乱换插孔,也不能随便加减 USB Hub,否则规则会失效。

3. 操作步骤

第一步:物理连接(定死位置)

先把设备插好,决定好它们以后就在这不动了。

  • 比如:IMU 插在扩展卡的上口 ,RTK 插在下口

  • 此时系统分配了 ttyUSB0 和 ttyUSB1。

第二步:查找物理路径 (KERNELS)

我们需要找到代表那个 USB 物理孔的唯一编码。

在终端分别执行:

bash 复制代码
# 查看 ttyUSB0 的物理路径信息
udevadm info -a -n /dev/ttyUSB0 | grep KERNELS

# 查看 ttyUSB1 的物理路径信息
udevadm info -a -n /dev/ttyUSB1 | grep KERNELS

输出里会有很多 KERNELS,找第三行左右、类似 1-2 或 3-1:1.0 这种格式的

你会发现两个设备的这个值是不一样的。

  • 假设 IMU (ttyUSB0) 查到的是:KERNELS=="3-1"

  • 假设 RTK (ttyUSB1) 查到的是:KERNELS=="3-2"

第三步:编写 udev 规则文件

新建或修改规则文件:

sudo nano /etc/udev/rules.d/99-usb-serial.rules

写入以下内容(把 KERNELS 换成你刚才查到的实际值):

bash 复制代码
# ==========================================================
# 解决双胞胎设备问题:ID和序列号均相同,通过物理路径(KERNELS)绑定
# 警告:插孔位置一旦改变,规则将失效!
# ==========================================================

# 1. IMU 模块 (物理位置:3-1)
ACTION=="add", SUBSYSTEM=="tty", KERNELS=="3-1", MODE="0777", GROUP="dialout", SYMLINK+="ttyimu"

# 2. RTK 模块 (物理位置:3-2)
ACTION=="add", SUBSYSTEM=="tty", KERNELS=="3-2", MODE="0777", GROUP="dialout", SYMLINK+="ttyrtk"
第四步:重新加载生效

保存文件后,执行以下命令重载规则:

bash 复制代码
sudo udevadm control --reload && sudo udevadm trigger

此时查看 /dev 下应该就有固定的软链接了:

bash 复制代码
ls -l /dev/ttyimu /dev/ttyrtk

4. 总结

  • 首选方案:如果有序列号 (ATTRS{serial}),优先用序列号区分,那样不怕换插孔。

  • 备选方案 :如果序列号一样,只能用本文的 KERNELS 方法,但要记住线不能乱动

相关推荐
_下雨天.1 小时前
LVS负载均衡
服务器·负载均衡·lvs
小成202303202654 小时前
Linux高级02
linux·开发语言
mounter6254 小时前
【硬核前沿】CXL 深度解析:重塑数据中心架构的“高速公路”,Linux 内核如何应对挑战?-- CXL 协议详解与 LSF/MM 最新动态
linux·服务器·网络·架构·kernel
++==4 小时前
Linux 进程间通信与线程同步技术详解:IPC 机制、线程 API、同步工具与经典同步问题
linux
特长腿特长5 小时前
centos、ubantu系列机的用户和用户组的结构是什么?具体怎么配置?用户组权限怎么使用?这篇文章持续更新,帮助你复习linux的基础知识
linux·运维·centos
zzzyyy5385 小时前
Linux环境变量
linux·运维·服务器
pluvium275 小时前
记对 xonsh shell 的使用, 脚本编写, 迁移及调优
linux·python·shell·xonsh
无级程序员5 小时前
centos7 安装 llvm-toolset-7-clang出错的问题解决
linux·centos
kebeiovo5 小时前
atomic原子操作实现无锁队列
服务器·c++
赛博云推-Twitter热门霸屏工具6 小时前
Twitter运营完整流程:从0到引流获客全流程拆解(2026)
运维·安全·自动化·媒体·twitter