Zbigniew Jędrzejewski-Szmek 62fe94
From 70af4d17dafe81acc96f71f4ec06fbea7386bc38 Mon Sep 17 00:00:00 2001
Zbigniew Jędrzejewski-Szmek 62fe94
From: Lennart Poettering <lennart@poettering.net>
Zbigniew Jędrzejewski-Szmek 62fe94
Date: Thu, 21 Aug 2014 16:52:41 +0200
Zbigniew Jędrzejewski-Szmek 62fe94
Subject: [PATCH] manager: don#t dispatch sd_notify() messages and SIGCHLD
Zbigniew Jędrzejewski-Szmek 62fe94
 multiple times to the same units
Zbigniew Jędrzejewski-Szmek 62fe94
Zbigniew Jędrzejewski-Szmek 62fe94
---
Zbigniew Jędrzejewski-Szmek 62fe94
 src/core/manager.c | 44 +++++++++++++++++++++++---------------------
Zbigniew Jędrzejewski-Szmek 62fe94
 1 file changed, 23 insertions(+), 21 deletions(-)
Zbigniew Jędrzejewski-Szmek 62fe94
Zbigniew Jędrzejewski-Szmek 62fe94
diff --git a/src/core/manager.c b/src/core/manager.c
Zbigniew Jędrzejewski-Szmek 62fe94
index e488aba5f8..c91ece116f 100644
Zbigniew Jędrzejewski-Szmek 62fe94
--- a/src/core/manager.c
Zbigniew Jędrzejewski-Szmek 62fe94
+++ b/src/core/manager.c
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -562,7 +562,7 @@ static int manager_setup_notify(Manager *m) {
Zbigniew Jędrzejewski-Szmek 62fe94
                 strncpy(sa.un.sun_path, m->notify_socket, sizeof(sa.un.sun_path)-1);
Zbigniew Jędrzejewski-Szmek 62fe94
                 r = bind(fd, &sa.sa, offsetof(struct sockaddr_un, sun_path) + strlen(sa.un.sun_path));
Zbigniew Jędrzejewski-Szmek 62fe94
                 if (r < 0) {
Zbigniew Jędrzejewski-Szmek 62fe94
-                        log_error("bind(@%s) failed: %m", sa.un.sun_path+1);
Zbigniew Jędrzejewski-Szmek 62fe94
+                        log_error("bind(%s) failed: %m", sa.un.sun_path);
Zbigniew Jędrzejewski-Szmek 62fe94
                         return -errno;
Zbigniew Jędrzejewski-Szmek 62fe94
                 }
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -1398,7 +1398,7 @@ static int manager_dispatch_notify_fd(sd_event_source *source, int fd, uint32_t
Zbigniew Jędrzejewski-Szmek 62fe94
                         .msg_controllen = sizeof(control),
Zbigniew Jędrzejewski-Szmek 62fe94
                 };
Zbigniew Jędrzejewski-Szmek 62fe94
                 struct ucred *ucred;
Zbigniew Jędrzejewski-Szmek 62fe94
-                Unit *u;
Zbigniew Jędrzejewski-Szmek 62fe94
+                Unit *u1, *u2, *u3;
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
                 n = recvmsg(m->notify_fd, &msghdr, MSG_DONTWAIT);
Zbigniew Jędrzejewski-Szmek 62fe94
                 if (n <= 0) {
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -1424,21 +1424,23 @@ static int manager_dispatch_notify_fd(sd_event_source *source, int fd, uint32_t
Zbigniew Jędrzejewski-Szmek 62fe94
                 assert((size_t) n < sizeof(buf));
Zbigniew Jędrzejewski-Szmek 62fe94
                 buf[n] = 0;
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
-                u = manager_get_unit_by_pid(m, ucred->pid);
Zbigniew Jędrzejewski-Szmek 62fe94
-                if (u) {
Zbigniew Jędrzejewski-Szmek 62fe94
-                        manager_invoke_notify_message(m, u, ucred->pid, buf, n);
Zbigniew Jędrzejewski-Szmek 62fe94
+                /* Notify every unit that might be interested, but try
Zbigniew Jędrzejewski-Szmek 62fe94
+                 * to avoid notifying the same one multiple times. */
Zbigniew Jędrzejewski-Szmek 62fe94
+                u1 = manager_get_unit_by_pid(m, ucred->pid);
Zbigniew Jędrzejewski-Szmek 62fe94
+                if (u1) {
Zbigniew Jędrzejewski-Szmek 62fe94
+                        manager_invoke_notify_message(m, u1, ucred->pid, buf, n);
Zbigniew Jędrzejewski-Szmek 62fe94
                         found = true;
Zbigniew Jędrzejewski-Szmek 62fe94
                 }
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
-                u = hashmap_get(m->watch_pids1, LONG_TO_PTR(ucred->pid));
Zbigniew Jędrzejewski-Szmek 62fe94
-                if (u) {
Zbigniew Jędrzejewski-Szmek 62fe94
-                        manager_invoke_notify_message(m, u, ucred->pid, buf, n);
Zbigniew Jędrzejewski-Szmek 62fe94
+                u2 = hashmap_get(m->watch_pids1, LONG_TO_PTR(ucred->pid));
Zbigniew Jędrzejewski-Szmek 62fe94
+                if (u2 && u2 != u1) {
Zbigniew Jędrzejewski-Szmek 62fe94
+                        manager_invoke_notify_message(m, u2, ucred->pid, buf, n);
Zbigniew Jędrzejewski-Szmek 62fe94
                         found = true;
Zbigniew Jędrzejewski-Szmek 62fe94
                 }
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
-                u = hashmap_get(m->watch_pids2, LONG_TO_PTR(ucred->pid));
Zbigniew Jędrzejewski-Szmek 62fe94
-                if (u) {
Zbigniew Jędrzejewski-Szmek 62fe94
-                        manager_invoke_notify_message(m, u, ucred->pid, buf, n);
Zbigniew Jędrzejewski-Szmek 62fe94
+                u3 = hashmap_get(m->watch_pids2, LONG_TO_PTR(ucred->pid));
Zbigniew Jędrzejewski-Szmek 62fe94
+                if (u3 && u3 != u2 && u3 != u1) {
Zbigniew Jędrzejewski-Szmek 62fe94
+                        manager_invoke_notify_message(m, u3, ucred->pid, buf, n);
Zbigniew Jędrzejewski-Szmek 62fe94
                         found = true;
Zbigniew Jędrzejewski-Szmek 62fe94
                 }
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -1485,7 +1487,7 @@ static int manager_dispatch_sigchld(Manager *m) {
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
                 if (si.si_code == CLD_EXITED || si.si_code == CLD_KILLED || si.si_code == CLD_DUMPED) {
Zbigniew Jędrzejewski-Szmek 62fe94
                         _cleanup_free_ char *name = NULL;
Zbigniew Jędrzejewski-Szmek 62fe94
-                        Unit *u;
Zbigniew Jędrzejewski-Szmek 62fe94
+                        Unit *u1, *u2, *u3;
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
                         get_process_comm(si.si_pid, &name);
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -1499,15 +1501,15 @@ static int manager_dispatch_sigchld(Manager *m) {
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
                         /* And now figure out the unit this belongs
Zbigniew Jędrzejewski-Szmek 62fe94
                          * to, it might be multiple... */
Zbigniew Jędrzejewski-Szmek 62fe94
-                        u = manager_get_unit_by_pid(m, si.si_pid);
Zbigniew Jędrzejewski-Szmek 62fe94
-                        if (u)
Zbigniew Jędrzejewski-Szmek 62fe94
-                                invoke_sigchld_event(m, u, &si);
Zbigniew Jędrzejewski-Szmek 62fe94
-                        u = hashmap_get(m->watch_pids1, LONG_TO_PTR(si.si_pid));
Zbigniew Jędrzejewski-Szmek 62fe94
-                        if (u)
Zbigniew Jędrzejewski-Szmek 62fe94
-                                invoke_sigchld_event(m, u, &si);
Zbigniew Jędrzejewski-Szmek 62fe94
-                        u = hashmap_get(m->watch_pids2, LONG_TO_PTR(si.si_pid));
Zbigniew Jędrzejewski-Szmek 62fe94
-                        if (u)
Zbigniew Jędrzejewski-Szmek 62fe94
-                                invoke_sigchld_event(m, u, &si);
Zbigniew Jędrzejewski-Szmek 62fe94
+                        u1 = manager_get_unit_by_pid(m, si.si_pid);
Zbigniew Jędrzejewski-Szmek 62fe94
+                        if (u1)
Zbigniew Jędrzejewski-Szmek 62fe94
+                                invoke_sigchld_event(m, u1, &si);
Zbigniew Jędrzejewski-Szmek 62fe94
+                        u2 = hashmap_get(m->watch_pids1, LONG_TO_PTR(si.si_pid));
Zbigniew Jędrzejewski-Szmek 62fe94
+                        if (u2 && u2 != u1)
Zbigniew Jędrzejewski-Szmek 62fe94
+                                invoke_sigchld_event(m, u2, &si);
Zbigniew Jędrzejewski-Szmek 62fe94
+                        u3 = hashmap_get(m->watch_pids2, LONG_TO_PTR(si.si_pid));
Zbigniew Jędrzejewski-Szmek 62fe94
+                        if (u3 && u3 != u2 && u3 != u1)
Zbigniew Jędrzejewski-Szmek 62fe94
+                                invoke_sigchld_event(m, u3, &si);
Zbigniew Jędrzejewski-Szmek 62fe94
                 }
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
                 /* And now, we actually reap the zombie. */