我正在使用 Lubuntu 16.04.3 LTS 上的 HIDAPI 制作一个自定义 USB HID 设备和一个桌面应用程序。我们myapp
现在就叫它。
显然,如果我这样做$ ./myapp
,会libusb_open()
失败LIBUSB_ERROR_ACCESS
。 (在我的调试器中显示为-3
; 花了一段时间才弄清楚,因为枚举似乎没有很好地记录)
但是如果我这样做$ sudo ./myapp
了,它就会成功。
我真的不想myapp
拥有root权限,那么没有它们我怎么能和我的USB设备通话呢?
我希望在这里得到答案,但似乎在这一点上已经被放弃了。它说明了用户权限,但我似乎无法在我的系统上找到它。我想我可能会找到一个名为usb
或者libusb
我可以将自己添加到的组,但没有这样的运气。
另一个 SE 站点上的这个问题有一个答案,它使用一些简单的文本文件来更改全局(可能是一个坏主意)或特定设备的权限,但是:
- 这不是我要找的“麻瓜的调整”。
- 这些文件中的大多数都有直接修改的警告,因为它们是自动生成的。那么如何确保随机包更新不会消除我的更改并因此中断
myapp
呢? - 无论如何,它似乎什么也没做。我按照这些说明重新启动,
myapp
但用户权限仍然无法与 USB 通信。
这仍然不是我真正想要的“麻瓜的调整”,但至少这是有效的:
显然 udev 有两个目录(我不知道为什么):
/etc/udev/rules.d
/lib/udev/rules.d
我一直在弄乱那个
/lib
,却一无所获。我在这里/etc
找到了一个,它确实有效:放
SUBSYSTEM=="usb", ATTRS{idVendor}=="VID", ATTRS{idProduct}=="PID", MODE="0666"
VID
是相关设备的USB-IF 分配的供应商 ID *PID
是相关设备的供应商分配的产品 ID *0666
提供对与此行匹配的任何内容的通用读/写访问权限*
$ lsusb
查看所有连接的 USB 设备及其 ID。在
/etc/udev/rules.d/xx-my-rule.rules
(可能需要 root/sudo 权限)xx
是任何大于 50 的数字(默认为 50,更高的数字优先)my-rule
是你想怎么称呼它.rules
然后
udevadm control --reload-rules
(可能还需要 root/sudo 权限),它应该对那个特定的 VID/PID 对“正常工作”。另一种选择,以进一步收紧权限,是使用
TAG+="uaccess"
.MODE="0666"
这限制了对当前登录(物理)用户而不是所有用户的访问。谢谢@Lekensteyn!对于其他为此苦苦挣扎的人 - 我需要在 Ubuntu 18.04 下将GROUP="plugdev"添加到我的 udev 规则中以使其工作。
所以对于我的 BTD-400 适配器,文件/etc/udev/rules.d/51-usb-device.rules读取: