Repository for eudev development
Go to file
kay.sievers@vrfy.org 7a947ce515 [PATCH] big cleanup of internal udev api
Here is the first patch to cleanup the internal processing of the
various stages of an udev event. It should not change any behavior,
but if your system depends on udev, please always test it before reboot :)

We pass only one generic structure around between add, remove,
namedev, db and dev_d handling and make all relevant data available
to all internal stages. All udev structures are renamed to "udev".

We replace the fake parameter by a flag in the udev structure.

We open the class device in the main binaries and not in udev_add, to
make it possible to use libsysfs for udevstart directory crawling.

The last sleep parameters are removed.
2005-04-26 22:02:46 -07:00
docs [PATCH] Writing udev rules doc update 2005-04-26 21:36:21 -07:00
etc [PATCH] add debian config files. 2005-04-26 22:02:45 -07:00
extras [PATCH] big cleanup of internal udev api 2005-04-26 22:02:46 -07:00
klibc [PATCH] fix up Makefiles to get the klibc build working properly. 2005-04-26 21:37:02 -07:00
libsysfs [PATCH] get rid of annoying extra lines in the syslog for some libsysfs debug messages. 2005-04-26 21:37:03 -07:00
tdb [PATCH] fix compilation warning in tdb log message. 2005-04-26 21:58:15 -07:00
test [PATCH] big cleanup of internal udev api 2005-04-26 22:02:46 -07:00
ccdv.c [PATCH] tweak the ccdv program to handle files in subdirectories being built. 2005-04-26 22:02:44 -07:00
ChangeLog [PATCH] 039 release 2005-04-26 22:02:45 -07:00
COPYING [PATCH] added initial documentation and gpl license 2005-04-26 21:00:32 -07:00
dev_d.c [PATCH] big cleanup of internal udev api 2005-04-26 22:02:46 -07:00
FAQ [PATCH] Update the FAQ with info about hardlink security 2005-04-26 21:36:59 -07:00
HOWTO-udev_for_dev [PATCH] fix HOWTO-udev_for_dev for udevdir 2005-04-26 21:35:10 -07:00
klibc_fixups.c [PATCH] udev - read long lines from config files overflow fix 2005-04-26 21:37:00 -07:00
klibc_fixups.h [PATCH] catchup with recent klibc 2005-04-26 21:35:47 -07:00
list.h [PATCH] Initial namedev parsing of config files 2005-04-26 21:01:38 -07:00
logging.h [PATCH] close the syslog 2005-04-26 22:02:45 -07:00
make_gcov.sh [PATCH] add scripts to run gcov for udev from Leann Ogasawara <ogasawara@osdl.org> 2005-04-26 21:35:15 -07:00
Makefile [PATCH] 039 release 2005-04-26 22:02:45 -07:00
namedev_parse.c [PATCH] fix udev segfaults with bad permissions file 2005-04-26 21:37:01 -07:00
namedev.c [PATCH] big cleanup of internal udev api 2005-04-26 22:02:46 -07:00
namedev.h [PATCH] big cleanup of internal udev api 2005-04-26 22:02:46 -07:00
README [PATCH] add USE_SELINUX to README documentation so people have a chance to see what is going on. 2005-04-26 21:37:02 -07:00
README-gcov_for_udev [PATCH] gcov for udev 2005-04-26 21:35:16 -07:00
run_gcov.sh [PATCH] add scripts to run gcov for udev from Leann Ogasawara <ogasawara@osdl.org> 2005-04-26 21:35:15 -07:00
selinux.h [PATCH] update the selinux.h file to start to look sane 2005-04-26 21:37:02 -07:00
TODO [PATCH] update the TODO list as we already have a devfs config file. 2005-04-26 21:35:07 -07:00
udev_add.c [PATCH] big cleanup of internal udev api 2005-04-26 22:02:46 -07:00
udev_config.c [PATCH] remove sleeps from udev as it is external now 2005-04-26 22:02:44 -07:00
udev_lib.c [PATCH] big cleanup of internal udev api 2005-04-26 22:02:46 -07:00
udev_lib.h [PATCH] big cleanup of internal udev api 2005-04-26 22:02:46 -07:00
udev_remove.c [PATCH] big cleanup of internal udev api 2005-04-26 22:02:46 -07:00
udev.8.in [PATCH] remove sleeps from udev as it is external now 2005-04-26 22:02:44 -07:00
udev.c [PATCH] big cleanup of internal udev api 2005-04-26 22:02:46 -07:00
udev.h [PATCH] big cleanup of internal udev api 2005-04-26 22:02:46 -07:00
udev.spec [PATCH] 039 release 2005-04-26 22:02:45 -07:00
udevd.8 [PATCH] fix manpages based on esr's spambot 2005-04-26 21:36:59 -07:00
udevd.c [PATCH] close the syslog 2005-04-26 22:02:45 -07:00
udevd.h [PATCH] switch udev's seqnum to u64 2005-04-26 21:37:01 -07:00
udevdb.c [PATCH] big cleanup of internal udev api 2005-04-26 22:02:46 -07:00
udevdb.h [PATCH] big cleanup of internal udev api 2005-04-26 22:02:46 -07:00
udevinfo.8 [PATCH] update bk ignore list some more. 2005-04-26 21:35:14 -07:00
udevinfo.c [PATCH] big cleanup of internal udev api 2005-04-26 22:02:46 -07:00
udevruler.c [PATCH] handle netdev in udevruler 2005-04-26 21:35:14 -07:00
udevsend.c [PATCH] close the syslog 2005-04-26 22:02:45 -07:00
udevstart.8 [PATCH] update bk ignore list some more. 2005-04-26 21:35:14 -07:00
udevstart.c [PATCH] big cleanup of internal udev api 2005-04-26 22:02:46 -07:00
udevtest.8 [PATCH] update bk ignore list some more. 2005-04-26 21:35:14 -07:00
udevtest.c [PATCH] big cleanup of internal udev api 2005-04-26 22:02:46 -07:00
wait_for_sysfs.c [PATCH] don't wait for dummy devices 2005-04-26 22:02:45 -07:00

udev - a userspace implementation of devfs

For more information on the design, and structure of this project, see the
files in the docs/ directory.

To use:

- You must be running a 2.6 version of the Linux kernel.

- Your 2.6 kernel must have had CONFIG_HOTPLUG enabled when it was built.

- Make sure sysfs is mounted.  udev will figure out where sysfs is mounted, but
  the traditional place for it is at /sys.  You can mount it by hand by running:
  	mount -t sysfs none /sys

- Make sure you have the latest version of the linux-hotplug scripts.  They are
  available at linux-hotplug.sf.net or from your local kernel.org mirror at:
	kernel.org/pub/linux/utils/kernel/hotplug/
  They are required in order for udev to work properly.

  If for some reason you do not install the hotplug scripts, you must tell the
  kernel to point the hotplug binary at wherever you install udev at.  This can
  be done by:
	echo "/sbin/udev" > /proc/sys/kernel/hotplug

- Build the project:
	make

  Note:
      There are a number of different flags that you can use when building
      udev.  They are as follows:
	prefix
		set this to the default root that you want udev to be
		installed into.  This works just like the 'configure --prefix'
		script does.  Default value is ''.  Only override this if you
		really know what you are doing.
	USE_KLIBC
		if set to 'true', udev is built and linked against the
		included version of klibc.  Default value is 'false'.
	USE_LOG
		if set to 'true', udev will emit messages to the syslog when
		it creates or removes device nodes.  This is helpful to see
		what udev is doing.  This is enabled by default.  Note, if you
		are building udev against klibc it is recommended that you
		disable this option (due to klibc's syslog implementation.)
	USE_SELINUX
		if set to 'true', udev will be built with SELinux support
		enabled.  This is disabled by default.
	DEBUG
		if set to 'true', debugging messages will be sent to the syslog
		as udev is run.  Default value is 'false'.
	KERNEL_DIR
		If this is not set it will default to /lib/modules/`uname -r`/build
		This is used if USE_KLIBC=true to find the kernel include
		directory that klibc needs to build against.  This must be set
		if you are not building udev while running a 2.6 kernel.

      So, if you want to build udev using klibc with debugging messages, you
      would do:
	make USE_KLIBC=true DEBUG=true

- Install the project:
	make install

  This will put the udev binary in /sbin, create the /udev and /etc/udev
  directories, and place the udev configuration files in /etc/udev.  You
  will probably want to edit the namedev.* files to create custom naming
  rules.  More info on how the config files are set up are contained in
  comments in the files, and is located in the documentation.

- Add and remove devices from the system and marvel as nodes are created
  and removed in /udev/ based on the device types.

- If you later get sick of it, uninstall it:
	make uninstall


Things are still quite rough, but it should work properly.  If nothing
seems to happen, make sure your build worked properly by running the
udev-test.pl script as root in the test/ subdirectory of the udev source
tree.

Development and documentation help is very much appreciated, see the TODO
file for a list of things left to be done.


Any comment/questions/concerns please let me and the other udev developers
know by sending a message to the linux-hotplug-devel mailing list at:
	linux-hotplug-devel@lists.sourceforge.net

greg k-h
greg@kroah.com