Разрешение, отклоненное некорневому пользователю для USB-устройства

Я испытываю много затруднений, заставляя Ардуино Крошечный Программист AVR, иначе (PMG-11801) работать над моим ноутбуком Ubuntu 18.04. Это - устройство Ардуино, что программы ATTiny85 вносят IDE Ардуино.

Я прочитал несколько сообщений форума от различных мест и попробовал решение, которое похоже на него, работал на многих других, но это не работало на меня. Вот то, что я сделал.

mmachenry$ lsusb
... other devices ...
Bus 001 Device 013: ID 1781:0c9f Multiple Vendors USBtiny
... other devices ...

Я отмечаю 1781:0c9f поставщиком и идентификатором продукта для следующего шага.

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

mmachenry$ cat /etc/udev/rules.d/99-USBtiny.rules 
SUBSYSTEM=="usb", ATTR{idVendor}=="1781", ATTR{idProduct}=="0c9f", GROUP="adm", MODE="0666"

Также обратите внимание, что я нахожусь в надлежащей группе.

mmachenry$ groups
mmachenry adm dialout cdrom sudo dip plugdev docker lpadmin sambashare

Чтобы иметь, это вступает в силу, сразу выполнил их после создания, которое управляет файлом.

sudo service udev restart
sudo udevadm control --reload-rules

Согласно просьбе комментарием Norbert, я выполнил проверку работоспособности на моих группах пользователей, но туда, кажется, ничто неправильно, поскольку нет никакого вывода.

mmachenry@mmachenry-laptop:~$ sudo update-passwd --sanity-check --verbose

Но когда я выполняю avrdude, я отклонил разрешение.

mmachenry$ hardware/tools/avr/bin/avrdude -C/home/mmachenry/Downloads/arduino-1.8.5-linux64/arduino-1.8.5/hardware/tools/avr/etc/avrdude.conf -vv -pattiny85 -cusbtiny

avrdude: Version 6.3, compiled on Jan 17 2017 at 11:00:16
         Copyright (c) 2000-2005 Brian Dean, http://www.bdmicro.com/
         Copyright (c) 2007-2014 Joerg Wunsch

         System wide configuration file is "/home/mmachenry/Downloads/arduino-1.8.5-linux64/arduino-1.8.5/hardware/tools/avr/etc/avrdude.conf"
         User configuration file is "/home/mmachenry/.avrduderc"
         User configuration file does not exist or is not a regular file, skipping

         Using Port                    : usb
         Using Programmer              : usbtiny
avrdude: usbdev_open(): Found USBtinyISP, bus:device: 001:013
avrdude: Warning: cannot open USB device: Permission denied
avrdude: Error: Could not find USBtiny device (0x1781/0xc9f)

avrdude done.  Thank you.

Однако я получаю много другого, положительного вывода при выполнении команды с sudo.

sudo hardware/tools/avr/bin/avrdude -C/home/mmachenry/Downloads/arduino-1.8.5-linux64/arduino-1.8.5/hardware/tools/avr/etc/avrdude.conf -vv -pattiny85 -cusbtiny

avrdude: Version 6.3, compiled on Jan 17 2017 at 11:00:16
         Copyright (c) 2000-2005 Brian Dean, http://www.bdmicro.com/
         Copyright (c) 2007-2014 Joerg Wunsch

         System wide configuration file is "/home/mmachenry/Downloads/arduino-1.8.5-linux64/arduino-1.8.5/hardware/tools/avr/etc/avrdude.conf"
         User configuration file is "/home/mmachenry/.avrduderc"
         User configuration file does not exist or is not a regular file, skipping

         Using Port                    : usb
         Using Programmer              : usbtiny
avrdude: usbdev_open(): Found USBtinyISP, bus:device: 001:013
         AVR Part                      : ATtiny85
         Chip Erase delay              : 400000 us
         PAGEL                         : P00
         BS2                           : P00
         RESET disposition             : possible i/o
         RETRY pulse                   : SCK
         serial program mode           : yes
         parallel program mode         : yes
         Timeout                       : 200
         StabDelay                     : 100
         CmdexeDelay                   : 25
         SyncLoops                     : 32
         ByteDelay                     : 0
         PollIndex                     : 3
         PollValue                     : 0x53
         Memory Detail                 :

                                  Block Poll               Page                       Polled
           Memory Type Mode Delay Size  Indx Paged  Size   Size #Pages MinW  MaxW   ReadBack
           ----------- ---- ----- ----- ---- ------ ------ ---- ------ ----- ----- ---------
           eeprom        65    12     4    0 no        512    4      0  4000  4500 0xff 0xff
           flash         65     6    32    0 yes      8192   64    128 30000 30000 0xff 0xff
           signature      0     0     0    0 no          3    0      0     0     0 0x00 0x00
           lock           0     0     0    0 no          1    0      0  9000  9000 0x00 0x00
           lfuse          0     0     0    0 no          1    0      0  9000  9000 0x00 0x00
           hfuse          0     0     0    0 no          1    0      0  9000  9000 0x00 0x00
           efuse          0     0     0    0 no          1    0      0  9000  9000 0x00 0x00
           calibration    0     0     0    0 no          1    0      0     0     0 0x00 0x00

         Programmer Type : USBtiny
         Description     : USBtiny simple USB programmer, http://www.ladyada.net/make/usbtinyisp/
avrdude: programmer operation not supported

avrdude: Using SCK period of 10 usec
CMD: [ac 53 00 00] [ac 52 53 00]
avrdude: AVR device initialized and ready to accept instructions

Reading |                                                    | 0% 0.00sCMD: [30 00 00 00] [00 30 00 1e]
CMD: [30 00 01 00] [00 30 00 93]
Reading | #################                                  | 33% 0.00sCMD: [30 00 02 00] [00 30 00 0b]
Reading | ################################################## | 100% 0.00s

avrdude: Device signature = 0x1e930b (probably t85)
CMD: [50 00 00 00] [00 50 00 e2]
CMD: [50 00 00 00] [00 50 00 e2]
CMD: [50 00 00 00] [00 50 00 e2]
CMD: [58 08 00 00] [00 58 08 df]
CMD: [58 08 00 00] [00 58 08 df]
CMD: [58 08 00 00] [00 58 08 df]
avrdude: safemode: hfuse reads as DF
CMD: [50 08 00 00] [00 50 08 ff]
CMD: [50 08 00 00] [00 50 08 ff]
CMD: [50 08 00 00] [00 50 08 ff]
avrdude: safemode: efuse reads as FF

CMD: [50 00 00 00] [00 50 00 e2]
CMD: [50 00 00 00] [00 50 00 e2]
CMD: [50 00 00 00] [00 50 00 e2]
CMD: [58 08 00 00] [00 58 08 df]
CMD: [58 08 00 00] [00 58 08 df]
CMD: [58 08 00 00] [00 58 08 df]
avrdude: safemode: hfuse reads as DF
CMD: [50 08 00 00] [00 50 08 ff]
CMD: [50 08 00 00] [00 50 08 ff]
CMD: [50 08 00 00] [00 50 08 ff]
avrdude: safemode: efuse reads as FF
avrdude: safemode: Fuses OK (E:FF, H:DF, L:E2)

avrdude done.  Thank you.

При выполнении этой внутренней части IDE Ардуино имеет тот же эффект. Как обычный пользователь, я отклонил разрешение. Когда я выполняю IDE как корень, он работает полностью и загружает мою программу на Ардуино. Обратите внимание, что это устройство распознано как USB-устройство, так как это - usbtinyISP, и не как последовательное устройство как некоторый Arduinos.

Почему разрешение для обычного пользователя для доступа к этому устройству, все еще отклоненному?

Спасибо.

3
задан 23 June 2018 в 18:38

1 ответ

  1. Удостоверяются, что Ваше правило udev корректно:

    SUBSYSTEM=="usb", ATTR{product}=="USBtiny", ATTR{idProduct}=="0c9f", ATTRS{idVendor}=="1781", MODE="0660", GROUP="dialout"
    
  2. Удостоверяются, что обновили udev:

    sudo udevadm control --reload-rules && udevadm trigger
    
  3. Удостоверяются, что отключили и повторно включили USB-устройство!

последний - то, что взяло меня некоторое время для выяснения!

0
ответ дан 1 December 2019 в 20:23

Другие вопросы по тегам:

Похожие вопросы: