]> git.ipfire.org Git - thirdparty/krb5.git/commitdiff
Properly handle EOF condition on libkrad sockets
authorNathaniel McCallum <npmccallum@redhat.com>
Fri, 30 Sep 2016 14:03:33 +0000 (10:03 -0400)
committerTom Yu <tlyu@mit.edu>
Mon, 24 Oct 2016 19:38:13 +0000 (15:38 -0400)
In the previous code, when the remote peer performed an orderly shutdown
on the socket, libkrad would enter a state in which all future requests
timed out.  Instead, if the peer shuts down its socket, we need to
attempt to reopen it.

(cherry picked from commit 248497427d5a45225817b6c22e9224e8ad969872)

ticket: 8504
version_fixed: 1.14.5

src/lib/krad/remote.c

index df3de3ad2255be4138544fdf77d0af6de7bb1277..68cd16ff395f5e92cb6a62d5b3be73b675d2f61f 100644 (file)
@@ -329,16 +329,15 @@ on_io_read(krad_remote *rr)
     /* Read the packet. */
     i = recv(verto_get_fd(rr->io), rr->buffer.data + rr->buffer.length,
              pktlen, 0);
-    if (i < 0) {
-        /* Should we try again? */
-        if (errno == EWOULDBLOCK || errno == EAGAIN || errno == EINTR)
-            return;
 
-        /* The socket is unrecoverable. */
+    /* On these errors, try again. */
+    if (i < 0 && (errno == EWOULDBLOCK || errno == EAGAIN || errno == EINTR))
+        return;
+
+    /* On any other errors or on EOF, the socket is unrecoverable. */
+    if (i <= 0) {
         remote_shutdown(rr);
         return;
-    } else if (i == 0) {
-        remote_del_flags(rr, FLAGS_READ);
     }
 
     /* If we have a partial read or just the header, try again. */