diff options
| author | ajs <ajs> | 2005-02-16 16:25:39 +0000 | 
|---|---|---|
| committer | ajs <ajs> | 2005-02-16 16:25:39 +0000 | 
| commit | 42218e71256cb86b5078c99c931030c7b0ce9bab (patch) | |
| tree | 32331f692e292f258b295727d2f2467617fe80ba /lib/network.c | |
| parent | a269d613fe0536a01eb86367a545e337e51d1309 (diff) | |
2005-02-16 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
	* network.c: (set_nonblocking) Should check return code from
	  fcntl(F_GETFL).
Diffstat (limited to 'lib/network.c')
| -rw-r--r-- | lib/network.c | 12 | 
1 files changed, 11 insertions, 1 deletions
| diff --git a/lib/network.c b/lib/network.c index 3b296720..3373983b 100644 --- a/lib/network.c +++ b/lib/network.c @@ -75,7 +75,17 @@ writen(int fd, const u_char *ptr, int nbytes)  int  set_nonblocking(int fd)  { -  if (fcntl(fd, F_SETFL, (fcntl(fd, F_GETFL) | O_NONBLOCK)) < 0) +  int flags; + +  /* According to the Single UNIX Spec, the return value for F_GETFL should +     never be negative. */ +  if ((flags = fcntl(fd, F_GETFL)) < 0) +    { +      zlog_warn("fcntl(F_GETFL) failed for fd %d: %s", +      		fd, safe_strerror(errno)); +      return -1; +    } +  if (fcntl(fd, F_SETFL, (flags | O_NONBLOCK)) < 0)      {        zlog_warn("fcntl failed setting fd %d non-blocking: %s",        		fd, safe_strerror(errno)); | 
