summaryrefslogtreecommitdiff
path: root/lib/network.c
diff options
context:
space:
mode:
authorDonald Sharp <sharpd@cumulusnetworks.com>2017-01-27 11:44:42 -0500
committerDonald Sharp <sharpd@cumulusnetworks.com>2017-01-27 11:44:42 -0500
commitc016b6c796fe3a8520fdd0f30ef377cbb73e0037 (patch)
tree78c3b29b41860c367390bba20a4a4d16fbaf3469 /lib/network.c
parent75688c44d98af271ca4eb4f3133ede9e7ae709bb (diff)
parentaceb2285dad63dca7bba7177012aabdb63e1cca5 (diff)
Merge remote-tracking branch 'origin/master' into pr/111
Diffstat (limited to 'lib/network.c')
-rw-r--r--lib/network.c9
1 files changed, 7 insertions, 2 deletions
diff --git a/lib/network.c b/lib/network.c
index 506e019136..2b6f2fbab5 100644
--- a/lib/network.c
+++ b/lib/network.c
@@ -62,8 +62,13 @@ writen(int fd, const u_char *ptr, int nbytes)
while (nleft > 0)
{
nwritten = write(fd, ptr, nleft);
-
- if (nwritten <= 0)
+
+ if (nwritten < 0)
+ {
+ if (!ERRNO_IO_RETRY(errno))
+ return nwritten;
+ }
+ if (nwritten == 0)
return (nwritten);
nleft -= nwritten;