RE: SELECT() returns 1 But FIONREAD says (Input/output error)
From: David Schwartz
Date:  Fri Jun 01 2007 - 12:43:39 EST
> David Schwartz wrote:
> > Nope. An errored connection is always ready for read/write -- there is
> > nothing to wait for as far as the kernel is concerned. Your code keeps
> > asking the kernel if something interesting has happened, the
> > kernel keeps
> > telling it yes, and it refuses to do anything about it.
> The select() returns because i pulled the USB cable from hub. Seems
> reasonable.
Good. Then there is nothing further to discuss.
> The next select() found what? to be interesting in order to prematurely
> terminate the select-wait? As far as I can tell, nothing interesting has
> happened since the previous select(). In this case the select() is only
> looking at read()'s.
You have a very serious misunderstanding of what 'select' does. The 'select'
function is level triggered and state based, not edge triggered or event
based. The situation was the same as before, and so the same result is
required.
The kernel assumes that either you handled the error condition or you aren't
going to handle the error condition. In either case, the correct thing to do
is to again inform you of the error.
Suppose the first 'select' comes from code that is just curious how many
sockets are ready but has no intention of handling the events. Not reporting
the error on the next call to 'select' would be disastrous.
DS
-
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/