Не удалось подключить устройство FT232RL к Pylibftdi (контроллер двигателя постоянного тока Thorlabs APT)

У меня есть контроллер двигателя постоянного тока Thorlabs, который можно обнаружить с помощью следующего журнала dmesg:

usb 5-2: new full-speed USB device number 6 using uhci_hcd
usb 5-2: New USB device found, idVendor=0403, idProduct=faf0
usb 5-2: New USB device strings: Mfr=1, Product=2, SerialNumber=3
usb 5-2: Product: APT DC Motor Controller
usb 5-2: Manufacturer: Thorlabs
usb 5-2: SerialNumber: 83858610
ftdi_sio 5-2:1.0: FTDI USB Serial Device converter detected
usb 5-2: Detected FT232RL
usb 5-2: Number of endpoints 2
usb 5-2: Endpoint 1 MaxPacketSize 64
usb 5-2: Endpoint 2 MaxPacketSize 64
usb 5-2: Setting MaxPacketSize 64
usb 5-2: FTDI USB Serial Device converter now attached to ttyUSB0

Его также можно найти в lsusb:

Bus 005 Device 007: ID 0403:faf0 Future Technology Devices International, Ltd

Основываясь на приведенной выше информации, я настроил /etc/udev/rules.d/99-libftdi.rules:

SUBSYSTEMS=="usb", ATTRS{idVendor}=="0403", ATTRS{idProduct}=="faf0", GROUP="dialout", MODE="0660"

(Я также пробовал группу users и режим 0666.)

И тогда я выполнил команду

$ udevadm test -a -p  $(udevadm info -q path -n /dev/ttyUSB0)

Который дает

GROUP 20 /etc/udev/rules.d/99-libftdi.rules:1
MODE 0660 /etc/udev/rules.d/99-libftdi.rules:1
handling device node '/dev/ttyUSB0', devnum=c188:0, mode=0660, uid=0, gid=20
preserve permissions /dev/ttyUSB0, 020660, uid=0, gid=20
preserve already existing symlink '/dev/char/188:0' to '../ttyUSB0'
found 'c188:0' claiming '/run/udev/links/\x2fserial\x2fby-id\x2fusb-Thorlabs_APT_DC_Motor_Controller_83858610-if00-port0'
creating link '/dev/serial/by-id/usb-Thorlabs_APT_DC_Motor_Controller_83858610-if00-port0' to '/dev/ttyUSB0'
preserve already existing symlink '/dev/serial/by-id/usb-Thorlabs_APT_DC_Motor_Controller_83858610-if00-port0' to '../../ttyUSB0'
found 'c188:0' claiming '/run/udev/links/\x2fserial\x2fby-path\x2fpci-0000:00:1d.0-usb-0:2:1.0-port0'
creating link '/dev/serial/by-path/pci-0000:00:1d.0-usb-0:2:1.0-port0' to '/dev/ttyUSB0'
preserve already existing symlink '/dev/serial/by-path/pci-0000:00:1d.0-usb-0:2:1.0-port0' to '../../ttyUSB0'

Теперь что касается программного обеспечения. Libftdi v1.0 устанавливается под Linux Mint 17 по следующей инструкции:

Библиотека Pylibftdi не работает (последовательный режим, UM232H)

и pylibftdi устанавливается через pip:

$ sudo -H env PATH=$PATH pip install pylibftdi

Он может повторить правильную версию libftdi:

$ python -m pylibftdi.examples.info

pylibftdi version     : 0.15.0
libftdi version       : libftdi_version(major=1, minor=0, micro=0, version_str='1.0', snapshot_str='v1.0')
libftdi library name  : libftdi1.so.2
libusb version        : libusb_version(major=1, minor=0, micro=17, nano=10830, rc='', describe='http://libusbx.org')
libusb library name   : libusb-1.0.so.0
Python version        : 2.7.10
OS platform           : Linux-3.13.0-37-generic-x86_64-with-debian-jessie-sid

Однако он не будет отображать какие-либо подключенные устройства FTDI, даже с sudo:

$ sudo python -m pylibftdi.examples.list_devices
$ (nothing printed)

Есть ли способ протестировать libftdi и pylibftdi по отдельности? Или у нас уже есть достаточно информации, чтобы получить эту работу? Заранее спасибо.


person htsai    schedule 30.06.2015    source источник


Ответы (1)


Устройство не обнаружено, потому что оно имеет странный idProduct. Официальные вопросы и ответы дают подсказку о жизнеспособном решении: http://pylibftdi.readthedocs.org/en/latest/how_to.html

Откройте .../pylibftdi/examples/list_devices.py и добавьте следующие строки после строки 24:

from pylibftdi import USB_PID_LIST
USB_PID_LIST.append(0xfaf0)

и попробуйте снова запустить команду:

$ python -m pylibftdi.examples.list_devices
Thorlabs:APT DC Motor Controller:83858610
person htsai    schedule 30.06.2015