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 | |
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).
-rw-r--r-- | lib/ChangeLog | 5 | ||||
-rw-r--r-- | lib/network.c | 12 |
2 files changed, 16 insertions, 1 deletions
diff --git a/lib/ChangeLog b/lib/ChangeLog index ee024389..0627d206 100644 --- a/lib/ChangeLog +++ b/lib/ChangeLog @@ -1,3 +1,8 @@ +2005-02-16 Andrew J. Schorr <ajschorr@alumni.princeton.edu> + + * network.c: (set_nonblocking) Should check return code from + fcntl(F_GETFL). + 2005-02-15 Andrew J. Schorr <ajschorr@alumni.princeton.edu> * network.h: Declare new function set_nonblocking. Indicate that 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)); |