From 57b394b50579feeee90a4cb12243d5785a9176a6 Mon Sep 17 00:00:00 2001 From: Lennart Poettering Date: Mon, 9 Mar 2015 19:41:01 +0100 Subject: [PATCH] fsckd: make sure we free the connection event source before we close the connection fd --- src/fsckd/fsckd.c | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/src/fsckd/fsckd.c b/src/fsckd/fsckd.c index 4851b9275..1415b53dd 100644 --- a/src/fsckd/fsckd.c +++ b/src/fsckd/fsckd.c @@ -77,7 +77,9 @@ typedef struct Manager { unsigned n_clients; int clear; + int connection_fd; + sd_event_source *connection_event_source; FILE *console; double percent; @@ -444,6 +446,7 @@ static void manager_free(Manager *m) { fflush(m->console); } + sd_event_source_unref(m->connection_event_source); safe_close(m->connection_fd); while (m->clients) @@ -483,7 +486,7 @@ static int manager_new(Manager **ret, int fd) { return -errno; } - r = sd_event_add_io(m->event, NULL, fd, EPOLLIN, manager_new_connection_handler, m); + r = sd_event_add_io(m->event, &m->connection_event_source, fd, EPOLLIN, manager_new_connection_handler, m); if (r < 0) return r; -- 2.30.2