dcavalca / rpms / systemd

Forked from rpms/systemd 3 months ago
Clone
Zbigniew Jędrzejewski-Szmek a48f80
From 8851f051210fa9c18ffb94ebe601261bacaf37d4 Mon Sep 17 00:00:00 2001
Zbigniew Jędrzejewski-Szmek a48f80
From: Lennart Poettering <lennart@poettering.net>
Zbigniew Jędrzejewski-Szmek a48f80
Date: Mon, 18 May 2015 23:23:17 +0200
Zbigniew Jędrzejewski-Szmek a48f80
Subject: [PATCH] resolved: fix crash when shutting down
Zbigniew Jędrzejewski-Szmek a48f80
MIME-Version: 1.0
Zbigniew Jędrzejewski-Szmek a48f80
Content-Type: text/plain; charset=UTF-8
Zbigniew Jędrzejewski-Szmek a48f80
Content-Transfer-Encoding: 8bit
Zbigniew Jędrzejewski-Szmek a48f80
Zbigniew Jędrzejewski-Szmek a48f80
Reported by Cristian Rodríguez
Zbigniew Jędrzejewski-Szmek a48f80
Zbigniew Jędrzejewski-Szmek a48f80
http://lists.freedesktop.org/archives/systemd-devel/2015-May/031626.html
Zbigniew Jędrzejewski-Szmek a48f80
(cherry picked from commit cab5b05903096e1c9cf5575ccc73f89d15c8db69)
Zbigniew Jędrzejewski-Szmek a48f80
---
Zbigniew Jędrzejewski-Szmek a48f80
 src/resolve/resolved-dns-cache.c  |  7 ++-----
Zbigniew Jędrzejewski-Szmek a48f80
 src/resolve/resolved-dns-server.c | 15 ++++++++-------
Zbigniew Jędrzejewski-Szmek a48f80
 src/resolve/resolved-link.c       |  6 +++---
Zbigniew Jędrzejewski-Szmek a48f80
 src/resolve/resolved-manager.c    |  4 ++--
Zbigniew Jędrzejewski-Szmek a48f80
 src/shared/prioq.c                |  6 ++++--
Zbigniew Jędrzejewski-Szmek a48f80
 src/shared/prioq.h                |  2 +-
Zbigniew Jędrzejewski-Szmek a48f80
 6 files changed, 20 insertions(+), 20 deletions(-)
Zbigniew Jędrzejewski-Szmek a48f80
Zbigniew Jędrzejewski-Szmek a48f80
diff --git a/src/resolve/resolved-dns-cache.c b/src/resolve/resolved-dns-cache.c
Zbigniew Jędrzejewski-Szmek a48f80
index 33ca4d1a45..be52891681 100644
Zbigniew Jędrzejewski-Szmek a48f80
--- a/src/resolve/resolved-dns-cache.c
Zbigniew Jędrzejewski-Szmek a48f80
+++ b/src/resolve/resolved-dns-cache.c
Zbigniew Jędrzejewski-Szmek a48f80
@@ -91,11 +91,8 @@ void dns_cache_flush(DnsCache *c) {
Zbigniew Jędrzejewski-Szmek a48f80
         assert(hashmap_size(c->by_key) == 0);
Zbigniew Jędrzejewski-Szmek a48f80
         assert(prioq_size(c->by_expiry) == 0);
Zbigniew Jędrzejewski-Szmek a48f80
 
Zbigniew Jędrzejewski-Szmek a48f80
-        hashmap_free(c->by_key);
Zbigniew Jędrzejewski-Szmek a48f80
-        c->by_key = NULL;
Zbigniew Jędrzejewski-Szmek a48f80
-
Zbigniew Jędrzejewski-Szmek a48f80
-        prioq_free(c->by_expiry);
Zbigniew Jędrzejewski-Szmek a48f80
-        c->by_expiry = NULL;
Zbigniew Jędrzejewski-Szmek a48f80
+        c->by_key = hashmap_free(c->by_key);
Zbigniew Jędrzejewski-Szmek a48f80
+        c->by_expiry = prioq_free(c->by_expiry);
Zbigniew Jędrzejewski-Szmek a48f80
 }
Zbigniew Jędrzejewski-Szmek a48f80
 
Zbigniew Jędrzejewski-Szmek a48f80
 static void dns_cache_remove(DnsCache *c, DnsResourceKey *key) {
Zbigniew Jędrzejewski-Szmek a48f80
diff --git a/src/resolve/resolved-dns-server.c b/src/resolve/resolved-dns-server.c
Zbigniew Jędrzejewski-Szmek a48f80
index caf06fe450..9a62a63258 100644
Zbigniew Jędrzejewski-Szmek a48f80
--- a/src/resolve/resolved-dns-server.c
Zbigniew Jędrzejewski-Szmek a48f80
+++ b/src/resolve/resolved-dns-server.c
Zbigniew Jędrzejewski-Szmek a48f80
@@ -78,23 +78,24 @@ DnsServer* dns_server_free(DnsServer *s)  {
Zbigniew Jędrzejewski-Szmek a48f80
         if (!s)
Zbigniew Jędrzejewski-Szmek a48f80
                 return NULL;
Zbigniew Jędrzejewski-Szmek a48f80
 
Zbigniew Jędrzejewski-Szmek a48f80
-        if (s->manager) {
Zbigniew Jędrzejewski-Szmek a48f80
+        if (s->link) {
Zbigniew Jędrzejewski-Szmek a48f80
                 if (s->type == DNS_SERVER_LINK)
Zbigniew Jędrzejewski-Szmek a48f80
                         LIST_REMOVE(servers, s->link->dns_servers, s);
Zbigniew Jędrzejewski-Szmek a48f80
-                else if (s->type == DNS_SERVER_SYSTEM)
Zbigniew Jędrzejewski-Szmek a48f80
+
Zbigniew Jędrzejewski-Szmek a48f80
+                if (s->link->current_dns_server == s)
Zbigniew Jędrzejewski-Szmek a48f80
+                        link_set_dns_server(s->link, NULL);
Zbigniew Jędrzejewski-Szmek a48f80
+        }
Zbigniew Jędrzejewski-Szmek a48f80
+
Zbigniew Jędrzejewski-Szmek a48f80
+        if (s->manager) {
Zbigniew Jędrzejewski-Szmek a48f80
+                if (s->type == DNS_SERVER_SYSTEM)
Zbigniew Jędrzejewski-Szmek a48f80
                         LIST_REMOVE(servers, s->manager->dns_servers, s);
Zbigniew Jędrzejewski-Szmek a48f80
                 else if (s->type == DNS_SERVER_FALLBACK)
Zbigniew Jędrzejewski-Szmek a48f80
                         LIST_REMOVE(servers, s->manager->fallback_dns_servers, s);
Zbigniew Jędrzejewski-Szmek a48f80
-                else
Zbigniew Jędrzejewski-Szmek a48f80
-                        assert_not_reached("Unknown server type");
Zbigniew Jędrzejewski-Szmek a48f80
 
Zbigniew Jędrzejewski-Szmek a48f80
                 if (s->manager->current_dns_server == s)
Zbigniew Jędrzejewski-Szmek a48f80
                         manager_set_dns_server(s->manager, NULL);
Zbigniew Jędrzejewski-Szmek a48f80
         }
Zbigniew Jędrzejewski-Szmek a48f80
 
Zbigniew Jędrzejewski-Szmek a48f80
-        if (s->link && s->link->current_dns_server == s)
Zbigniew Jędrzejewski-Szmek a48f80
-                link_set_dns_server(s->link, NULL);
Zbigniew Jędrzejewski-Szmek a48f80
-
Zbigniew Jędrzejewski-Szmek a48f80
         free(s);
Zbigniew Jędrzejewski-Szmek a48f80
 
Zbigniew Jędrzejewski-Szmek a48f80
         return NULL;
Zbigniew Jędrzejewski-Szmek a48f80
diff --git a/src/resolve/resolved-link.c b/src/resolve/resolved-link.c
Zbigniew Jędrzejewski-Szmek a48f80
index f94e4bb6f0..27d9129e00 100644
Zbigniew Jędrzejewski-Szmek a48f80
--- a/src/resolve/resolved-link.c
Zbigniew Jędrzejewski-Szmek a48f80
+++ b/src/resolve/resolved-link.c
Zbigniew Jędrzejewski-Szmek a48f80
@@ -68,13 +68,13 @@ Link *link_free(Link *l) {
Zbigniew Jędrzejewski-Szmek a48f80
         if (l->manager)
Zbigniew Jędrzejewski-Szmek a48f80
                 hashmap_remove(l->manager->links, INT_TO_PTR(l->ifindex));
Zbigniew Jędrzejewski-Szmek a48f80
 
Zbigniew Jędrzejewski-Szmek a48f80
+        while (l->dns_servers)
Zbigniew Jędrzejewski-Szmek a48f80
+                dns_server_free(l->dns_servers);
Zbigniew Jędrzejewski-Szmek a48f80
+
Zbigniew Jędrzejewski-Szmek a48f80
         dns_scope_free(l->unicast_scope);
Zbigniew Jędrzejewski-Szmek a48f80
         dns_scope_free(l->llmnr_ipv4_scope);
Zbigniew Jędrzejewski-Szmek a48f80
         dns_scope_free(l->llmnr_ipv6_scope);
Zbigniew Jędrzejewski-Szmek a48f80
 
Zbigniew Jędrzejewski-Szmek a48f80
-        while (l->dns_servers)
Zbigniew Jędrzejewski-Szmek a48f80
-                dns_server_free(l->dns_servers);
Zbigniew Jędrzejewski-Szmek a48f80
-
Zbigniew Jędrzejewski-Szmek a48f80
         free(l);
Zbigniew Jędrzejewski-Szmek a48f80
         return NULL;
Zbigniew Jędrzejewski-Szmek a48f80
 }
Zbigniew Jędrzejewski-Szmek a48f80
diff --git a/src/resolve/resolved-manager.c b/src/resolve/resolved-manager.c
Zbigniew Jędrzejewski-Szmek a48f80
index b5ad701611..7c253aa13f 100644
Zbigniew Jędrzejewski-Szmek a48f80
--- a/src/resolve/resolved-manager.c
Zbigniew Jędrzejewski-Szmek a48f80
+++ b/src/resolve/resolved-manager.c
Zbigniew Jędrzejewski-Szmek a48f80
@@ -536,11 +536,11 @@ Manager *manager_free(Manager *m) {
Zbigniew Jędrzejewski-Szmek a48f80
         while (m->dns_queries)
Zbigniew Jędrzejewski-Szmek a48f80
                 dns_query_free(m->dns_queries);
Zbigniew Jędrzejewski-Szmek a48f80
 
Zbigniew Jędrzejewski-Szmek a48f80
-        dns_scope_free(m->unicast_scope);
Zbigniew Jędrzejewski-Szmek a48f80
-
Zbigniew Jędrzejewski-Szmek a48f80
         manager_flush_dns_servers(m, DNS_SERVER_SYSTEM);
Zbigniew Jędrzejewski-Szmek a48f80
         manager_flush_dns_servers(m, DNS_SERVER_FALLBACK);
Zbigniew Jędrzejewski-Szmek a48f80
 
Zbigniew Jędrzejewski-Szmek a48f80
+        dns_scope_free(m->unicast_scope);
Zbigniew Jędrzejewski-Szmek a48f80
+
Zbigniew Jędrzejewski-Szmek a48f80
         hashmap_free(m->links);
Zbigniew Jędrzejewski-Szmek a48f80
         hashmap_free(m->dns_transactions);
Zbigniew Jędrzejewski-Szmek a48f80
 
Zbigniew Jędrzejewski-Szmek a48f80
diff --git a/src/shared/prioq.c b/src/shared/prioq.c
Zbigniew Jędrzejewski-Szmek a48f80
index 8af4c51c2f..b89888be0e 100644
Zbigniew Jędrzejewski-Szmek a48f80
--- a/src/shared/prioq.c
Zbigniew Jędrzejewski-Szmek a48f80
+++ b/src/shared/prioq.c
Zbigniew Jędrzejewski-Szmek a48f80
@@ -45,12 +45,14 @@ Prioq *prioq_new(compare_func_t compare_func) {
Zbigniew Jędrzejewski-Szmek a48f80
         return q;
Zbigniew Jędrzejewski-Szmek a48f80
 }
Zbigniew Jędrzejewski-Szmek a48f80
 
Zbigniew Jędrzejewski-Szmek a48f80
-void prioq_free(Prioq *q) {
Zbigniew Jędrzejewski-Szmek a48f80
+Prioq* prioq_free(Prioq *q) {
Zbigniew Jędrzejewski-Szmek a48f80
         if (!q)
Zbigniew Jędrzejewski-Szmek a48f80
-                return;
Zbigniew Jędrzejewski-Szmek a48f80
+                return NULL;
Zbigniew Jędrzejewski-Szmek a48f80
 
Zbigniew Jędrzejewski-Szmek a48f80
         free(q->items);
Zbigniew Jędrzejewski-Szmek a48f80
         free(q);
Zbigniew Jędrzejewski-Szmek a48f80
+
Zbigniew Jędrzejewski-Szmek a48f80
+        return NULL;
Zbigniew Jędrzejewski-Szmek a48f80
 }
Zbigniew Jędrzejewski-Szmek a48f80
 
Zbigniew Jędrzejewski-Szmek a48f80
 int prioq_ensure_allocated(Prioq **q, compare_func_t compare_func) {
Zbigniew Jędrzejewski-Szmek a48f80
diff --git a/src/shared/prioq.h b/src/shared/prioq.h
Zbigniew Jędrzejewski-Szmek a48f80
index d836b36cd9..1c044b135c 100644
Zbigniew Jędrzejewski-Szmek a48f80
--- a/src/shared/prioq.h
Zbigniew Jędrzejewski-Szmek a48f80
+++ b/src/shared/prioq.h
Zbigniew Jędrzejewski-Szmek a48f80
@@ -28,7 +28,7 @@ typedef struct Prioq Prioq;
Zbigniew Jędrzejewski-Szmek a48f80
 #define PRIOQ_IDX_NULL ((unsigned) -1)
Zbigniew Jędrzejewski-Szmek a48f80
 
Zbigniew Jędrzejewski-Szmek a48f80
 Prioq *prioq_new(compare_func_t compare);
Zbigniew Jędrzejewski-Szmek a48f80
-void prioq_free(Prioq *q);
Zbigniew Jędrzejewski-Szmek a48f80
+Prioq *prioq_free(Prioq *q);
Zbigniew Jędrzejewski-Szmek a48f80
 int prioq_ensure_allocated(Prioq **q, compare_func_t compare_func);
Zbigniew Jędrzejewski-Szmek a48f80
 
Zbigniew Jędrzejewski-Szmek a48f80
 int prioq_put(Prioq *q, void *data, unsigned *idx);