Commit f508ed40 authored by Rusty Russell's avatar Rusty Russell

io: Fix bug where duplex connection is last fd, when another gets deleted.

Signed-off-by: default avatarRusty Russell <rusty@rustcorp.com.au>
parent 5a510ed5
...@@ -105,6 +105,14 @@ static void del_fd(struct fd *fd) ...@@ -105,6 +105,14 @@ static void del_fd(struct fd *fd)
fds[n] = fds[num_fds-1]; fds[n] = fds[num_fds-1];
assert(fds[n]->backend_info == num_fds-1); assert(fds[n]->backend_info == num_fds-1);
fds[n]->backend_info = n; fds[n]->backend_info = n;
/* If that happens to be a duplex, move that too. */
if (!fds[n]->listener) {
struct io_conn *c = (void *)fds[n];
if (c->duplex) {
assert(c->duplex->fd.backend_info == num_fds-1);
c->duplex->fd.backend_info = n;
}
}
} else if (num_fds == 1) { } else if (num_fds == 1) {
/* Free everything when no more fds. */ /* Free everything when no more fds. */
io_alloc.free(pollfds); io_alloc.free(pollfds);
...@@ -184,6 +192,7 @@ void backend_del_conn(struct io_conn *conn) ...@@ -184,6 +192,7 @@ void backend_del_conn(struct io_conn *conn)
io_alloc.free(conn->timeout); io_alloc.free(conn->timeout);
if (conn->duplex) { if (conn->duplex) {
/* In case fds[] pointed to the other one. */ /* In case fds[] pointed to the other one. */
assert(conn->duplex->fd.backend_info == conn->fd.backend_info);
fds[conn->fd.backend_info] = &conn->duplex->fd; fds[conn->fd.backend_info] = &conn->duplex->fd;
conn->duplex->duplex = NULL; conn->duplex->duplex = NULL;
conn->fd.backend_info = -1; conn->fd.backend_info = -1;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment