Script de execução automática quando a placa Wifi está conectada (udev)

9

Eu tenho tentado usar udev para fazer um sistema Debian executar um script bash quando uma placa wireless é conectada.

Até agora eu criei este arquivo /etc/udev/rules.d/wifi-detect.rules :

ACTION=="add", ATTRS{idVendor}=="0cf3", ATTRS{idProduct}=="9271", RUN+="/root/test.sh"

E, por enquanto, estou tentando tornar test.sh com este trabalho de conteúdo:

#!/bin/bash
/bin/echo "test!" > /test.txt

Mas, por alguma razão, nada parece acontecer quando eu conecto a placa wireless, nenhum arquivo test.txt é criado.

Meu lsusb no cartão:

Bus 001 Device 015: ID 0cf3:9271 Atheros Communications, Inc. AR9271 802.11n

A execução de udevadm monitor –env é o que acontece quando eu conecto o cartão:

KERNEL[1017.642278] add      /devices/platform/bcm2708_usb/usb1/1-1/1-1.3 (usb)
KERNEL[1017.644676] add      /devices/platform/bcm2708_usb/usb1/1-1/1-1.3/1-1.3:1.0 (usb)
KERNEL[1017.645035] add      /devices/platform/bcm2708_usb/usb1/1-1/1-1.3/firmware/1-1.3 (firmware)
KERNEL[1017.708056] remove   /devices/platform/bcm2708_usb/usb1/1-1/1-1.3/firmware/1-1.3 (firmware)
UDEV  [1017.714772] add      /devices/platform/bcm2708_usb/usb1/1-1/1-1.3 (usb)
UDEV  [1017.733002] remove   /devices/platform/bcm2708_usb/usb1/1-1/1-1.3/firmware/1-1.3 (firmware)
UDEV  [1017.772669] add      /devices/platform/bcm2708_usb/usb1/1-1/1-1.3/firmware/1-1.3 (firmware)
UDEV  [1017.798707] add      /devices/platform/bcm2708_usb/usb1/1-1/1-1.3/1-1.3:1.0 (usb)
KERNEL[1018.456804] add      /devices/platform/bcm2708_usb/usb1/1-1/1-1.3/1-1.3:1.0/ieee80211/phy8 (ieee80211)
KERNEL[1018.465994] add      /devices/platform/bcm2708_usb/usb1/1-1/1-1.3/1-1.3:1.0/net/wlan0 (net)
KERNEL[1018.479878] add      /devices/platform/bcm2708_usb/usb1/1-1/1-1.3/1-1.3:1.0/leds/ath9k_htc-phy8 (leds)
KERNEL[1018.483074] add      /devices/platform/bcm2708_usb/usb1/1-1/1-1.3/usb_device/usbdev1.20 (usb_device)
UDEV  [1018.600456] add      /devices/platform/bcm2708_usb/usb1/1-1/1-1.3/1-1.3:1.0/leds/ath9k_htc-phy8 (leds)
UDEV  [1018.604376] add      /devices/platform/bcm2708_usb/usb1/1-1/1-1.3/1-1.3:1.0/ieee80211/phy8 (ieee80211)
UDEV  [1018.626243] add      /devices/platform/bcm2708_usb/usb1/1-1/1-1.3/usb_device/usbdev1.20 (usb_device)
KERNEL[1018.659318] move     /devices/platform/bcm2708_usb/usb1/1-1/1-1.3/1-1.3:1.0/net/wlan1 (net)
UDEV  [1018.758843] add      /devices/platform/bcm2708_usb/usb1/1-1/1-1.3/1-1.3:1.0/net/wlan1 (net)
UDEV  [1018.932207] move     /devices/platform/bcm2708_usb/usb1/1-1/1-1.3/1-1.3:1.0/net/wlan1 (net)

Eu tentei muitos exemplos, mas não consigo fazer isso funcionar. Espero que alguém possa me ajudar com este;) Obrigado!

EDIT:

Para simplificar, alterei minha regra para:

ACTION=="add", ATTRS{idVendor}=="0cf3", ATTRS{idProduct}=="9271", RUN+="/bin/echo 'test' > /test.txt"

Eu consegui definir udevadm control --log-priority=info como @ user1146332 sugerido e recebi este log interessante:

Sep  9 16:27:53 iklive-rpi1 udevd[1537]: RUN '/bin/echo 'test' > /test.txt' /etc/udev/rules.d/wifi-detect.rules:1
Sep  9 16:27:53 iklive-rpi1 udevd[1544]: starting 'firmware.agent'
Sep  9 16:27:53 iklive-rpi1 udevd[126]: seq 663 queued, 'remove' 'firmware'
Sep  9 16:27:53 iklive-rpi1 udevd[126]: seq 663 forked new worker [1547]
Sep  9 16:27:53 iklive-rpi1 udevd[1537]: 'firmware.agent' [1544] exit with return code 0
Sep  9 16:27:53 iklive-rpi1 udevd[1548]: starting '/bin/echo 'test' > /test.txt'
Sep  9 16:27:53 iklive-rpi1 udevd[1547]: seq 663 running
Sep  9 16:27:53 iklive-rpi1 udevd[1547]: no db file to read /run/udev/data/+firmware:1-1.3.4: No such file or directory
Sep  9 16:27:53 iklive-rpi1 udevd[1547]: passed -1 bytes to netlink monitor 0x1af5ee0
Sep  9 16:27:53 iklive-rpi1 udevd[126]: seq 663 done with 0
Sep  9 16:27:53 iklive-rpi1 udevd[1547]: seq 663 processed with 0
Sep  9 16:27:53 iklive-rpi1 udevd[1537]: '/bin/echo 'test' > /test.txt'(out) 'test > /test.txt'
Sep  9 16:27:53 iklive-rpi1 udevd[1537]: '/bin/echo 'test' > /test.txt' [1548] exit with return code 0

Então ... Não é o return code 0 o código de saída para conclusão bem-sucedida? Em caso afirmativo, por que não recebo nenhum arquivo no sistema?

EDIT 2:

Consegui fazer isso funcionar usando a dica de @htor. Minha regra atual:

ACTION=="add", ATTRS{idVendor}=="0cf3", ATTRS{idProduct}=="9271", RUN+="/bin/sh -c '/bin/echo test >> /test.txt'"

Mas por alguma razão o comando é executado como 8 vezes, existe uma maneira de evitar isso? Eu acho que está acontecendo porque quando os drivers da placa wireless estão sendo carregados eles precisam virtualmente desmontar e montar a placa. Dicas?

    
por TCB13 08.09.2012 / 20:43

2 respostas

3

Eu tive um problema semelhante há um tempo atrás e a solução foi alterar a parte RUN+= para RUN+="sh -c '/root/test.sh'" . Agora, eu não sei se você precisa disso, neste caso, como a regra está chamando um script, não um comando.

Outra observação: tente remover o ! da string "test!" ou substitua as aspas duplas por aspas simples. O estrondo ! provavelmente está causando problemas devido ao seu significado especial no shell e as aspas duplas preservam esse significado.

    
por 08.09.2012 / 20:55
2

Meu conselho seria definir a prioridade de registro de udev de err a info com

 udevadm control --log-priority=info

Se você quiser ver ainda mais informações, defina-o como debug . Agora você pode encontrar informações muito detalhadas sobre o que o udev fez em /var/log/daemon.log (pelo menos em um sistema relacionado ao debian). Geralmente isso ajuda muito a perseguir erros.

Este é apenas um complemento para a resposta de Htor, que provavelmente resolve o seu problema.

    
por 08.09.2012 / 21:09