2003-10-20 11:59:45 +07:00
|
|
|
.TH UDEV 8 "October 2003" "" "Linux Administrator's Manual"
|
2003-10-17 14:29:17 +07:00
|
|
|
.SH NAME
|
2003-10-20 11:59:45 +07:00
|
|
|
udev \- Linux configurable dynamic device naming support
|
2003-10-17 14:29:17 +07:00
|
|
|
.SH SYNOPSIS
|
2003-10-22 11:46:00 +07:00
|
|
|
.BI udev " hotplug-subsystem"
|
2003-10-17 14:29:17 +07:00
|
|
|
.SH "DESCRIPTION"
|
|
|
|
.B udev
|
2004-04-02 13:59:56 +07:00
|
|
|
provides a dynamic device directory containing only the files for actually
|
|
|
|
present devices. It creates or removes device node files usually located in
|
|
|
|
the /dev directory, or it renames network interfaces.
|
|
|
|
.br
|
2003-10-22 11:46:00 +07:00
|
|
|
.P
|
2003-10-20 11:59:45 +07:00
|
|
|
As part of the
|
|
|
|
.B hotplug
|
|
|
|
subsystem,
|
|
|
|
.B udev
|
2003-10-22 11:46:00 +07:00
|
|
|
is executed if a kernel device is added or removed from the system.
|
2003-10-20 11:59:45 +07:00
|
|
|
On device creation,
|
|
|
|
.B udev
|
2003-10-22 11:46:00 +07:00
|
|
|
reads the sysfs directory of the given device to collect device attributes
|
2003-10-20 11:59:45 +07:00
|
|
|
like label, serial number or bus device number.
|
2004-03-10 10:50:30 +07:00
|
|
|
These attributes may be used as keys to determine a
|
2004-04-02 13:59:56 +07:00
|
|
|
unique name for the device.
|
2003-11-12 18:48:04 +07:00
|
|
|
.B udev
|
|
|
|
maintains a database for devices present on the system.
|
2003-10-22 11:46:00 +07:00
|
|
|
.br
|
2003-10-20 11:59:45 +07:00
|
|
|
On device removal,
|
|
|
|
.B udev
|
2004-01-13 16:35:55 +07:00
|
|
|
queries its database for the name of the device file to be deleted.
|
2003-10-22 11:46:00 +07:00
|
|
|
.SH "CONFIGURATION"
|
2003-12-05 10:22:53 +07:00
|
|
|
All
|
|
|
|
.B udev
|
2004-12-18 06:19:35 +07:00
|
|
|
configuration files consist of a set of lines of text. All empty
|
2004-12-08 05:01:44 +07:00
|
|
|
lines or lines beginning with '#' will be ignored.
|
2003-12-03 16:09:48 +07:00
|
|
|
.P
|
2003-11-12 18:48:04 +07:00
|
|
|
.B udev
|
2003-12-03 16:09:48 +07:00
|
|
|
expects its main configuration file at
|
2004-02-27 10:35:38 +07:00
|
|
|
.IR /etc/udev/udev.conf .
|
2004-03-10 10:50:30 +07:00
|
|
|
The file consists of a set of variables and values allowing the user to
|
|
|
|
override default udev values. The following variables can be overridden
|
|
|
|
in this file:
|
2003-12-03 16:09:48 +07:00
|
|
|
.TP
|
|
|
|
.B udev_root
|
2004-03-10 10:50:30 +07:00
|
|
|
Indicates where to place the device nodes in the filesystem. The default
|
|
|
|
value is
|
2004-04-24 11:50:27 +07:00
|
|
|
.IR @udevdir@/ .
|
2003-12-03 16:09:48 +07:00
|
|
|
.TP
|
|
|
|
.B udev_db
|
2004-03-10 10:50:30 +07:00
|
|
|
The name and location of the udev database. The default value is
|
2004-11-06 20:28:01 +07:00
|
|
|
.IR @udevdir@/.udevdb .
|
2003-12-03 16:09:48 +07:00
|
|
|
.TP
|
|
|
|
.B udev_rules
|
2004-04-03 07:59:04 +07:00
|
|
|
The name of the udev rules file or directory to look for files with the suffix
|
|
|
|
.IR .rules .
|
|
|
|
All rule files are read in lexical order. The default value is
|
2004-04-24 11:50:27 +07:00
|
|
|
.IR /etc/udev/rules.d/ .
|
2003-12-03 16:09:48 +07:00
|
|
|
.TP
|
2004-02-13 15:35:30 +07:00
|
|
|
.B udev_log
|
2004-12-08 05:01:44 +07:00
|
|
|
The switch to enable/disable logging of udev information
|
2004-04-02 13:59:56 +07:00
|
|
|
The default value is
|
2004-02-27 10:35:38 +07:00
|
|
|
.IR yes .
|
2004-02-13 15:35:30 +07:00
|
|
|
.TP
|
2003-12-03 16:09:48 +07:00
|
|
|
.B default_mode
|
2004-12-19 04:58:37 +07:00
|
|
|
The default mode for all nodes where no explicit value is given by a rule.
|
|
|
|
The default value is
|
2004-12-20 09:04:11 +07:00
|
|
|
.IR 0660 .
|
2004-01-20 10:44:24 +07:00
|
|
|
.TP
|
|
|
|
.B default_owner
|
2004-12-19 04:58:37 +07:00
|
|
|
The default owner for all nodes where no explicit value is given by a rule.
|
|
|
|
The default value is
|
2004-02-27 10:35:38 +07:00
|
|
|
.IR root .
|
2004-01-20 10:44:24 +07:00
|
|
|
.TP
|
|
|
|
.B default_group
|
2004-12-19 04:58:37 +07:00
|
|
|
The default group for all nodes where no explicitly value is given by a rule.
|
|
|
|
The default value is
|
2004-02-27 10:35:38 +07:00
|
|
|
.IR root .
|
2003-10-20 11:59:45 +07:00
|
|
|
.br
|
2003-12-03 16:09:48 +07:00
|
|
|
.P
|
2004-12-18 06:19:35 +07:00
|
|
|
.RI "A sample " udev.conf " file might look like this:
|
2003-12-03 16:09:48 +07:00
|
|
|
.sp
|
|
|
|
.nf
|
2004-03-10 10:50:30 +07:00
|
|
|
# udev_root - where to place the device nodes in the filesystem
|
2004-04-24 11:50:27 +07:00
|
|
|
udev_root="/udev"
|
2003-12-03 16:09:48 +07:00
|
|
|
|
2004-03-10 10:50:30 +07:00
|
|
|
# udev_db - The name and location of the udev database
|
2004-11-06 20:28:01 +07:00
|
|
|
udev_db="/udev/.udevdb"
|
2003-12-03 16:09:48 +07:00
|
|
|
|
2004-04-03 07:59:04 +07:00
|
|
|
# udev_rules - The name of the udev rules file or directory to look
|
|
|
|
for files with the suffix .rules
|
|
|
|
udev_rules="/etc/udev/rules.d/"
|
2003-12-03 16:09:48 +07:00
|
|
|
|
2004-02-13 15:35:30 +07:00
|
|
|
# udev_log - set to "yes" if you want logging, else "no"
|
|
|
|
udev_log="yes"
|
|
|
|
|
2004-12-19 04:58:37 +07:00
|
|
|
# default_mode - set the default mode for all nodes that have no
|
|
|
|
# permissions specified
|
2004-12-20 09:04:11 +07:00
|
|
|
default_mode="0660"
|
2004-01-20 10:44:24 +07:00
|
|
|
|
2004-12-19 04:58:37 +07:00
|
|
|
# default_owner - set the default owner for all nodes that have no
|
|
|
|
# permissions specified
|
2004-01-20 10:44:24 +07:00
|
|
|
default_owner="root"
|
|
|
|
|
2004-12-19 04:58:37 +07:00
|
|
|
# default_group - set the default group for all nodes that have no
|
|
|
|
# permissions specified
|
2004-01-20 10:44:24 +07:00
|
|
|
default_group="root"
|
2003-12-03 16:09:48 +07:00
|
|
|
.fi
|
|
|
|
.P
|
2004-12-08 05:01:44 +07:00
|
|
|
The rules for device naming are read from the files located in the
|
2004-04-24 11:50:27 +07:00
|
|
|
.I /etc/udev/rules.d/
|
|
|
|
directory, or at the location specified by the
|
2003-12-03 16:09:48 +07:00
|
|
|
.I udev_rules
|
2003-12-17 14:36:19 +07:00
|
|
|
value in the
|
2003-12-03 16:09:48 +07:00
|
|
|
.I /etc/udev/udev.conf
|
|
|
|
file.
|
2004-04-24 11:50:27 +07:00
|
|
|
.br
|
2004-01-13 16:35:55 +07:00
|
|
|
Every line in the rules file defines the mapping between device attributes
|
2004-04-02 13:59:56 +07:00
|
|
|
and the device name. One or more keys are specified to match a rule with
|
|
|
|
the current device. If all keys are matching, the rule will be applied and
|
|
|
|
the name is used to name the device file or the network interface.
|
2003-12-10 15:30:43 +07:00
|
|
|
.br
|
2004-01-13 16:35:55 +07:00
|
|
|
If no matching rule is found, the default kernel device name is used.
|
2003-10-21 13:33:54 +07:00
|
|
|
.P
|
2004-03-23 13:19:37 +07:00
|
|
|
Every rule consists of a list of comma separated fields:
|
2003-10-22 11:46:00 +07:00
|
|
|
.sp
|
2004-03-02 13:38:44 +07:00
|
|
|
.IR "key " ,[ "key " ,...] " name " [, " symlink" ]
|
2003-10-22 11:46:00 +07:00
|
|
|
.sp
|
2004-03-10 10:50:30 +07:00
|
|
|
where fields are:
|
2003-10-20 11:59:45 +07:00
|
|
|
.TP
|
2003-12-30 15:54:29 +07:00
|
|
|
.B BUS
|
2004-01-13 16:35:55 +07:00
|
|
|
Match the bus type of the device.
|
|
|
|
(The sysfs device bus must be able to be determined by a "device" symlink.)
|
|
|
|
.TP
|
|
|
|
.B KERNEL
|
|
|
|
Match the kernel device name.
|
|
|
|
.TP
|
2004-11-12 12:52:55 +07:00
|
|
|
.B SUBSYSTEM
|
2004-11-13 11:21:12 +07:00
|
|
|
Match the kernel subsystem name.
|
2004-11-12 12:52:55 +07:00
|
|
|
.TP
|
2004-11-13 11:21:12 +07:00
|
|
|
.B DRIVER
|
|
|
|
Match the kernel driver name.
|
2004-11-12 12:52:55 +07:00
|
|
|
.TP
|
2004-01-13 16:35:55 +07:00
|
|
|
.B ID
|
|
|
|
Match the device number on the bus, like PCI bus id.
|
|
|
|
.TP
|
|
|
|
.B PLACE
|
|
|
|
Match the topological position on bus, like physical port of USB device
|
|
|
|
.TP
|
2004-02-17 16:27:01 +07:00
|
|
|
.BI SYSFS{ filename }
|
2004-01-13 16:35:55 +07:00
|
|
|
Match sysfs device attribute like label, vendor, USB serial number, SCSI UUID
|
2004-12-18 06:19:35 +07:00
|
|
|
or file system label. Up to 5 different sysfs files can be checked, with
|
2004-03-10 10:50:30 +07:00
|
|
|
all of the values being required to match the rule.
|
2004-03-05 09:59:13 +07:00
|
|
|
.br
|
|
|
|
Trailing whitespace characters in the sysfs attribute value are ignored, if
|
|
|
|
the key doesn't have any trailing whitespace characters by itself.
|
2004-01-13 16:35:55 +07:00
|
|
|
.TP
|
|
|
|
.B PROGRAM
|
|
|
|
Call external program. This key is valid if the program returns successful.
|
2004-02-27 12:29:49 +07:00
|
|
|
The environment variables of
|
2004-02-27 10:39:33 +07:00
|
|
|
.B udev
|
|
|
|
are also available for the program.
|
|
|
|
.br
|
2004-03-10 10:50:30 +07:00
|
|
|
The string returned by the program may be additionally matched with the
|
2004-01-13 16:35:55 +07:00
|
|
|
.B RESULT
|
|
|
|
key.
|
|
|
|
.TP
|
|
|
|
.B RESULT
|
|
|
|
Match the returned string of the last
|
|
|
|
.B PROGRAM
|
2004-03-10 10:50:30 +07:00
|
|
|
call. This key may be used in any following rule after a
|
2004-01-13 16:35:55 +07:00
|
|
|
.B PROGRAM
|
|
|
|
call.
|
2004-03-02 13:38:44 +07:00
|
|
|
.TP
|
2004-02-17 16:27:01 +07:00
|
|
|
.B NAME
|
2004-04-02 13:59:56 +07:00
|
|
|
The name of the node to be created, or the name, the network interface
|
|
|
|
should be renamed to.
|
2004-03-02 13:38:44 +07:00
|
|
|
.br
|
|
|
|
If given with the attribute
|
2004-02-17 16:27:01 +07:00
|
|
|
.BR NAME{ all_partitions }
|
2004-12-18 06:19:35 +07:00
|
|
|
.B udev
|
|
|
|
will create device nodes for all 15 partitions of a blockdevice.
|
2004-02-17 16:27:01 +07:00
|
|
|
This may be useful for removable media devices.
|
2004-11-13 20:43:24 +07:00
|
|
|
.br
|
|
|
|
If given with the attribute
|
|
|
|
.BR NAME{ ignore_remove }
|
2004-12-18 06:19:35 +07:00
|
|
|
.B udev
|
|
|
|
will ignore any later remove event for this device.
|
2004-11-13 20:43:24 +07:00
|
|
|
This may be useful as a workaround for broken device drivers.
|
|
|
|
.sp
|
|
|
|
Multiple attributes may be separated by comma.
|
2004-03-02 13:38:44 +07:00
|
|
|
.TP
|
|
|
|
.B SYMLINK
|
|
|
|
The name of a symlink targeting the node. Multiple symlinks may be
|
|
|
|
specified by separating the names by the space character.
|
2004-03-10 10:50:22 +07:00
|
|
|
.br
|
|
|
|
If both the name and the symlink fields are omitted or its
|
2004-12-08 05:01:44 +07:00
|
|
|
values are empty, the device will be ignored and no node will be created.
|
2004-03-10 10:50:22 +07:00
|
|
|
.br
|
|
|
|
If only the symlink field is given and the name field is omitted,
|
2004-12-08 05:01:44 +07:00
|
|
|
the rule will not be applied immediately, but the symlink field is added
|
2004-03-10 10:50:22 +07:00
|
|
|
to the symlink list of the rule which will create the node.
|
|
|
|
This makes it possible to specify additional symlinks in a possibly
|
|
|
|
separate rules file, while the device nodes are maintained by the
|
|
|
|
distribution provided rules file.
|
2004-03-11 13:35:37 +07:00
|
|
|
.TP
|
|
|
|
.B OWNER, GROUP, MODE
|
2004-12-18 17:34:17 +07:00
|
|
|
The permissions for this device. Every specified value overwrites the default
|
|
|
|
value specified in the config file.
|
2004-02-17 16:27:01 +07:00
|
|
|
.P
|
2003-12-10 15:30:43 +07:00
|
|
|
.RB "The " NAME " ," SYMLINK " and " PROGRAM
|
2004-12-08 05:01:44 +07:00
|
|
|
fields support simple printf-like string substitutions:
|
2003-11-19 21:18:54 +07:00
|
|
|
.TP
|
|
|
|
.B %n
|
2003-12-10 15:30:43 +07:00
|
|
|
The "kernel number" of the device.
|
2004-02-28 21:53:25 +07:00
|
|
|
For example, 'sda3' has a "kernel number" of '3'.
|
2003-11-19 21:18:54 +07:00
|
|
|
.TP
|
2003-12-23 13:40:19 +07:00
|
|
|
.B %k
|
|
|
|
The "kernel name" for the device.
|
|
|
|
.TP
|
2003-11-19 21:18:54 +07:00
|
|
|
.B %M
|
2003-12-10 15:30:43 +07:00
|
|
|
The kernel major number for the device.
|
2003-11-19 21:18:54 +07:00
|
|
|
.TP
|
|
|
|
.B %m
|
2003-12-10 15:30:43 +07:00
|
|
|
The kernel minor number for the device.
|
2003-11-19 21:18:54 +07:00
|
|
|
.TP
|
|
|
|
.B %b
|
2003-12-10 15:30:43 +07:00
|
|
|
The bus id for the device.
|
2003-11-24 14:39:39 +07:00
|
|
|
.TP
|
|
|
|
.B %c
|
2004-12-08 05:01:44 +07:00
|
|
|
The string returned by the external program, specified in
|
2004-01-14 09:31:20 +07:00
|
|
|
.B PROGRAM
|
|
|
|
(This does not work within the
|
|
|
|
.B PROGRAM
|
|
|
|
field for the obvious reason.)
|
2004-02-18 10:02:39 +07:00
|
|
|
.br
|
2004-03-10 10:50:30 +07:00
|
|
|
A single part of the string, separated by a space character
|
2004-03-23 13:19:37 +07:00
|
|
|
may be selected by specifying the part number as an attribute:
|
2004-03-11 16:37:18 +07:00
|
|
|
.BI %c{ N }
|
|
|
|
If the number is followed by the + char this part plus
|
|
|
|
all remaining parts of the result string are substituted:
|
|
|
|
.BI %c{ N+ }
|
2004-02-18 10:02:39 +07:00
|
|
|
.TP
|
|
|
|
.BI %s{ filename }
|
|
|
|
The content of a sysfs attribute.
|
2003-11-25 14:45:38 +07:00
|
|
|
.TP
|
[PATCH] compatibility symlinks for udev
On Mon, 2004-09-06 at 17:45 +0200, Kay Sievers wrote:
> On Mon, 2004-09-06 at 16:46 +0200, David Zeuthen wrote:
>
> Nice, I like it. It's a easy way to group device nodes of the same type,
> but coming from different kernel subsystems.
>
That's a good way of putting it, yeah.
> > Here's a patch against udev-030 that can help create compatibility
> > symlinks like /dev/cdrom, /dev/cdrom1 etc. The patch introduces a new
> > substitution type %C (for Compatibility) that can be used as follows
>
> I suggest using %e for enumeration here, cause "compatibility" can
> easily be misunderstood.
>
Good point, I've changed that.
> And we need a few lines added to the man page at udev.8.in :)
>
Done. I've also added an example.
Also, Kay pointed out offlist that the rules can be written to not
require a shell script; this actually works
KERNEL="sr*", NAME="%k", SYMLINK="cdrom%e"
KERNEL="scd*", NAME="%k", SYMLINK="cdrom%e"
KERNEL="pcd*", NAME="%k", SYMLINK="cdrom%e"
KERNEL="hd[a-z]", PROGRAM="/bin/cat /proc/ide/%k/media", RESULT="cdrom", NAME="\%k", SYMLINK="cdrom%e"
KERNEL="fd[0-9]", NAME="%k", SYMLINK="floppy%e"
KERNEL="hd[a-z]", PROGRAM="/bin/cat /proc/ide/%k/media", RESULT="floppy", NAME=\"%k", SYMLINK="floppy%e"
New patch is attached.
David
2004-09-11 11:04:13 +07:00
|
|
|
.B %e
|
|
|
|
If a device node already exists with the name, the smallest positive
|
|
|
|
decimal integer N is substituted such that the resulting name doesn't
|
|
|
|
match an existing device node. Otherwise nothing is substituted. This
|
|
|
|
can be used to create compatibility symlinks and enumerate devices of
|
|
|
|
the same type originating from different kernel subsystems.
|
|
|
|
.TP
|
2004-01-15 09:18:12 +07:00
|
|
|
.B %%
|
2004-02-28 21:53:25 +07:00
|
|
|
The '%' character itself.
|
|
|
|
.P
|
|
|
|
The count of charcters to insert may be limited by specifying
|
|
|
|
the format length value. For example, '%3s{file}' will only insert
|
|
|
|
the first three characters of the sysfs attribute.
|
2003-11-19 21:18:54 +07:00
|
|
|
.P
|
2004-12-18 06:19:35 +07:00
|
|
|
.RI "A sample " udev.rules " file might look like this:"
|
2003-10-22 11:46:00 +07:00
|
|
|
.sp
|
2003-10-20 11:59:45 +07:00
|
|
|
.nf
|
2004-12-08 05:01:44 +07:00
|
|
|
# if /sbin/scsi_id returns "OEM 0815", the device will be called disk1
|
2004-01-13 16:35:55 +07:00
|
|
|
BUS="scsi", PROGRAM="/sbin/scsi_id", RESULT="OEM 0815", NAME="disk1"
|
2003-11-24 14:39:39 +07:00
|
|
|
|
2003-10-20 11:59:45 +07:00
|
|
|
# USB printer to be called lp_color
|
2004-02-17 16:27:01 +07:00
|
|
|
BUS="usb", SYSFS{serial}="W09090207101241330", NAME="lp_color"
|
2003-10-20 11:59:45 +07:00
|
|
|
|
2004-03-10 10:50:30 +07:00
|
|
|
# SCSI disk with a specific vendor and model number will be called boot
|
2004-02-17 16:27:01 +07:00
|
|
|
BUS="scsi", SYSFS{vendor}="IBM", SYSFS{model}="ST336", NAME="boot%n"
|
2003-12-23 13:36:10 +07:00
|
|
|
|
2003-10-20 11:59:45 +07:00
|
|
|
# sound card with PCI bus id 00:0b.0 to be called dsp
|
2004-01-13 16:35:55 +07:00
|
|
|
BUS="pci", ID="00:0b.0", NAME="dsp"
|
2003-10-20 11:59:45 +07:00
|
|
|
|
|
|
|
# USB mouse at third port of the second hub to be called mouse1
|
2004-01-13 16:35:55 +07:00
|
|
|
BUS="usb", PLACE="2.3", NAME="mouse1"
|
2003-10-20 11:59:45 +07:00
|
|
|
|
2003-12-11 06:40:08 +07:00
|
|
|
# ttyUSB1 should always be called pda with two additional symlinks
|
2004-01-13 16:35:55 +07:00
|
|
|
KERNEL="ttyUSB1", NAME="pda", SYMLINK="palmtop handheld"
|
2003-10-21 13:33:54 +07:00
|
|
|
|
2003-12-11 06:40:08 +07:00
|
|
|
# multiple USB webcams with symlinks to be called webcam0, webcam1, ...
|
2004-02-17 16:27:01 +07:00
|
|
|
BUS="usb", SYSFS{model}="XV3", NAME="video%n", SYMLINK="webcam%n"
|
[PATCH] compatibility symlinks for udev
On Mon, 2004-09-06 at 17:45 +0200, Kay Sievers wrote:
> On Mon, 2004-09-06 at 16:46 +0200, David Zeuthen wrote:
>
> Nice, I like it. It's a easy way to group device nodes of the same type,
> but coming from different kernel subsystems.
>
That's a good way of putting it, yeah.
> > Here's a patch against udev-030 that can help create compatibility
> > symlinks like /dev/cdrom, /dev/cdrom1 etc. The patch introduces a new
> > substitution type %C (for Compatibility) that can be used as follows
>
> I suggest using %e for enumeration here, cause "compatibility" can
> easily be misunderstood.
>
Good point, I've changed that.
> And we need a few lines added to the man page at udev.8.in :)
>
Done. I've also added an example.
Also, Kay pointed out offlist that the rules can be written to not
require a shell script; this actually works
KERNEL="sr*", NAME="%k", SYMLINK="cdrom%e"
KERNEL="scd*", NAME="%k", SYMLINK="cdrom%e"
KERNEL="pcd*", NAME="%k", SYMLINK="cdrom%e"
KERNEL="hd[a-z]", PROGRAM="/bin/cat /proc/ide/%k/media", RESULT="cdrom", NAME="\%k", SYMLINK="cdrom%e"
KERNEL="fd[0-9]", NAME="%k", SYMLINK="floppy%e"
KERNEL="hd[a-z]", PROGRAM="/bin/cat /proc/ide/%k/media", RESULT="floppy", NAME=\"%k", SYMLINK="floppy%e"
New patch is attached.
David
2004-09-11 11:04:13 +07:00
|
|
|
|
|
|
|
# grouping of optical drives from multiple kernel subsystems
|
|
|
|
KERNEL="sr*", NAME="%k", SYMLINK="cdrom%e"
|
|
|
|
KERNEL="scd*", NAME="%k", SYMLINK="cdrom%e"
|
|
|
|
KERNEL="pcd*", NAME="%k", SYMLINK="cdrom%e"
|
|
|
|
KERNEL="hd[a-z]", PROGRAM="/bin/cat /proc/ide/%k/media", RESULT="cdrom",
|
|
|
|
NAME="%k", SYMLINK="cdrom%e"
|
2003-10-20 11:59:45 +07:00
|
|
|
.fi
|
2003-10-22 11:46:00 +07:00
|
|
|
.P
|
2003-12-04 10:26:02 +07:00
|
|
|
A number of different fields in the above configuration files support a simple
|
2003-12-05 10:22:53 +07:00
|
|
|
form of shell style pattern matching. It supports the following pattern characters:
|
2003-12-04 10:26:02 +07:00
|
|
|
.TP
|
|
|
|
.B *
|
|
|
|
Matches zero, one, or more characters.
|
|
|
|
.TP
|
|
|
|
.B ?
|
|
|
|
Matches any single character, but does not match zero characters.
|
|
|
|
.TP
|
|
|
|
.B [ ]
|
|
|
|
Matches any single character specified within the brackets. For example, the
|
2004-12-18 06:19:35 +07:00
|
|
|
pattern string "tty[SR]" would match either "ttyS" or "ttyR". Ranges are also
|
|
|
|
supported within this match with the '\-' character. For example, to match on
|
2004-03-02 13:34:10 +07:00
|
|
|
the range of all digits, the pattern [0\-9] would be used. If the first character
|
2004-12-08 05:01:44 +07:00
|
|
|
following the '[' is a '!', any characters not enclosed are matched.
|
2004-04-02 13:59:56 +07:00
|
|
|
.P
|
|
|
|
After device node creation, removal, or network device renaming,
|
|
|
|
.B udev
|
2004-12-18 06:19:35 +07:00
|
|
|
executes the programs located in the directory tree under
|
2004-04-02 13:59:56 +07:00
|
|
|
.IR /etc/dev.d/ .
|
2004-12-08 05:01:44 +07:00
|
|
|
The name of a program must have the suffix
|
2004-04-02 13:59:56 +07:00
|
|
|
.I .dev
|
2004-12-08 05:01:44 +07:00
|
|
|
to be recognized.
|
2004-04-02 13:59:56 +07:00
|
|
|
.br
|
|
|
|
In addition to the hotplug environment variables,
|
2004-11-28 19:41:15 +07:00
|
|
|
.B UDEV_LOG
|
|
|
|
is set if udev is configured to use the syslog facility. Executed programs may
|
|
|
|
want to follow that setting.
|
2004-04-02 13:59:56 +07:00
|
|
|
.B DEVNAME
|
|
|
|
is exported to make the name of the created node, or the name the network
|
2004-12-18 06:19:35 +07:00
|
|
|
device is renamed to, available to the executed program. The programs in every
|
2004-04-02 13:59:56 +07:00
|
|
|
directory are sorted in lexical order, while the directories are searched in
|
|
|
|
the following order:
|
|
|
|
.sp
|
|
|
|
.nf
|
|
|
|
/etc/dev.d/$(DEVNAME)/*.dev
|
|
|
|
/etc/dev.d/$(SUBSYSTEM)/*.dev
|
|
|
|
/etc/dev.d/default/*.dev
|
|
|
|
.fi
|
2004-12-18 06:19:35 +07:00
|
|
|
.SH "ENVIRONMENT"
|
|
|
|
.P
|
|
|
|
The following variables are read from the environment:
|
|
|
|
.TP
|
|
|
|
.B ACTION
|
|
|
|
.IR add " or " remove
|
|
|
|
signifies the addition or the removal of a device.
|
|
|
|
.TP
|
|
|
|
.B DEVPATH
|
|
|
|
The sysfs devpath of the device without the mountpoint but a leading slash.
|
|
|
|
.TP
|
|
|
|
.B SUBSYSTEM
|
|
|
|
The subsystem the device belongs to. Alternatively the subsystem may
|
|
|
|
be passed as the first argument.
|
|
|
|
.TP
|
|
|
|
.B UDEV_CONFIG_FILE
|
|
|
|
Overrides the default location of the
|
|
|
|
.B udev
|
|
|
|
config file.
|
|
|
|
.TP
|
|
|
|
.B UDEV_NO_DEVD
|
|
|
|
The default behavior of
|
|
|
|
.B udev
|
|
|
|
is to execute programs in the
|
|
|
|
.I /etc/dev.d/
|
|
|
|
directory after device handling. If set,
|
|
|
|
.B udev
|
|
|
|
will skip this step.
|
2003-10-17 14:29:17 +07:00
|
|
|
.SH "FILES"
|
|
|
|
.nf
|
|
|
|
/sbin/udev udev program
|
2003-12-03 16:09:48 +07:00
|
|
|
/etc/udev/* udev config files
|
2003-10-17 14:29:17 +07:00
|
|
|
/etc/hotplug.d/default/udev.hotplug hotplug symlink to udev program
|
2004-04-02 13:59:56 +07:00
|
|
|
/etc/dev.d/* programs invoked by udev
|
2003-10-17 14:29:17 +07:00
|
|
|
.fi
|
|
|
|
.SH "SEE ALSO"
|
2004-01-27 10:56:43 +07:00
|
|
|
.BR udevinfo (8),
|
2004-02-27 10:39:33 +07:00
|
|
|
.BR udevd (8),
|
2003-10-22 11:46:00 +07:00
|
|
|
.BR hotplug (8)
|
2003-10-17 14:29:17 +07:00
|
|
|
.PP
|
2004-12-18 06:19:35 +07:00
|
|
|
.B Web resources:
|
|
|
|
.nf
|
2004-03-02 13:34:10 +07:00
|
|
|
.I http://linux\-hotplug.sourceforge.net/
|
2004-12-18 06:19:35 +07:00
|
|
|
.I http://www.kernel.org/pub/linux/utils/kernel/hotplug/udev.html
|
|
|
|
.fi
|
2003-10-17 14:29:17 +07:00
|
|
|
.SH AUTHORS
|
2003-11-12 18:48:04 +07:00
|
|
|
.B udev
|
|
|
|
was developed by Greg Kroah-Hartman <greg@kroah.com> with much help from
|
2003-12-04 10:27:24 +07:00
|
|
|
Dan Stekloff <dsteklof@us.ibm.com>, Kay Sievers <kay.sievers@vrfy.org>, and
|
|
|
|
many others.
|