Ninjatrappeur's systemd working tree
Go to file
kay.sievers@vrfy.org 7fafc03242 [PATCH] spilt udev into pieces
On Thu, Jan 22, 2004 at 01:27:45AM +0100, Kay Sievers wrote:
> On Wed, Jan 21, 2004 at 02:38:25PM +0100, Kay Sievers wrote:
> > On Thu, Jan 15, 2004 at 01:45:10PM -0800, Greg KH wrote:
> > > On Thu, Jan 15, 2004 at 10:36:25PM +0800, Ling, Xiaofeng wrote:
> > > > Hi, Greg
> > > >    I wrote a simple implementation for the two pieces
> > > > of send and receive hotplug event,
> > > > use a message queue and a list for the out of order
> > > >  hotplug event. It also has a timeout timer of 3 seconds.
> > > >  They are now separate program. the file nseq is the test script.
> > > >  Could you have a look to see wether it is feasible?
> > > > If so, I'll continue to merge with udev.
> > >
> > > Yes, very nice start.  Please continue on.
> > >
> > > One minor comment, please stick with the kernel coding style when you
> > > are writing new code for udev.
> >
> > I took the code from Xiaofeng, cleaned the whitespace, renamed some bits,
> > tweaked the debugging, added the udev exec and created a patch for the current tree.
> >
> > It seems functional now, by simply executing our current udev (dirty hack).
> > It reorders the incoming events and if one is missing it delays the
> > execution of the following ones up to a maximum of 10 seconds.
> >
> > Test script is included, but you can't mix hotplug sequence numbers and
> > test script numbers, it will result in waiting for the missing numbers :)
>
> Hey, nobody want's to play with me?
> So here I'm chatting with myself :)
>
> This is the next version with signal handling for resetting the expected
> signal number. I changed the behaviour of the timeout to skip all
> missing events at once and to proceed with the next event in the queue.
>
> So it's now possible to use the test script at any time, cause it resets
> the daemon, if real hotplug event coming in later all missing nimbers will
> be skipped after a timeout of 10 seconds and the queued events are applied.

Here is the next updated updated version to apply to the lastet udev.
I've added infrastructure for getting the state of the IPC queue in the
sender and set the program to exec by the daemon. Also the magic key id
is replaced by the usual key generation by path/nr.

It looks promising, I use it on my machine and my 4in1 USB-flash-reader
connect/disconnect emits the events "randomly" but udevd is able to
reorder it and calls our normal udev in the right order.
2005-04-26 21:13:17 -07:00
docs [PATCH] minor grammer fixes for the udev_vs_devfs document 2005-04-26 21:13:14 -07:00
etc [PATCH] set default owner/group in db - update 2005-04-26 21:13:17 -07:00
extras [PATCH] udev-013/extras/multipath update 2005-04-26 21:13:17 -07:00
klibc [PATCH] sync klibc with release 0.95 2005-04-26 21:13:08 -07:00
libsysfs [PATCH] libsysfs update for refresh + namedev.c changes 2005-04-26 21:13:16 -07:00
tdb [PATCH] signal fixes due to klibc update. 2005-04-26 21:13:08 -07:00
test [PATCH] spilt udev into pieces 2005-04-26 21:13:17 -07:00
COPYING [PATCH] added initial documentation and gpl license 2005-04-26 21:00:32 -07:00
ChangeLog [PATCH] 014 release 2005-04-26 21:13:17 -07:00
FAQ [PATCH] update the FAQ with info about bad modprobe events from the devfs scheme... 2005-04-26 21:13:08 -07:00
Makefile [PATCH] spilt udev into pieces 2005-04-26 21:13:17 -07:00
README [PATCH] clean up the logging patch a bit to make the option more like the other options. 2005-04-26 21:13:17 -07:00
TODO [PATCH] remove TODO item about BUS value, as it is now done. 2005-04-26 21:13:17 -07:00
klibc_fixups.c [PATCH] get rid of functions in klibc_fixups that are now in klibc 2005-04-26 21:13:02 -07:00
klibc_fixups.h [PATCH] udev - exec status fix for klibc 2005-04-26 21:13:14 -07:00
list.h [PATCH] Initial namedev parsing of config files 2005-04-26 21:01:38 -07:00
logging.c [PATCH] add udev logging to info log 2005-04-26 21:13:17 -07:00
logging.h [PATCH] misc code cleanups. 2005-04-26 21:13:17 -07:00
namedev.c [PATCH] add support for figuring out which device on the sysfs "chain" the rule applies to. 2005-04-26 21:13:17 -07:00
namedev.h [PATCH] add udev logging to info log 2005-04-26 21:13:17 -07:00
namedev_parse.c [PATCH] misc code cleanups. 2005-04-26 21:13:17 -07:00
udev-add.c [PATCH] set default owner/group in db - update 2005-04-26 21:13:17 -07:00
udev-remove.c [PATCH] add udev logging to info log 2005-04-26 21:13:17 -07:00
udev.8 [PATCH] set default owner/group in db - update 2005-04-26 21:13:17 -07:00
udev.c [PATCH] udev - reverse user query options 2005-04-26 21:13:17 -07:00
udev.h [PATCH] set default owner/group in db - update 2005-04-26 21:13:17 -07:00
udev.spec [PATCH] 014_bk mark 2005-04-26 21:13:17 -07:00
udev_config.c [PATCH] set default owner/group in db - update 2005-04-26 21:13:17 -07:00
udev_dbus.c [PATCH] fix formatting of udev_dbus.c to use tabs. Also get it to build properly now. 2005-04-26 21:13:06 -07:00
udev_dbus.h [PATCH] move all of the DBUS logic into one file and remove all of the #ifdef crud from the main code. 2005-04-26 21:13:06 -07:00
udevd.c [PATCH] spilt udev into pieces 2005-04-26 21:13:17 -07:00
udevd.h [PATCH] spilt udev into pieces 2005-04-26 21:13:17 -07:00
udevdb.c [PATCH] udev - reverse user query options 2005-04-26 21:13:17 -07:00
udevdb.h [PATCH] udev - reverse user query options 2005-04-26 21:13:17 -07:00
udevsend.c [PATCH] spilt udev into pieces 2005-04-26 21:13:17 -07:00

README

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_DBUS
		if set to 'true', DBUS messages will be sent everytime udev
		creates or removes a device node.  This requires that DBUS
		development headers and libraries be present on your system to
		build properly.  Default value is 'false'.
	DEBUG
		if set to 'true', debugging messages will be sent to the syslog
		as udev is run.  Default value is 'false'.

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

      Note: If you want to use klibc, you will have to set up the "linux"
            symlink properly.  See the file klibc/klibc/README and pay
	    attention to step "a)" there.

- 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