On Wed, Nov 03, 2010 at 10:38:33AM -0600, Eric Blake wrote:
On 11/03/2010 07:23 AM, Daniel P. Berrange wrote:
>> I was wondering about reusing saferead/write but they have a different
>> semantic on blocking,
>
> Yep, saferead/write cannot be used on any FD with O_NONBLOCK
> set, because they'll just spin in a 100% CPU loop whenever
> EAGAIN occurs, until they get nbytes worth of data.
Is it worth teaching saferead/write to use fcntl() to determine if an fd
is O_NONBLOCK? And if so, should it outright reject an O_NONBLOCK fd
(to help us diagnose bugs) or be documented as allowing an EAGAIN
failure on non-blocking fds?
The API design doesn't lend itself to this, because it would result in
a horribly inefficient way of reading data
fcntl(fd)
read(fd, buf, 1024);
fcntl(fd)
read(fd, buf, 1024);
fcntl(fd)
read(fd, buf, 1024);
fcntl(fd)
read(fd, buf, 1024);
fcntl(fd)
read(fd, buf, 1024);
fcntl(fd)
read(fd, buf, 1024);
fcntl(fd)
read(fd, buf, 1024);
...
Daniel
--
|: Red Hat, Engineering, London -o-
http://people.redhat.com/berrange/ :|
|:
http://libvirt.org -o-
http://virt-manager.org -o-
http://deltacloud.org :|
|:
http://autobuild.org -o-
http://search.cpan.org/~danberr/ :|
|: GnuPG: 7D3B9505 -o- F3C9 553F A1DA 4AC2 5648 23C1 B3DF F742 7D3B 9505 :|