Voglio disabilitare i dispositivi USB basati sull'ID del fornitore in ambiente Linux. Voglio consentire solo dispositivi USB specifici, in base all'ID fornitore.
Voglio disabilitare i dispositivi USB basati sull'ID del fornitore in ambiente Linux. Voglio consentire solo dispositivi USB specifici, in base all'ID fornitore.
Risposte:
È possibile creare una regola udev che disabilita i dispositivi per impostazione predefinita, ma ne abilita alcuni in base all'ID fornitore. Crea un file /etc/udev/rules.d/01-usblockdown.rules
che contiene una regola per disabilitare i dispositivi:
ACTION=="add", SUBSYSTEMS=="usb", RUN+="/bin/sh -c 'for host in /sys/bus/usb/devices/usb*; do echo 0 > $host/authorized_default; done'"
E quindi le regole per abilitare i dispositivi che si desidera consentire (è possibile utilizzare ATTR{idVendor}
per accedere all'ID fornitore):
ACTION=="add", ATTR{idVendor}=="0000" RUN+="/bin/sh -c 'echo 1 >/sys$DEVPATH/authorized'"
Vedi "Bloccare Linux usando UDEV" per maggiori informazioni.
(questo potrebbe essere stato un commento migliore, ma mi mancano i punti, quindi l'ho espanso in una risposta)
Sono venuto qui alla ricerca di come consentire tutti i dispositivi USB tranne disabilitare uno specifico per fornitore e ID prodotto. Come disabilitare un dispositivo audio USB con udev risponde per l'esempio 0d8c: 000c.
Creare /etc/udev/rules.d/disable-usb-device.rules
:
ACTION=="add", ATTR{idVendor}=="0d8c", ATTR{idProduct}=="000c", RUN="/bin/sh -c 'echo 0 >/sys/\$devpath/authorized'"
C'è una discrepanza tra la risposta e un commento qui sotto con RUN=
vs. RUN+=
, ho provato il primo e ha funzionato bene.
Mi aspettavo che dmesg o lusb riferissero in modo diverso, ma entrambi mostrano che il dispositivo non autorizzato viene enumerato come prima, ma altri processi / moduli che si sarebbero avviati automaticamente sembrano non essere in esecuzione, il che era l'effetto desiderato. cat /sys/bus/usb/devices/1-2.2.1.1.4/authorized
(1-2.2 ... per esempio che si trova in dmesg) mostra che lo 0 è stato messo nel posto giusto.
ATTRS
(plurale) e non ATTR
quando interrogo i dispositivi udevadm
.