aboutsummaryrefslogtreecommitdiff
path: root/seatd
diff options
context:
space:
mode:
authorKenny Levinsen <kl@kl.wtf>2020-08-31 22:44:02 +0200
committerKenny Levinsen <kl@kl.wtf>2020-08-31 23:13:16 +0200
commit5b8117f3d4ad767e5ddb8e202c938bc2e0174ffb (patch)
tree33192ba1acf09f19ec7b9a35e3e96358ae25741d /seatd
parentc9ce7c71aa80769033b556d1c486da81c2fda551 (diff)
client: Do not leak idle clients on exit
Diffstat (limited to 'seatd')
-rw-r--r--seatd/client.c2
-rw-r--r--seatd/server.c7
2 files changed, 9 insertions, 0 deletions
diff --git a/seatd/client.c b/seatd/client.c
index d658454..bd46a86 100644
--- a/seatd/client.c
+++ b/seatd/client.c
@@ -138,6 +138,7 @@ static int handle_open_seat(struct client *client) {
return -1;
}
+ linked_list_remove(&client->link);
if (seat_add_client(seat, client) == -1) {
log_errorf("unable to add client to target seat: %s", strerror(errno));
return -1;
@@ -174,6 +175,7 @@ static int handle_close_seat(struct client *client) {
log_error("unable to remove client from seat");
return -1;
}
+ linked_list_insert(&client->server->idle_clients, &client->link);
struct proto_header header = {
.opcode = SERVER_SEAT_CLOSED,
diff --git a/seatd/server.c b/seatd/server.c
index 9a71d66..1da8041 100644
--- a/seatd/server.c
+++ b/seatd/server.c
@@ -26,6 +26,7 @@ int server_init(struct server *server) {
poller_init(&server->poller);
linked_list_init(&server->seats);
+ linked_list_init(&server->idle_clients);
if (poller_add_signal(&server->poller, SIGUSR1, server_handle_vt_rel, server) == NULL ||
poller_add_signal(&server->poller, SIGUSR2, server_handle_vt_acq, server) == NULL ||
@@ -51,6 +52,11 @@ int server_init(struct server *server) {
void server_finish(struct server *server) {
assert(server);
+ while (!linked_list_empty(&server->idle_clients)) {
+ struct client *client = (struct client *)server->idle_clients.next;
+ linked_list_remove(&client->link);
+ client_destroy(client);
+ }
while (!linked_list_empty(&server->seats)) {
struct seat *seat = (struct seat *)server->seats.next;
linked_list_remove(&seat->link);
@@ -131,6 +137,7 @@ int server_add_client(struct server *server, int fd) {
}
log_infof("new client connected (pid: %d, uid: %d, gid: %d)", client->pid, client->uid,
client->gid);
+ linked_list_insert(&server->idle_clients, &client->link);
return 0;
}