WebUSB - ошибка "Невозможно запросить интерфейс" - PullRequest
0 голосов
/ 21 марта 2020

Я пытаюсь использовать POS-принтер через WebUSB API с приведенным ниже кодом, но он не работает на .claimInterface() с ошибкой DOMException: Unable to claim interface. Все тесты проводятся на Chrome 80.0.3987.116 на Linux. Как я могу отладить это?

(обновление) Я нашел это демо , но оно приводит к той же ошибке.

async function start () {
    const device = await navigator.usb.requestDevice({
        filters: [{
            vendorId: 0x04b8,
            productId: 0x0202
        }]
    });
    await device.open();
    await device.selectConfiguration(device.configurations[0].configurationValue);
    await device.claimInterface(device.configurations[0].interfaces[0].interfaceNumber);
}

Конечно, я запускаю его на сервере localhost (что означает «безопасный контекст» ) и вызов функции start() с жестом пользователя.

Я также подтвердил, что никакие другие процессы не используют устройство.

% lsof /dev/bus/usb/001/011
COMMAND  PID USER   FD   TYPE DEVICE SIZE/OFF   NODE NAME
chrome  4156 ikr7  393u   CHR 189,10      0t0 331233 /dev/bus/usb/001/011

И ниже вывод lsusb -vs 001:011.

Bus 001 Device 011: ID 04b8:0202 Seiko Epson Corp. Receipt Printer M129C/TM-T70
Device Descriptor:
  bLength                18
  bDescriptorType         1
  bcdUSB               1.10
  bDeviceClass            0 
  bDeviceSubClass         0 
  bDeviceProtocol         0 
  bMaxPacketSize0         8
  idVendor           0x04b8 Seiko Epson Corp.
  idProduct          0x0202 Receipt Printer M129C/TM-T70
  bcdDevice            2.00
  iManufacturer           1 EPSON
  iProduct                2 EPSON UB-U01III
  iSerial                 3 20110125210031250M02C
  bNumConfigurations      1
  Configuration Descriptor:
    bLength                 9
    bDescriptorType         2
    wTotalLength       0x0020
    bNumInterfaces          1
    bConfigurationValue     1
    iConfiguration          0 
    bmAttributes         0xc0
      Self Powered
    MaxPower              100mA
    Interface Descriptor:
      bLength                 9
      bDescriptorType         4
      bInterfaceNumber        0
      bAlternateSetting       0
      bNumEndpoints           2
      bInterfaceClass       255 Vendor Specific Class
      bInterfaceSubClass    255 Vendor Specific Subclass
      bInterfaceProtocol      2 
      iInterface              0 
      Endpoint Descriptor:
        bLength                 7
        bDescriptorType         5
        bEndpointAddress     0x01  EP 1 OUT
        bmAttributes            2
          Transfer Type            Bulk
          Synch Type               None
          Usage Type               Data
        wMaxPacketSize     0x0008  1x 8 bytes
        bInterval               0
      Endpoint Descriptor:
        bLength                 7
        bDescriptorType         5
        bEndpointAddress     0x82  EP 2 IN
        bmAttributes            2
          Transfer Type            Bulk
          Synch Type               None
          Usage Type               Data
        wMaxPacketSize     0x0040  1x 64 bytes
        bInterval               0
Device Status:     0x0001
  Self Powered

1 Ответ

1 голос
/ 21 марта 2020

Проблема была в usblp драйвере, который автоматически загружался ядром Linux. Добавление его в черный список решило проблему. Вот мой /etc/modprobe.d/blacklistusblp.conf файл.

blacklist usblp

Обратите внимание, что занесение в черный список usblp отключает все USB-принтеры, использующие драйвер usblp, но, к счастью, большинство людей, включая меня, используют CUPS в качестве драйвера принтера.

(обновление) Выяснилось, что было бы лучше написать правило udev, которое автоматически отключает драйверы ядра по умолчанию, а не помещает их в черный список. Вот мой /etc/udev/rules.d/99-escpos.rules.

SUBSYSTEM=="usb", ATTRS{idVendor}=="04b8", ATTRS{idProduct}=="0202", MODE="0664", GROUP="wheel", RUN+="/bin/sh -c 'echo -n $id:1.0 > /sys/bus/usb/drivers/usblp/unbind && echo -n $id:1.0 > /sys/bus/usb/drivers/usbfs/unbind'"

Это правило также выгружает usbfs, который иногда загружается ядром при отсоединении usblp.

...