+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
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));