Unexpected soft update inconsistency
    Cedric Berger 
    cedric at berger.to
       
    Mon Jun 12 01:19:01 PDT 2006
    
    
  
Matthew Dillon wrote:
:    (2) new system call entry points for non-blocking read and write, then
:	libc_r can completely ignore FNONBLOCK and just use the new entry
:	points.
:
:    Otherwise this little problem is going to bite us over and over again
:    as time passes.
:
:    I'm thinking (2) might be the only real solution.
    Something like this:
    nbpread(int d, void *buf, size_t nbytes, off_t offset)
    nbpread(int d, const void *buf, size_t nbytes, off_t offset)
    (same arguments as pread/pwrite).  offset can be -1, indicating that the
    current offset should be used and updated.  The function would perform
    the operation non-blocking regardless of the non blocking setting on the
    file pointer.
    libc_r would then use the new entry points and would not mess with
    the non-blocking flag on the FP at all.
That would be fantastic.
I've banged my head with this problem often enough.
And I'm not the only one, of course:
http://cr.yp.to/unix/nonblock.html
Cedric
    
    
More information about the Bugs
mailing list