Re: [patch 7/8] fdmap v2 - implement sys_socket2

From: Davide Libenzi
Date: Sun Jun 10 2007 - 15:16:50 EST


On Sun, 10 Jun 2007, Paul Mackerras wrote:

> > for (i = 0; i < NR_OPEN; i++)
> > if (!fd_is_special_to_us(i))
> > close(i);
> >
> > Note that this is conceptually buggy, but occurs in several major C
> > programming books, most of the major shells, and a lot of other
> > software to boot.
>
> Buggy in what way? In the use of the NR_OPEN constant?

That is buggy because the code assumes it is the only owner of the fd
space. Thing that is not true if runtimes have opened their own file
descriptors to handle their own links to the kernel.
The syslog case is kinda bogus. For certain things, you can afford a retry
policy (assuming somone else did not open another fd over the fd that you
cached - then it's gonna be fun). It is crappy, but it *may* work. Sure
is, does not fit any definition of "reliable" I'm aware of.
Think about a runtime that had an epoll fd open and a few fds dropped into
it to, say, deliver some sort of events to the application. After the
Close Loop of Death, the whole thing is gone.
As is, runtimes cannot reliably use (cached) fds for their own internal
communication with the kernel. That, I think we can agree it is a fact.
We can then say that we do not care if runtimes cannot reliably use fds,
and move on. But it's hard to say that the problem does not exist.



- Davide


-
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/