2015-08-13 1 views
2

У меня есть устройство 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.

+0

Установили ли вы себя в качестве члена группы plugdev и создали правила /lib/udev/rules.d файл для устройства? –

+0

Мне нужно быть членом plugdev? но .. im root (?) Хорошо, я попробую. – j0h

ответ

2

В моем опыте, вы должны были создать файл правил для устройства системы Udev

  1. Что-то вдоль линий:

    ACTION=="add", SUBSYSTEMS=="usb", ATTRS{idVendor}=="171b", ATTRS{idProduct}=="2001", MODE="660", GROUP="plugdev" 
    

    в файле с именем /lib/udev/rules.d/50-YourSoftwareName.rules (например, копать в man udev для правил именования файлов, но 50-usbhax.rules должен делать)

  2. Добавить свое имя пользователя в plugdev группа

    adduser username plugdev 
    
  3. правила Перезагрузить

    sudo udevadm control --reload (то есть минус минус перезарядка)
    sudo udevadm trigger

  4. отключите и снова подключите устройство или перезагрузить машину и посмотреть, если он работает.

Примечание: Некоторые системы используют группу input, а не plugdev, поэтому редактировать выше соответственно.
Для проверки того, что ваша система использует взглянуть на имя group для соответствующих записей в /dev/usb или /dev/input

+0

Мне пришлось добавить 'SUBSYSTEM == 'usb',' (single) в дополнение к 'SUBSYSTEMS == 'usb'' (множественное число), установить 'MODE =" 0666 "' и перезагрузиться, чтобы быть в состоянии для доступа к устройству Keysight TMC без root/sudo. – skitheo

+0

Кроме того, чтение 'man udev' говорит о том, что необходимо внести локальные изменения в'/etc/udev/rules.d' ** не ** '/ lib/udev/rules.d /'. – skitheo

+0

@skitheo Как я уже сказал, проверьте имя 'group' в'/dev/usb' или '/ dev/input' для группы, относящейся к вашей машине. '/ lib/udev/rules.d /' содержит записи по умолчанию, а '/ etc/udev/rules.d /' содержит настраиваемые правила. правила '/ etc' могут использоваться для переопределения записей по умолчанию, но если у вас нет каких-либо правил по умолчанию для вашего устройства, это означает, что вы используете/etc/udev или/lib/udev, оба действительны , –

Смежные вопросы