]> git.sesse.net Git - betaftpd/commitdiff
process_all_clients(): Fixed a bug (reporting and much tracing by Sean MacLennan...
authorsgunderson <sgunderson>
Thu, 17 Aug 2000 22:59:14 +0000 (22:59 +0000)
committersgunderson <sgunderson>
Thu, 17 Aug 2000 22:59:14 +0000 (22:59 +0000)
ftpd.c

diff --git a/ftpd.c b/ftpd.c
index 4d65210591c26c260d2c864dd5913c14c7dfdf0e..757c109e677d88091e8b513e9f16124f27d1e695 100644 (file)
--- a/ftpd.c
+++ b/ftpd.c
@@ -579,11 +579,7 @@ int process_all_clients(const fd_set * const active_clients, const int num_ac)
                c = next;
                next = c->next_conn;
 #if HAVE_POLL
-               if (fds[c->sock].revents & (POLLERR|POLLHUP|POLLNVAL)) {
-                       destroy_conn(c);
-                       continue;
-               }
-               if (!fds[c->sock].revents & POLLIN) {
+               if (!fds[c->sock].revents & (POLLIN|POLLERR|POLLHUP|POLLNVAL)) {
                        continue;
                }
 #else
@@ -603,8 +599,10 @@ int process_all_clients(const fd_set * const active_clients, const int num_ac)
                         * client has closed the socket. If we get a return value
                         * of -1 (error), we close the socket ourselves.
                         *
-                        * Just to be safe, we include this code for poll() as
-                        * well.
+                        * We do the same for poll(), even though we actually have
+                        * bits that tell us what is happening (in case of new 
+                        * input AND error/hangup at the same time, we do an
+                        * explicit check at the bottom of the loop as well).
                         */
                        destroy_conn(c);
                        continue;
@@ -619,6 +617,11 @@ int process_all_clients(const fd_set * const active_clients, const int num_ac)
 
                c->buf_len += bytes_avail;
                parse_command(c);
+
+               if (fds[c->sock].revents & (POLLERR|POLLHUP|POLLNVAL)) {
+                        destroy_conn(c);
+                        continue;
+                }
        }
        return checked_through;
 }