LibUSB ErrNo 16 Ресурс занят — устройство чтения магнитных полос

Я использую rPi 2B, к которому я подключил устройство чтения карт Magstripe (используя преобразователь PS/2 в USB). Я определил правильный идентификатор поставщика/продукта с помощью lsusb, а затем использую следующий код, который использует libusb для подключения к считывателю. Этот код выполняет проверку is_kernel_driver_active, которая, по-видимому, является основным источником ошибки для этой проблемы. Код взят из проекта keyboard_alike на github.

def initialize(self):
    self._device = usb.core.find(idVendor=self.vendor_id, idProduct=self.product_id)

    if self._device is None:
        raise DeviceException('No device found, check vendor_id and product_id')

    if self._device.is_kernel_driver_active(self.interface):
        try:
            self._device.detach_kernel_driver(self.interface)
        except usb.core.USBError as e:
            raise DeviceException('Could not detach kernel driver: %s' % str(e))

    try:
        self._device.set_configuration()
        if self.should_reset:
            self._device.reset()
    except usb.core.USBError as e:
        raise DeviceException('Could not set configuration: %s' % str(e))

    self._endpoint = self._device[0][(0, 0)][0]

При выполнении от имени пользователя root я получаю Resource busy при вызове self._device.set_configuration().

Я запустил все обновления и не знаю, что делать дальше.


person Matthew    schedule 23.10.2016    source источник


Ответы (1)


Я думаю, что исправил это, используя этот сообщение - похоже, проблема в том, что считыватель магнитной полосы был запрошен драйвером USBHID при запуске. Эта проблема не решается с помощью detach_kernel_driver().

Я создал правило в /etc/udev/rules.d, чтобы это устройство не загружалось. Теперь я перехожу к новой проблеме, но это, похоже, исправило первоначальную проблему.

Мое правило выглядело так: # Считыватель магнитной полосы должен быть отключен SUBSYSTEM=="usb", ATTRS{idVendor}=="04b4", ATTRS{idProduct}=="2324", ATTR{authorized}="0"

person Matthew    schedule 23.10.2016