Udev
udev (user /dev) es el gestor de dispositivos para el núcleo Linux. Gestiona los nodos de dispositivo en /dev y también todos las acciones en espacio de usuario cuando se añaden o eliminan dispositivos. El lector debería también echar un vistazo a [Project:Eudev|eudev] una bifurcación de udev. Readers of this article should also look at eudev, a fork of udev.
udev from the sys-apps/systemd-utils package is used as the default device manager for Gentoo systems using the OpenRC init system, independently of systemd.
¿Qué es udev?
El directorio /dev
Most Linux users understand that /dev/sda1 is just a fast way of referring to the first partition on the first disk that the kernel found. That's pretty easy, right?
But consider hotpluggable devices like USB, IEEE 1394, hot-swappable PCI, etc. What is the first device for each of these? And for how long? What will the other devices be named when the first one disappears? How will that affect ongoing transactions? Wouldn't it be fun if a printing job were suddenly moved from a high-end laser printer to an almost-dead matrix printer just because someone decided to pull the plug on the laser printer (which just happened to be the first printer)?
Enter the device manager. A modern device manager must:
- Run in userspace.
- Dynamically create and remove device files.
- Provide consistent device naming.
- Provide a userspace application program interface (API).
Every time a change happens within the device structure, the kernel emits a uevent which gets picked up by the device manager. The device manager then follows the rules declared in the /etc/udev/rules.d, /run/udev/rules.d and /lib/udev/rules.d directories. Based on the information contained within the uevent, it finds the rule or rules it needs to trigger and performs the required actions. These actions may involve the creation or deletion of device files, and may also trigger the loading of particular firmware files into kernel memory.
Instalación
Cuando actualice udev, eche un vistazo a guía de actualización de udev para obtener información sobre cómo evitar que los sistemas no inicien.
Núcleo
udev necesita las siguientes opciones del núcleo:
General setup --->
[*] Configure standard kernel features (expert users) --->
[ ] Enable deprecated sysfs features to support old userspace tools
[*] Enable signalfd() system call
Enable the block layer --->
[*] Block layer SG support v4
Networking support --->
Networking options --->
<*> Unix domain sockets
Device Drivers --->
Generic Driver Options --->
() path to uevent helper
[*] Maintain a devtmpfs filesystem to mount at /dev
< > ATA/ATAPI/MFM/RLL support (DEPRECATED) --->
File systems --->
[*] Inotify support for userspace
Pseudo filesystems --->
[*] /proc file system support
[*] sysfs file system support
Ajustes USE
Portage reconoce el ajuste USE global udev
para habilitar el soporte de udev en otros paquetes. Al añadir este ajuste USE a la lista de ajustes (se realiza por defecto en todos los perfiles) se instalará automáticamente el paquete sys-fs/udev:
USE="udev"
Emerge
Después de definir los ajustes USE, seguramente se desee actualizar el sistema para que los cambios tengan efecto:
root #
emerge --ask --changed-use --deep @world
Configuración
Servicio
Para arrancar udev en el inicio del sistema, añádalo al nivel de ejecución sysinit. Esto se puede hacer lanzando la siguiente orden con privilegios de root:
root #
rc-update add udev sysinit
Configuración avanzada
Reglas
Udev ofrece un conjunto de reglas que concuerdan con los valores exportados de los uevents (eventos enviados por el núcleo) y las propiedades del dispositivo que se ha descubierto. Una regla que concuerda posiblemente creará y nombrará un nodo de dispositivo y lanzará los programas definidos para poner en marcha y configurar el dispositivo.
Las definiciones de las reglas se almacenan en dos localizaciones:
- /lib/udev/rules.d/. Las reglas en este directorio son instaladas por determinados paquetes, normalmente los usuarios no deberían cambiarlas.
- /etc/udev/rules.d/. Este directorio es para las reglas especificadas por los usuarios finales. Cualquier nueva regla se debe añadir en este directorio.
En estos directorios se recorren en orden alfabético múltiples ficheros de reglas (con el sufijo .rules), udev buscará expresiones que concuerden con un uevent y con el estado definido (es el uevent debido que se ha añadido o retirado un dispositivo) y la orden a ejecutar.
La concordancia del evento se basa en información como:
- El SUBSYSTEM del uevent (para qué tipo de dispositivo se dispara el uevent).
- La ACTION que se realiza (añadir, cambiar o eliminar).
- Uno o más atributos (a través de ATTR o ATTRS), tales como la clase del dispositivo, el fabricante u otra información del dispositivo.
- El nombre que ofrece el núcleo (a través de KERNEL), como sd* (para los discos SCSI/SATA) o input* (para dispositivos de entrada como ratones y teclados)
- Uno o más ajustes de entorno (a través de ENV), utilizados para enviar información entre múltiples reglas.
Basándose en esta información, la regla puede entonces comprobar sí:
- Se necesita compartir alguna información con eventos posteriores (a través de variables de entorno)
- Se necesita crear enlaces en /dev
- Se necesita lanzar alguna orden
Udev realiza esto para cada regla que concuerda (por lo que no se detiene en la primera concordancia) para permitir un enfoque flexible de gestión de los dispositivos.
Nombres persistentes de dispositivos
El núcleo detecta los dispositivos de forma asíncrona. Udev crea un reflejo del sistema de ficheros del núcleo sysfs y por lo tanto los dispositivos se nombran y numeran en el orden de su detección. Así, por defecto udev no ofrece nombres persistentes de los dispositivos. Sin embargo, existen mecanismos de algunas clases de dispositivo para ofrecerlos:
- Udev crea enlaces simbólicos adicionales para los dispositivos de almacenamiento basándose en el identificador (ID), la etiqeta, el UUID y la ruta del dispositivo. Eche un vistazo al directorio /dev/disk/by-*. Por lo que, por ejemplo, en lugar de utilizar el archivo de dispositivo /dev/sda utiliza el fichero /dev/disk/by-label/ALGUNA_ETIQUETA.
- Lo mismo aplica para los dispositivos de entrada en el directorio /dev/input.
- Usando reglas propias los usuarios pueden crear sus propios ficheros de dispositivo.
Predictable network interface naming
The new network interface naming convention is not the same. So the symlinks used by netifrc will need to be re-linked. Use /etc/init.d/net.lo as a link target for whatever interface names need to be added. Be sure to replace <interface_name>
in the commands below with the Ethernet interface names present on the system. It is possible to discover which interfaces exist by running the ip link command:
user $
ip link
Create a symbolic link for the existing interfaces in the /etc/init.d/ directory:
root #
ln -s /etc/init.d/net.lo /etc/init.d/net.<interface_name>
Edit /etc/conf.d/net with any necessary configuration for all interfaces.
Add the script(s) to the default runlevel to have the interface(s) start automatically:
root #
rc-update add net.<interface_name> default
Optional: Disable or override predictable network interface naming
Network device names such as eth0
or wlan0
as provided by the kernel are normally changed on system boot (see dmesg) by the /lib/udev/rules.d/80-net-setup-link.rules udev rule and the NamePolicy in /lib/systemd/network/99-default.link.
This behavior may be disabled in several ways:
- Symlink /etc/systemd/network/99-default.link to /dev/null: ln -s /dev/null /etc/systemd/network/99-default.link.
- Create a lower-numbered .link file in /etc/systemd/network which assigns a different name to the interface.
- Pass
net.ifnames=0
on the kernel command line.
Utilización
Algunas órdenes útiles son las siguientes:
- Monitorizar las actividades de udev:
root #
udevadm monitor
root #
udevadm monitor
- Mostrar todos los mensajes sobre un determinado archivo de dispositivo: :
root #
udevadm info --query=all --name=/dev/FICHERO_DE_DISPOSITIVO
root #
udevadm info --query=all --name=/dev/DEVICE_FILE
- Show udev info about a given sys path device file (might be obtained via udevadm monitor):
root #
udevadm info --attribute-walk --path=/devices/DEVICE_FILE
- Asignar un nombre persistente a un dispositivo Ethernet:
SUBSYSTEM=="net", ACTION=="add", ATTR{address}=="01:23:45:67:89:ab", NAME="eth0"
SUBSYSTEM=="net", ACTION=="add", ATTR{address}=="01:23:45:67:89:ab", NAME="ethernet0"
- After changing a rules file in /etc/udev/rules.d/, either reboot or make udev reload them with:
root #
udevadm control --reload-rules
- For already added devices (plugged USB, etc.), the reloaded rules take effect either after changing the device (replugging USB, etc.) or by making udev request kernel events again via udevadm trigger. Various event actions can be triggered. By default, the change event action is triggered:
root #
udevadm trigger
Lea la página del manual de udevadm para más información.
Resolución de problemas
Registrar mensajes del monitor
Para registrar todos los mensajes cuando se lanza udevadm monitor, se debe modificar el siguiente fichero de configuración:
udev_monitor="YES"
Se creará un el nuevo fichero de registro localizado en /run/udev/udevmonitor.log.
Modo depuración
Habilitar el modo depuración permitirá mostrar más mensajes de registro:
udev_debug="YES"
Defina la prioridad del registro:
udev_log="debug"
Se creará el fichero de registro /run/udevdebug.log pero no se mostrarán mensajes en él. Las versiones más recientes de udev mostrarán todos los mensajes en dmesg.
Faltan los ficheros de dispositivo /dev/null y /dev/console
Algunas versiones de udev necesitan los ficheros /dev/null y /dev/console para funcionar correctamente pero no pueden crearlos ellos mismos. Para crear manualmente estos ficheros por udev, lance las siguientes ordenes con privilegios de root:
root #
mkdir test
root #
mount --bind / test
root #
cd test/dev
root #
mknod -m 660 console c 5 1
root #
mknod -m 660 null c 1 3
root #
cd ../..
root #
umount test
root #
rmdir test
NIC asignada a eth0 pero se mueve a eth1
En las placas base con dos tarjetas de red puede suceder que ifconfig no muestre ni eth0 ni eth1. La orden dmesg puede mostrar las NIC detectadas como eth0 y luego cambiar a eth1. Al realizar un ifconfig -a también se mostrar la NIC como eth1. Esto es debido a que el núcleo asigna estos nombres en primer lugar. Los usuarios deben escribir sus propias reglas personalizadas como /etc/udev/rules.d/70-my-network.rules para usar los nombres que elija como lan0 o wireless0 o utilizar los nombres predecibles para las interfaces (que se han habilitado por defecto a partir de la versión 197 de udev).
Recuerde también eliminar los ficheros antiguos de las versiones anteriores de udev:
root #
rm /etc/udev/rules.d/70-persistent-net.rules /etc/systemd/network/99-default.link
Asegúrese también de no pasar net.ifnames=0
en la línea de órdenes del núcleo. Este ajuste desactivaría la característica de nombres predecibles de dispositivo de interfaz para todo el sistema udev.
Ver también
- eudev — una bifurcación del proyecto udev de Gentoo, el gestor de ficheros de dispositivo para el núcleo Linux., a fork of udev, systemd's device file manager for the Linux kernel.
Recursos externos
Bug 575718 - Petición para que el consejo decida en relación al proveedor por defecto de virtual/udev - Proveedor por defecto del paquete virtual/udev ha cambiado a sys-fs/eudev