Subject: Re: Time to fix a 25 year old misdesign
To: None <firstname.lastname@example.org>
From: Greg A. Woods <email@example.com>
Date: 10/15/2000 14:10:37
[ On Sunday, October 15, 2000 at 19:36:09 (+0200), Lennart Augustsson wrote: ]
> Subject: Re: Time to fix a 25 year old misdesign
> Thinking some more about my proposal I realize that it is flawed.
> The problem is that it is not only the open() system call that generates
> an extra reference to a device vnode, but also for().
Indeed. I was going to point that out next, but Matt beat me to it! :-)
> This means that with my scheme there would (potentially) be more
> calls to dev_close() than dev_open(), which is also broken.
Not just fork() but, as Matt says, dup() and FD-passing too.
> This could be fixed by introducing a device method that is called when
> the reference count is increased (e.g. by fork). But now its starts to
> get unelegant...
There's also really no need either since with a correct driver design
that separates functionality out logically to separate /dev files
(i.e. with different minor numbers) will eliminate the need for such
uglyness in the driver.
Changing this very fundamental part of the Unix I/O system design would
have potentially far reaching implications that could "break" many more
things than it is intended to fix (thus the elegance of the current
Greg A. Woods
+1 416 218-0098 VE3TCP <firstname.lastname@example.org> <robohack!woods>
Planix, Inc. <email@example.com>; Secrets of the Weird <firstname.lastname@example.org>