Скрипт в правиле udev не запускается

10475
Eric Heikes

Я использую Ubuntu 9.10 (Karmic Koala) на ноутбуке и хотел бы, чтобы NumLock автоматически переключался в зависимости от того, подключена ли моя клавиатура USB (включен ли numlock) или нет (выключен numlock).

Для этого я сначала установил пакет «numlockx». numlockx onи numlockx offработает отлично.

Чтобы подключиться к системе устройств, я решил использовать udev. Я прочитал «Написание правил udev», но у меня возникли проблемы с выполнением правила udev.

Во-первых, вот пример dmesgвывода:

[20906.985102] usb 3-2: новое низкоскоростное USB-устройство с использованием uhci_hcd и адреса 6 [20907.166403] USB 3-2: конфигурация № 1 выбрана из 1 выбора [20907.192904] ввод: Эргономическая клавиатура Microsoft Natural® 4000 в виде /devices/pci0000:00/0000:00:1a.0/usb3/3-2/3-2:1.0/input/input20 [20907.193100] microsoft 0003: 045E: 00DB.000B: ввод, hidraw1: USB HID v1.11 Клавиатура [Эргономичная клавиатура Microsoft Natural® 4000] на usb-0000: 00: 1a.0-2 / input0 [20907.217810] ввод: Эргономичная клавиатура Microsoft Natural® 4000, как /devices/pci0000:00/0000:00:1a.0/usb3/3-2/3-2:1.1/input/input21 [20907.217979] microsoft 0003: 045E: 00DB.000C: ввод, hidraw2: USB HID v1.11 Устройство [Эргономическая клавиатура Microsoft Natural® 4000] на usb-0000: 00: 1a.0-2 / input1 

Я использовал udevadm infoдля сбора информации об устройстве:

> udevadm info -a -p /devices/pci0000:00/0000:00:1a.0/usb3/3-2/3-2:1.1/input/input21  глядя на устройство '/devices/pci0000:00/0000:00:1a.0/usb3/3-2/3-2:1.1/input/input21': KERNEL == "input21" SUBSYSTEM == "вход" DRIVER == "" Атр {} Phys == "USB-0000: 00: 1a.0-2 / input1" ATTR == "" Атр == "вход: b0003v045Ep00DBe0111-e0,1,2,3,4,14, k71,72,73,74,75,77,79,7A, 7В, 7С, 7D, 7E, 7F, 80, 81,82,83,84,85,86,87,88,89,8A, 8В, 8С, 8Е, 90,96,98,9B, 9С, 9Е, 9F, А1, А3, А4, А5, А6, А7, А8, А9, AB, AC, AD, AE, В0, В1, В2, В3, В4, В5, В6, В8, В9, ВА, ВВ, ВС, BD, BE, BF, С0, С1, С2, CE, CF, D0, D1, D2, D5, D9, DB, DF, Е2, Е7, Е8, Е9, Е. А., Е.Б., F0,100,162,166,16A, 16E, 178,179,17A, 17B, 17C, 17D, 17F, 180,181,182,185,18C, 18D, 192,193,195,1A0,1A1,1A2,1A3,1A4,1A5,1A6,1A7,1A8,1A9,1AA, 1AB, 1AC, 1AD, 1AE, 1B0,1B1,1B7, r6, а20, m4, lsfw»  глядя на родительское устройство '/devices/pci0000:00/0000:00:1a.0/usb3/3-2/3-2:1.1': KERNELS == "3-2: 1,1" SUBSYSTEMS == "USB" DRIVERS == "usbhid" ATTRS == "01" ATTRS == "0" ATTRS == "01" ATTRS == "03" ATTRS == "00" ATTRS == "00" AttrS == "USB: v045Ep00DBd0173dc00dsc00dp00ic03isc00ip00" ATTRS == "1"  глядя на родительское устройство '/devices/pci0000:00/0000:00:1a.0/usb3/3-2': KERNELS == "3-2" SUBSYSTEMS == "USB" DRIVERS == "USB" ATTRS == "" ATTRS == "2" ATTRS == "1" ATTRS == "a0" ATTRS == "100mA" ATTRS == "532" ATTRS == "045e" ATTRS == "" 00 дБ ATTRS == "0173" ATTRS == "00" ATTRS == "00" ATTRS == "00" ATTRS == "1" ATTRS == "8" ATTRS == "1.5" ATTRS == "3" ATTRS == "6" ATTRS == "2,00" ATTRS == "0" AttrS == "0x0" ATTRS == "1" ATTRS == "Microsoft"  глядя на родительское устройство '/devices/pci0000:00/0000:00:1a.0/usb3': KERNELS == "usb3" SUBSYSTEMS == "USB" DRIVERS == "USB" ATTRS == "" ATTRS == "1" ATTRS == "1" ATTRS == "e0" ATTRS == "0 мА" ATTRS == "127" ATTRS == "1d6b" ATTRS == "0001" ATTRS == "0206" ATTRS == "09" ATTRS == "00" ATTRS == "00" ATTRS == "1" ATTRS == "64" ATTRS == "12" ATTRS == "3" ATTRS == "1" ATTRS == "1.10" ATTRS == "2" AttrS == "0x0" ATTRS == "1" ATTRS == "Linux 2.6.31-16-generic uhci_hcd" ATTRS == "UHCI Host Controller" ATTRS == "0000: 00: 1a.0" ATTRS == "1"  глядя на родительское устройство '/devices/pci0000:00/0000:00:1a.0': KERNELS == "0000: 00: 1a.0" SUBSYSTEMS == "PCI" DRIVERS == "uhci_hcd" ATTRS == "0x8086" ATTRS == "0x2937" ATTRS == "0x1558" ATTRS == "0x0860" ATTRS == "0x0c0300" ATTRS == "16" ATTRS == "FF" ATTRS == "0-7" AttrS == "PCI: v00008086d00002937sv00001558sd00000860bc0Csc03i00" ATTRS == "0" ATTRS == ""  глядя на родительское устройство '/ devices / pci0000: 00': KERNELS == "pci0000: 00" SUBSYSTEMS == "" DRIVERS == "" 

Итак, я создал файл с именем /etc/udev/rules.d/usb-keyboard.rules:

# Включите NumLock, когда клавиатура подключена. ДЕЙСТВИЕ == "добавить", ATTRS == "Microsoft", SUBSYSTEM == "ввод", RUN + = "/ usr / bin / numlockx вкл"  # Выключайте NumLock, когда клавиатура отключена. ДЕЙСТВИЕ == "удалить", ATTRS == "Microsoft", SUBSYSTEM == "ввод", RUN + = "/ usr / bin / numlockx off" 

Я использовал udevadm testдля проверки правильности правил:

> udevadm test --action = add /devices/pci0000:00/0000:00:1a.0/usb3/3-2/3-2:1.1/input/input21 run_command: вызов: тест udevadm_test: версия 147  [...] parse_file: чтение '/etc/udev/rules.d/usb-keyboard.rules' как файла правил udev_rules_new: правила используют токены 180864 байта (15072 * 12 байтов), буфер 31614 байтов udev_rules_new: временный индекс использовал 49760 байт (2488 * 20 байт) udev_device_new_from_syspath: устройство 0x28d7d80 имеет devpath '/devices/pci0000:00/0000:00:1a.0/usb3/3-2/3-2:1.1/input/input21' udev_rules_apply_to_event: RUN '/ sbin / modprobe -b $ env ' /lib/udev/rules.d/80-drivers.rules:5 udev_rules_apply_to_event: RUN 'сокет: @ / org / freedesktop / hal / udev_event' /lib/udev/rules.d/90-hal.rules:2 udev_device_new_from_syspath: устройство 0x28d8560 имеет devpath '/devices/pci0000:00/0000:00:1a.0/usb3/3-2/3-2:1.1' udev_device_new_from_syspath: устройство 0x28d8708 имеет devpath '/devices/pci0000:00/0000:00:1a.0/usb3/3-2' udev_rules_apply_to_event: RUN '/ usr / bin / numlockx на' /etc/udev/rules.d/usb-keyboard.rules:7 udevadm_test: UDEV_LOG = 6 udevadm_test: DEVPATH = / devices / pci0000: 00/0000: 00: 1a.0 / usb3 / 3-2 / 3-2: 1.1 / input / input21 udevadm_test: PRODUCT = 3 / 45e / db / 111 udevadm_test: NAME = "Эргономичная клавиатура Microsoft Natural® 4000" udevadm_test: PHYS = "usb-0000: 00: 1a.0-2 / input1" udevadm_test: UNIQ = "" udevadm_test: EV == 10001f udevadm_test: KEY == 837fff 2c3027 bf004444 0 0 1 10f84 8a27c007 ff7f7bfa d9415fff febeffdf ffefffff ffffffff fffffffe udevadm_test: REL == 40 udevadm_test: ABS == 1 0 udevadm_test: MSC == 10 udevadm_test: MODALIAS = вход: b0003v045Ep00DBe0111-e0,1,2,3,4,14, k71,72,73,74,75,77,79,7A, 7B, 7C, 7D, 7E, 7F, 80,81, 82,83,84,85,86,87,88,89,8A, 8В, 8С, 8Е, 90,96,98,9B, 9С, 9Е, 9F, А1, А3, А4, А5, А6, А7, А8, А9, AB, AC, AD, AE, В0, В1, В2, В3, В4, В5, В6, В8, В9, ВА, ВВ, ВС, BD, BE, BF, С0, С1, С2, CE, CF, D0, D1, D2, D5, D9, DB, DF, Е2, Е7, Е8, Е9, Е. А., Е.Б., F0,100,162,166,16A, 16E, 178,179,17A, 17B, 17C, 17D, 17F, 180181182185, 18C, 18D, 192,193,195,1A0,1A1,1A2,1A3,1A4,1A5,1A6,1A7,1A8,1A9,1AA, 1AB, 1AC, 1AD, 1AE, 1B0,1B1,1B7, r6, а20, m4, lsfw udevadm_test: ACTION = добавить udevadm_test: SUBSYSTEM = вход udevadm_test: run: '/ sbin / modprobe -b вход: b0003v045Ep00DBe0111-e0,1,2,3,4,14, k71,72,73,74,75,77,79,7A, 7B, 7C, 7D, 7E, 7F, 80,81,82,83,84,85,86,87,88,89,8A, 8B, 8C, 8E, 90,96,98,9B, 9С, 9Е, 9F, A1, A3, A4, А5, А6, А7, А8, А9, AB, AC, AD, AE, В0, В1, В2, В3, В4, В5, В6, В8, В9, ВА, ВВ, ВС, BD, BE, BF, С0, С1, С2, CE, CF, D0, D1, D2, D5, D9, DB, DF, Е2, Е7, Е8, Е9, Е. А., Е.Б., F0,100,162,166,16A, 16E, 178,179,17A, 17B, 17C, 17D, 17F, 180,181,182,185,18C, 18D, 192,193,195,1A0,1A1,1A2,1A3,1A4,1A5,1A6,1A7,1A8,1A9,1AA, 1AB, 1AC, 1AD, 1AE, 1B0,1B1,1B7, r6, а20, m4, lsfw» udevadm_test: run: 'socket: @ / org / freedesktop / hal / udev_event' udevadm_test: run: '/ usr / bin / numlockx on' 

А вот тест «удалить»:

> udevadm test --action = remove /devices/pci0000:00/0000:00:1a.0/usb3/3-2/3-2:1.1/input/input21  run_command: вызов: тест udevadm_test: версия 147  [...] parse_file: чтение '/etc/udev/rules.d/usb-keyboard.rules' как файла правил udev_rules_new: правила используют токены 180864 байта (15072 * 12 байтов), буфер 31614 байтов udev_rules_new: временный индекс использовал 49760 байт (2488 * 20 байт) udev_device_new_from_syspath: устройство 0xd2fd80 имеет devpath '/devices/pci0000:00/0000:00:1a.0/usb3/3-2/3-2:1.1/input/input21' udev_rules_apply_to_event: RUN 'сокет: @ / org / freedesktop / hal / udev_event' /lib/udev/rules.d/90-hal.rules:2 udev_device_new_from_syspath: устройство 0xd2fff8 имеет devpath '/devices/pci0000:00/0000:00:1a.0/usb3/3-2/3-2:1.1' udev_device_new_from_syspath: устройство 0xd30690 имеет devpath '/devices/pci0000:00/0000:00:1a.0/usb3/3-2' udev_rules_apply_to_event: RUN '/ usr / bin / numlockx off' /etc/udev/rules.d/usb-keyboard.rules:10 udevadm_test: UDEV_LOG = 6 udevadm_test: DEVPATH = / devices / pci0000: 00/0000: 00: 1a.0 / usb3 / 3-2 / 3-2: 1.1 / input / input21 udevadm_test: PRODUCT = 3 / 45e / db / 111 udevadm_test: NAME = "Эргономичная клавиатура Microsoft Natural® 4000" udevadm_test: PHYS = "usb-0000: 00: 1a.0-2 / input1" udevadm_test: UNIQ = "" udevadm_test: EV == 10001f udevadm_test: KEY == 837fff 2c3027 bf004444 0 0 1 10f84 8a27c007 ff7f7bfa d9415fff febeffdf ffefffff ffffffff fffffffe udevadm_test: REL == 40 udevadm_test: ABS == 1 0 udevadm_test: MSC == 10 udevadm_test: MODALIAS = вход: b0003v045Ep00DBe0111-e0,1,2,3,4,14, k71,72,73,74,75,77,79,7A, 7B, 7C, 7D, 7E, 7F, 80,81, 82,83,84,85,86,87,88,89,8A, 8В, 8С, 8Е, 90,96,98,9B, 9С, 9Е, 9F, А1, А3, А4, А5, А6, А7, А8, А9, AB, AC, AD, AE, В0, В1, В2, В3, В4, В5, В6, В8, В9, ВА, ВВ, ВС, BD, BE, BF, С0, С1, С2, CE, CF, D0, D1, D2, D5, D9, DB, DF, Е2, Е7, Е8, Е9, Е. А., Е.Б., F0,100,162,166,16A, 16E, 178,179,17A, 17B, 17C, 17D, 17F, 180181182185, 18C, 18D, 192,193,195,1A0,1A1,1A2,1A3,1A4,1A5,1A6,1A7,1A8,1A9,1AA, 1AB, 1AC, 1AD, 1AE, 1B0,1B1,1B7, r6, а20, m4, lsfw udevadm_test: ACTION = удалить udevadm_test: SUBSYSTEM = вход udevadm_test: run: 'socket: @ / org / freedesktop / hal / udev_event' udevadm_test: run: '/ usr / bin / numlockx off' 

Проблема в том, что когда клавиатура подключена или отключена, состояние NumLock не изменяется. Я попытался перезапустить службу udev, но безуспешно. Мои правила udev неверны? Я поступаю об этом неправильно?

8
Исправлена! Спасибо Тони-П-Ли и Уайткварку за то, что они указали мне правильное направление. Eric Heikes 14 лет назад 0

3 ответа на вопрос

4
tony-p-lee

эти две команды могут быть использованы для отладки проблем udev:

 udevd --debug-trace --verbose strace -p pid_of_udevd -f -e trace=open,exec 

Обратите внимание, что аргументы могут меняться в разных версиях ...

Отличный совет - хотя на моем udevd нет «многословной» опции. `udevd --debug` - это все, что мне нужно, чтобы отследить проблему. Eric Heikes 14 лет назад 3
@EricHeikes: Наконец-то удалось получить полезный вывод, почему скрипты оболочки udev не работают. Спасибо! Mikko Ohtamaa 8 лет назад 0
4
whitequark

Проблема в том, что вы, вероятно, протестировали numlockx в (как следует из названия) в некоторой среде X. X-клиенты (программы с графическим интерфейсом, которые подключаются к X-серверу, например, Firefox или GEdit) должны знать сервер для подключения и также должны проходить определенную авторизацию. Попробуйте войти в систему с простой консоли, независимо от того, являетесь ли вы пользователем root или обычным пользователем, и запустить какое-либо приложение с графическим интерфейсом: оно покажет некоторые ошибки, связанные с DISPLAY, потому что не знает об этом.

Чтобы это исправить, вам нужно установить переменную окружения DISPLAY; если у вас есть только один X-сервер, он почти всегда имеет адрес: 0.

Попробуйте это в простой консоли: введите numlockx on, и он покажет «Ошибка открытия дисплея!». Типа DISPLAY=:0 numlockx on, и он будет работать (работал для меня по крайней мере).

Таким образом, вы можете установить эту переменную окружения в udev или просто запустить sh -c 'DISPLAY=:0 numlockx <state>'.

Ты прав! Я не считал, что numlockx требует X-среды. К сожалению, хотя установка DISPLAY избавляет от сообщения об ошибке, оно не работает - ни в консоли, ни через udev. Eric Heikes 14 лет назад 0
Говорил слишком рано. Это работает, если вы запускаете оболочку, используя полный путь: `/ bin / sh -c '...'` Eric Heikes 14 лет назад 0
0
Blorgbeard

Это может быть чистым совпадением, но мое правило udev начало работать, когда я назвал его, начиная с цифры, например. 80-usb-keyboard.rules,

Я тоже обдумал это, но это ничего не меняет. Eric Heikes 14 лет назад 0