Re: devfs vs udev, thoughts from a devfs user

From: Greg KH
Date: Fri Feb 13 2004 - 16:23:59 EST


On Tue, Feb 10, 2004 at 10:29:44AM -0800, Mike Bell wrote:
> On Tue, Feb 10, 2004 at 10:12:42AM -0800, Greg KH wrote:
> > No, that is not true. devfs exports the device node itself. It does
> > not just export the major:minor number.
>
> That's a pretty minor difference, from the kernel's point of view. It's
> basically putting the same numbers in different fields.

Heh, that's a HUGE difference!

I think you are missing a few things here:
- sysfs is not only for exporting device major:minor info. It's for a
1001 other very useful things. You can't config out sysfs, you get
it for "free" with 2.6. So it isn't a "choose sysfs vs. devfs"
argument at all. It's a "do I want to enable devfs or not" issue.

- sysfs exports loads of info about every device in your system, not
only the major:minor info. It exports what device this major:minor
is assigned to, the topology of the device, the fact that it has
vendor id FOO and product id BAR, and serial number "123". devfs has
none of this.

- you get /sbin/hotplug calls for "free" too. Yes, you can config this
out, but the added benefits of hotplug calls far outweigh any memory
savings you get for not enabling this option (embedded systems not
included.)

So, if you put hotplug and sysfs together, udev can control your /dev.
And it can provide persistent device naming, which on its own, devfs can
not.

Again, the fact that udev can do everything devfs can (manage a /dev),
in userspace, and in less memory, is a big win in my eyes.

Oh, and recall that I implemented a "dynamic /dev" with LSB names almost
a year ago, in 6Kb of userspace code. The amount of memory that this
takes for devfs to do I don't really want to imagine...

> > devfs also does not export the position within the entire device tree,
> > which sysfs does.
>
> devfs tried to do just that. sysfs does it better though. I don't see
> what that has to do with my point.

persistent device names... That's the main point of udev.

> > They are two completely different filesystems, doing two completely
> > different things. Please do not confuse them.
>
> sysfs and devfs are very different. I said they both accomplish one
> common goal, sysfs for udev and devfs for devfsd.

Not at all. sysfs has 1001 goals at the least. So many different
people are using it for different things that it's really amazing to me.
It also shows how powerful and how correct the model of it is.

And as stated above, you always get sysfs in your kernel (unless you are
running the -tiny tree...)

I'm not going to try to answer all of your other questions specifically,
as I think I have covered them all now. If you feel that you still have
some questions remaining about this, or that I have not explained
anything good enough, please let me know.

thanks,

greg k-h
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/