Ninjatrappeur's systemd working tree
Go to file
Kay Sievers 95776dc6ec consistent key naming to match only the event device or include all parent devices
This scheme is more consistent and makes it obvious if a match happens
against the event device only, or the full chain of parent devices.

The old key names are now:
  BUS -> SUBSYSTEMS
  ID -> KERNELS
  SYSFS -> ATTRS
  DRIVER -> DRIVERS

Match keys for the event device:
  KERNEL
  SUBSYSTEM
  ATTR
  DRIVER (in a future release, for now the same as DRIVERS)

Match keys for all devices along the parent device chain:
  KERNELS
  SUBSYSTEMS
  ATTRS
  DRIVERS

ID, BUS, SYSFS are no longer mentioned in the man page but still work.
DRIVER must be converted to DRIVERS to match the new scheme. For now,
an error is logged, if DRIVER is used. In a future release, the DRIVER
key behaviour will change.
2006-08-19 16:06:25 +02:00
docs remove broken %e enumeration 2006-07-04 12:27:00 +02:00
etc/udev update SUSE rules 2006-08-13 04:24:40 +02:00
extras consistent key naming to match only the event device or include all parent devices 2006-08-19 16:06:25 +02:00
test consistent key naming to match only the event device or include all parent devices 2006-08-19 16:06:25 +02:00
.gitignore remove old symlinks before creating current ones 2006-04-12 22:08:05 +02:00
ChangeLog 097 release 2006-08-13 05:34:05 +02:00
COPYING [PATCH] added initial documentation and gpl license 2005-04-26 21:00:32 -07:00
FAQ remove broken %e enumeration 2006-07-04 12:27:00 +02:00
list.h [PATCH] cleanup list.h 2005-04-26 23:51:00 -07:00
logging.h whitespace fixes 2006-01-28 16:39:46 +01:00
Makefile rename udev_libc_wrapper -> udev_sysdeps 2006-08-16 02:04:04 +02:00
README update README 2006-08-07 03:13:27 +02:00
RELEASE-NOTES 097 release 2006-08-13 05:34:05 +02:00
TODO remove broken %e enumeration 2006-07-04 12:27:00 +02:00
udev.7 consistent key naming to match only the event device or include all parent devices 2006-08-19 16:06:25 +02:00
udev.c selinux: init once in the daemon, not in every event process 2006-08-18 03:47:59 +02:00
udev.h consistent key naming to match only the event device or include all parent devices 2006-08-19 16:06:25 +02:00
udev.xml consistent key naming to match only the event device or include all parent devices 2006-08-19 16:06:25 +02:00
udev_config.c better log test and comments 2006-01-13 13:17:10 +01:00
udev_db.c consistent key naming to match only the event device or include all parent devices 2006-08-19 16:06:25 +02:00
udev_device.c consistent key naming to match only the event device or include all parent devices 2006-08-19 16:06:25 +02:00
udev_node.c consistent key naming to match only the event device or include all parent devices 2006-08-19 16:06:25 +02:00
udev_rules.c consistent key naming to match only the event device or include all parent devices 2006-08-19 16:06:25 +02:00
udev_rules.h consistent key naming to match only the event device or include all parent devices 2006-08-19 16:06:25 +02:00
udev_rules_parse.c consistent key naming to match only the event device or include all parent devices 2006-08-19 16:06:25 +02:00
udev_selinux.c selinux: fix typo in block device node selection 2006-05-07 22:31:06 +02:00
udev_selinux.h selinux merge fixups again... 2005-04-26 23:52:14 -07:00
udev_sysdeps.c lookup_user, lookup_group: report "unknown user" and "lookup failed" 2006-08-18 03:15:26 +02:00
udev_sysdeps.h rename udev_libc_wrapper -> udev_sysdeps 2006-08-16 02:04:04 +02:00
udev_sysfs.c consistent key naming to match only the event device or include all parent devices 2006-08-19 16:06:25 +02:00
udev_utils.c apply format char to variables exported by ENV 2006-04-15 19:32:05 +02:00
udev_utils_file.c udevinfo, udevtest: simplify '/sys' stripping from devpath argument 2006-08-18 02:33:46 +02:00
udev_utils_run.c don't add $SUBSYSTEM automatically as $1 to programs 2006-01-26 04:38:33 +01:00
udev_utils_string.c add ',' to trusted chars 2006-03-17 01:56:02 +01:00
udevcontrol.c udevd: autotune max_childs/max_childs_running 2006-08-10 12:50:53 +02:00
udevd.8 man pages: work around xmlto which tries to be smart 2006-07-29 02:08:58 +02:00
udevd.c selinux: init once in the daemon, not in every event process 2006-08-18 03:47:59 +02:00
udevd.h udevd: read DRIVER from the environment 2006-08-13 05:32:09 +02:00
udevd.xml man pages: work around xmlto which tries to be smart 2006-07-29 02:08:58 +02:00
udevinfo.8 man pages: work around xmlto which tries to be smart 2006-07-29 02:08:58 +02:00
udevinfo.c consistent key naming to match only the event device or include all parent devices 2006-08-19 16:06:25 +02:00
udevinfo.xml man pages: work around xmlto which tries to be smart 2006-07-29 02:08:58 +02:00
udevmonitor.8 man pages: work around xmlto which tries to be smart 2006-07-29 02:08:58 +02:00
udevmonitor.c initialize unused sockets to -1 2006-08-05 13:24:05 +02:00
udevmonitor.xml man pages: work around xmlto which tries to be smart 2006-07-29 02:08:58 +02:00
udevsettle.8 man pages: work around xmlto which tries to be smart 2006-07-29 02:08:58 +02:00
udevsettle.c set default udevsettle timeout to 3 minutes 2006-04-06 19:46:24 +02:00
udevsettle.xml man pages: work around xmlto which tries to be smart 2006-07-29 02:08:58 +02:00
udevstart.8 man pages: work around xmlto which tries to be smart 2006-07-29 02:08:58 +02:00
udevstart.c selinux: init once in the daemon, not in every event process 2006-08-18 03:47:59 +02:00
udevstart.xml man pages: work around xmlto which tries to be smart 2006-07-29 02:08:58 +02:00
udevtest.8 man pages: fix typos 2006-08-17 00:58:37 +02:00
udevtest.c udevinfo, udevtest: simplify '/sys' stripping from devpath argument 2006-08-18 02:33:46 +02:00
udevtest.xml man pages: fix typos 2006-08-17 00:58:37 +02:00
udevtrigger.8 man pages: work around xmlto which tries to be smart 2006-07-29 02:08:58 +02:00
udevtrigger.c udevtrigger: fix event order 2006-04-08 18:19:10 +02:00
udevtrigger.xml man pages: work around xmlto which tries to be smart 2006-07-29 02:08:58 +02:00

udev - userspace device management

For more information see the files in the docs/ directory.

Important Note:
  Integrating udev in the system is a whole lot of work, has complex dependencies
  and differs a lot from distro to distro. All major distros depend on udev these
  days and the system may not work without a proper installed version. The upstream
  udev project does not support or recommend to replace a distro's udev installation
  with the upstream version. The installation of a unmodified upstream version may
  render your system unusable. Until now, there is no "default" setup or a set of
  "default" rules provided by the upstream udev version.

Requirements:
  - Version 2.6.15 of the Linux kernel for reliable operation of this release of
    udev. The kernel may have a requirement on udev too, see Documentation/Changes
    in the kernel source tree for the actual dependency.

  - The kernel must have sysfs, unix domain sockets and networking enabled.
    (unix domain sockets (CONFIG_UNIX) as a loadable kernel module may work,
    but it is completely silly - don't complain if anything goes wrong.)

  - The proc filesystem must be mounted on /proc, the sysfs filesystem must
    be mounted at /sys. No other location will be supported by udev.


Operation:
  Udev creates and removes device nodes in /dev, based on events the kernel
  sends out on device discovery or removal.

  - Very early in the boot process, the /dev directory should get a 'tmpfs'
    filesystem mounted, which is populated from scratch by udev. Created nodes
    or changed permissions will not survive a reboot, which is intentional.

  - The content of /lib/udev/devices directory which contains the nodes,
    symlinks and directories, which are always expected to be in /dev, should
    be copied over to the tmpfs mounted /dev, to provide the required nodes
    to initialize udev and continue booting.

  - The old hotplug helper /sbin/hotplug should be disabled on bootup, before
    actions like loading kernel modules are taken, which may cause a lot of
    events.

  - The udevd daemon must be started on bootup to receive netlink uevents
    from the kernel driver core.

  - All kernel events are matched against a set of specified rules in
    /etc/udev/rules.d/ which make it possible to hook into the event
    processing to load required kernel modules and setup devices. For all
    devices the kernel exports a major/minor number, udev will create a
    device node with the default kernel name or the one specified by a
    matching udev rule.


Compile Options:
  DESTDIR
  	Prefix of install target, used for package building.
  USE_LOG
  	If set to 'true', udev is able to pass errors or debug information
  	to syslog. This is very useful to see what udev is doing or not doing.
  	It is enabled by default, don't expect any useful answer, if you
  	need to hunt a bug, but you can't enable syslog.
  DEBUG
  	If set to 'true', very verbose debugging messages will be compiled
  	into the udev binaries. The actual level of debugging is specified
  	in the udev config file.
  USE_SELINUX
  	If set to 'true', udev will be built with SELinux support
  	enabled.  This is disabled by default.
  EXTRAS
  	list of helper programs in extras/ to build.
        make EXTRAS="extras/cdrom_id extras/scsi_id extras/volume_id"


Installation:
  - The install target intalls the udev binaries in the default locations,
    All at boot time reqired binaries will be installed in /lib/udev or /sbin.

  - The default location for scripts and binaries that are called from
    rules is /lib/udev. Other packages who install udev rules, should use
    that directory too.

  - It is recommended to use the /lib/udev/devices directory to place
    device nodes and symlinks in, which are copied to /dev at every boot.
    That way, nodes for broken subsystems or devices which can't be
    detected automatically by the kernel, will always be available.

  - Copies of the rules files for the major distros are provided as examples
    in the etc/udev directory.

  - The persistent device naming links in /dev/disk/ are required by other
    software that depends on the data udev has collected from the devices
    and should be installed by default with every udev installation.

Please direct any comment/question/concern to the linux-hotplug-devel mailing list at:
  linux-hotplug-devel@lists.sourceforge.net