Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 8 Aug 2008 15:51:21 -0700 (PDT)
From:      Nate Eldredge <neldredge@math.ucsd.edu>
To:        Chuck Robey <chuckr@telenix.org>
Cc:        "Carlos A. M. dos Santos" <unixmania@gmail.com>, Pieter de Goeje <pieter@degoeje.nl>, Nate Eldredge <neldredge@math.ucsd.edu>, freebsd-hackers@freebsd.org
Subject:   Re: read with timeout ??
Message-ID:  <Pine.GSO.4.64.0808081545570.11980@zeno.ucsd.edu>
In-Reply-To: <489CAC2F.1070907@telenix.org>
References:  <489B9D4D.4010009@telenix.org> <Pine.GSO.4.64.0808071813530.11980@zeno.ucsd.edu> <e71790db0808071950j32e196e4o42fab1aeb62ab8a4@mail.gmail.com> <200808081009.56521.pieter@degoeje.nl> <489CAC2F.1070907@telenix.org>

next in thread | previous in thread | raw e-mail | index | archive | help
On Fri, 8 Aug 2008, Chuck Robey wrote:

> -----BEGIN PGP SIGNED MESSAGE-----
> Hash: SHA1
>
> Pieter de Goeje wrote:
>>
>> I think poll(2) is also simpler than select for this purpose.
>>
>
> It does look like that, I need to check the implementation a bit, because the
> name of this thing makes me really suspicious about how often it checks for an
> fd for being ready for a read.  I know select comes right back, I was under the
> impression that poll didn't use signals to do this.

AFAIK the effects are identical, just the arguments are set up in a 
different way.  Both of them will block until the fd is ready and then 
return "immediately" (subject to other processes running of course).  The 
name "poll" is a misnomer because it doesn't actually work by polling, 
but you can pretend that it does (and does so "infinitely often"). 
Neither one uses signals per se, though if the underlying hardware device 
is interrupt-driven, that will be what (indirectly) triggers the wake-up.

poll does seem to be more convenient than messing about with fd_set's. 
select is older and so it comes to my mind first, that's all.

-- 

Nate Eldredge
neldredge@math.ucsd.edu



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?Pine.GSO.4.64.0808081545570.11980>