[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20090422015228.GA13312@bx9.net>
Date: Tue, 21 Apr 2009 18:52:28 -0700
From: Greg Lindahl <greg@...kko.com>
To: David Miller <davem@...emloft.net>
Cc: penguin-kernel@...ove.sakura.ne.jp, paul.moore@...com,
linux-security-module@...r.kernel.org, netdev@...r.kernel.org
Subject: Re: [PATCH] LSM: Add security_socket_post_accept() and
security_socket_post_recv_datagram().
On Tue, Apr 21, 2009 at 06:14:11PM -0700, David Miller wrote:
> We had a similar situation with read()'s on UDP sockets.
>
> When poll() says something, it has to stick.
Isn't that completely different? Anyone who writes code that calls
accept() quickly finds out that in the real world it fails for all
kinds of reasons worth ignoring. As an example, a comment in ircd at
the only accept call (circa 1998):
/*
** There may be many reasons for error return, but in otherwise
** correctly working environment the probable cause is running
** out of file descriptors (EMFILE, ENFILE or others?). The
** man pages for accept don't seem to list these as possible,
** although it's obvious that it may happen here.
** Thus no specific errors are tested at this point, just
** assume that connections cannot be accepted until some old
** is closed first.
*/
And it silently ignores EAGAIN, which of course is a can't happen when
used with select(). The recently-written only-runs-on-Linux system I'm
working on ignores EAGAIN, even though it's a can't happen with
epoll. I can ask the guy who wrote it, but he's probably ignoring it
because he was frequently seeing them.
I'd be surprised if you found much real-life code that didn't
gracefully tolerate accept failures. Can anyone come up with an
example?
-- greg
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists