Repository for eudev development
Go to file
2008-07-11 10:27:55 +02:00
docs docs: update some docs and delete outdated stuff 2008-06-26 18:12:50 +02:00
etc/udev rules: Debian update 2008-07-11 10:27:55 +02:00
extras scsi_id: the fallback fix broke error handling 2008-07-10 22:22:10 +02:00
test add substitution in MODE= field 2008-05-19 09:05:20 +02:00
.gitignore remove udevstart 2007-11-13 23:44:12 +01:00
ChangeLog release 124 2008-06-12 07:24:30 +02:00
COPYING update source file headers 2006-08-28 00:29:11 +02:00
FAQ switch mailing lists to linux-hotplug@vger.kernel.org 2007-12-27 04:17:46 +01:00
list.h [PATCH] cleanup list.h 2005-04-26 23:51:00 -07:00
logging.h update TODO 2006-09-02 14:26:44 +02:00
Makefile release 124 2008-06-12 07:24:30 +02:00
README release 119 2008-03-15 00:05:02 +01:00
RELEASE-NOTES release 124 2008-06-12 07:24:30 +02:00
test-udev.c add OPTIONS+="event_timeout=<seconds>" 2008-04-21 19:00:54 +02:00
TODO release 120 2008-04-03 21:12:53 +02:00
udev_config.c logging: add trailing newline to all strings 2008-04-20 21:07:06 +02:00
udev_db.c write "event_timeout" to db 2008-04-21 20:22:56 +02:00
udev_device.c add OPTIONS+="event_timeout=<seconds>" 2008-04-21 19:00:54 +02:00
udev_node.c do not touch node ownership and permissions, if already correct 2008-07-10 23:54:28 +02:00
udev_rules_parse.c rename WAIT_FOR_SYSFS to WAIT_FOR and accept an absolute path 2008-05-20 15:02:17 +02:00
udev_rules.c rules: persistent net - handle "locally administered" ibmveth MAC addresses 2008-05-26 17:11:13 +02:00
udev_rules.h rename WAIT_FOR_SYSFS to WAIT_FOR and accept an absolute path 2008-05-20 15:02:17 +02:00
udev_selinux.c logging: add trailing newline to all strings 2008-04-20 21:07:06 +02:00
udev_selinux.h update source file headers 2006-08-28 00:29:11 +02:00
udev_sysdeps.c update TODO 2006-09-02 14:26:44 +02:00
udev_sysdeps.h inotify syscall definitions for M32R 2006-12-06 15:01:30 +01:00
udev_sysfs.c logging: add trailing newline to all strings 2008-04-20 21:07:06 +02:00
udev_utils_file.c logging: add trailing newline to all strings 2008-04-20 21:07:06 +02:00
udev_utils_string.c replace_chars: replace spaces in node name 2007-05-17 20:01:54 +02:00
udev_utils.c logging: add trailing newline to all strings 2008-04-20 21:07:06 +02:00
udev.7 man: rebuild from xml 2008-07-10 23:53:54 +02:00
udev.h add OPTIONS+="event_timeout=<seconds>" 2008-04-21 19:00:54 +02:00
udev.xml man: add link_priority default value 2008-07-10 00:11:05 +02:00
udevadm.8 udevadm: control - fix --env key to accept --env=<KEY>=<value> 2008-04-22 03:19:21 +02:00
udevadm.c logging: add trailing newline to all strings 2008-04-20 21:07:06 +02:00
udevadm.xml udevadm: control - fix --env key to accept --env=<KEY>=<value> 2008-04-22 03:19:21 +02:00
udevcontrol.c udevadm: control - fix --env key to accept --env=<KEY>=<value> 2008-04-22 03:19:21 +02:00
udevd.8 man: udevd- fix udev(8) reference 2008-05-14 04:33:34 +02:00
udevd.c udevd: export .udev/queue/$seqnum before .udev/uevent_seqnum 2008-05-30 09:43:58 +02:00
udevd.h track "move" events to rename database and failed files 2007-08-26 05:22:35 +02:00
udevd.xml man: udevd- fix udev(8) reference 2008-05-14 04:33:34 +02:00
udevinfo.c udevadm: info - do not print ATTR{dev}== 2008-04-28 05:07:47 +02:00
udevmonitor.c also accept real socket files for RUN+="socket:<path>" 2008-04-02 04:43:25 +02:00
udevsettle.c udevadm: settle - add verbose output when running into timeout 2008-07-11 00:52:22 +02:00
udevtest.c add OPTIONS+="event_timeout=<seconds>" 2008-04-21 19:00:54 +02:00
udevtrigger.c udevadm: trigger - add --env= option 2008-04-22 03:01:29 +02:00

udev - userspace device management

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

Important Note:
  Integrating udev in the system has complex dependencies and differs from distro
  to distro. All major distros depend on udev these days and the system may not
  work without a properly installed version. The upstream udev project does not
  recommend to replace a distro's udev installation with the upstream version.

Requirements:
  - Version 2.6.18 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 does not make any sense - 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 locations are 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 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, may 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.

  - Default udev rules and persistent device naming rules are required by other
    software that depends on the data udev collects 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@vger.kernel.org