У меня есть устройство UniFlow от Netware. Когда я подключить его в нем проявляется в dmesg:Как я могу познакомиться с этим устройством, используя pyusb?
[ 2962.369905] usb 2-1.4: new full-speed USB device number 11 using ehci-pci
[ 2962.463867] usb 2-1.4: New USB device found, idVendor=171b, idProduct=2001
[ 2962.463871] usb 2-1.4: New USB device strings: Mfr=1, Product=2, SerialNumber=0
[ 2962.463874] usb 2-1.4: Product: USB Keyboard
[ 2962.463876] usb 2-1.4: Manufacturer: RFIDeas
[ 2962.465361] input: RFIDeas USB Keyboard as /devices/pci0000:00/0000:00:1d.0/usb2/2-1/2-1.4/2-1.4:1.0/0003:171B:2001.0008/input/input17
[ 2962.465481] hid-generic 0003:171B:2001.0008: input,hidraw3: USB HID v1.10 Keyboard [RFIDeas USB Keyboard] on usb-0000:00:1d.0-1.4/input0
Он также появляется в перечисленных USB устройств, с lsusb
командой:
Bus 002 Device 011: ID 171b:2001
Поправьте меня, если я ошибаюсь, но я думаю, Мне нужно развязать устройство, чтобы я мог использовать pyusb для связи с устройством. Когда я пытаюсь запустить свой код, я получаю ошибки при загрузке ресурсов.
Так я cd'd до /sys/bus/usb/devices/usb2/2-1/2-1.4 (заимствована из dmesg), а затем попытались отвязать устройство с помощью
sudo sh -c echo "2-1.4:1.0 > unbind"
Но мне отказали в разрешении. Поэтому я вошел в систему под именем root, но мне все же отказали в разрешении.
Вот мой исходный код, который я пытаюсь использовать для связи с устройством:
#!/usr/bin/env python
import usb.core
import usb.util
import sys
# Find our device from lsusb
# Vendor : Product 171b:2001
dev = usb.core.find(idVendor=0x171b, idProduct=0x2001)
# Was it found?
if dev is None:
raise ValueError('Device not found')
# Set the active configuration. With no arguments, the first
# configuration will be the active one
dev.set_configuration()
# Let's fuzz around!
# Let's start by reading one byte from the device using different requests
# bRequest is a byte so there are 255 different values
for bRequest in range(255):
try:
ret = dev.ctrl_transfer(0xC0, bRequest, 0, 0, 1)
print "bRequest ",bRequest
print ret
except:
# Failed to get data for this request
pass
А вот ошибки, я получаю, когда я пытаюсь запустить программу:
$ sudo python usbhax.py
Traceback (most recent call last):
File "usbhax.py", line 16, in <module>
dev.set_configuration()
File "/usr/local/lib/python2.7/dist-packages/usb/core.py", line 799, in set_configuration
self._ctx.managed_set_configuration(self, configuration)
File "/usr/local/lib/python2.7/dist-packages/usb/core.py", line 128, in managed_set_configuration
self.backend.set_configuration(self.handle, cfg.bConfigurationValue)
File "/usr/local/lib/python2.7/dist-packages/usb/backend/libusb1.py", line 730, in set_configuration
_check(self.lib.libusb_set_configuration(dev_handle.handle, config_value))
File "/usr/local/lib/python2.7/dist-packages/usb/backend/libusb1.py", line 552, in _check
raise USBError(_strerror(ret), ret, _libusb_errno[ret])
usb.core.USBError: [Errno 16] Resource busy
Что я делаю неправильно? Что я могу сделать для связи с этим устройством?
Да, у меня установлен libusb и pyusb. Я работаю в среде Ubuntu.
Установили ли вы себя в качестве члена группы plugdev и создали правила /lib/udev/rules.d файл для устройства? –
Мне нужно быть членом plugdev? но .. im root (?) Хорошо, я попробую. – j0h