Zbigniew Jędrzejewski-Szmek ef7b48
From ed66f51061f2ce4d31838739c51f11276f97aaaf Mon Sep 17 00:00:00 2001
Zbigniew Jędrzejewski-Szmek ef7b48
From: =?UTF-8?q?Zbigniew=20J=C4=99drzejewski-Szmek?= <zbyszek@in.waw.pl>
Zbigniew Jędrzejewski-Szmek ef7b48
Date: Fri, 13 Mar 2015 21:22:05 -0500
Zbigniew Jędrzejewski-Szmek ef7b48
Subject: [PATCH] sd-daemon: simplify sd_pid_notify_with_fds
Zbigniew Jędrzejewski-Szmek ef7b48
Zbigniew Jędrzejewski-Szmek ef7b48
Coverity was complaining that CMSG_NXTHDR is used without
Zbigniew Jędrzejewski-Szmek ef7b48
checking the return value. In this case it cannot fail, but
Zbigniew Jędrzejewski-Szmek ef7b48
it is a good excuse to simplify the function a bit.
Zbigniew Jędrzejewski-Szmek ef7b48
Zbigniew Jędrzejewski-Szmek ef7b48
CID #1261726.
Zbigniew Jędrzejewski-Szmek ef7b48
Zbigniew Jędrzejewski-Szmek ef7b48
(cherry picked from commit 64144440a5d2d94482f882b992fd2a4e0dca7a05)
Zbigniew Jędrzejewski-Szmek ef7b48
Zbigniew Jędrzejewski-Szmek ef7b48
http://lists.freedesktop.org/archives/systemd-devel/2015-April/031348.html
Zbigniew Jędrzejewski-Szmek ef7b48
---
Zbigniew Jędrzejewski-Szmek ef7b48
 src/libsystemd/sd-daemon/sd-daemon.c | 61 ++++++++++++++++--------------------
Zbigniew Jędrzejewski-Szmek ef7b48
 1 file changed, 27 insertions(+), 34 deletions(-)
Zbigniew Jędrzejewski-Szmek ef7b48
Zbigniew Jędrzejewski-Szmek ef7b48
diff --git a/src/libsystemd/sd-daemon/sd-daemon.c b/src/libsystemd/sd-daemon/sd-daemon.c
Zbigniew Jędrzejewski-Szmek ef7b48
index 22a3a5347a..1474321c95 100644
Zbigniew Jędrzejewski-Szmek ef7b48
--- a/src/libsystemd/sd-daemon/sd-daemon.c
Zbigniew Jędrzejewski-Szmek ef7b48
+++ b/src/libsystemd/sd-daemon/sd-daemon.c
Zbigniew Jędrzejewski-Szmek ef7b48
@@ -352,12 +352,10 @@ _public_ int sd_pid_notify_with_fds(pid_t pid, int unset_environment, const char
Zbigniew Jędrzejewski-Szmek ef7b48
                 .msg_iovlen = 1,
Zbigniew Jędrzejewski-Szmek ef7b48
                 .msg_name = &sockaddr,
Zbigniew Jędrzejewski-Szmek ef7b48
         };
Zbigniew Jędrzejewski-Szmek ef7b48
-        struct cmsghdr *control;
Zbigniew Jędrzejewski-Szmek ef7b48
         _cleanup_close_ int fd = -1;
Zbigniew Jędrzejewski-Szmek ef7b48
         struct cmsghdr *cmsg = NULL;
Zbigniew Jędrzejewski-Szmek ef7b48
         const char *e;
Zbigniew Jędrzejewski-Szmek ef7b48
-        size_t controllen_without_ucred = 0;
Zbigniew Jędrzejewski-Szmek ef7b48
-        bool try_without_ucred = false;
Zbigniew Jędrzejewski-Szmek ef7b48
+        bool have_pid;
Zbigniew Jędrzejewski-Szmek ef7b48
         int r;
Zbigniew Jędrzejewski-Szmek ef7b48
 
Zbigniew Jędrzejewski-Szmek ef7b48
         if (!state) {
Zbigniew Jędrzejewski-Szmek ef7b48
@@ -396,42 +394,37 @@ _public_ int sd_pid_notify_with_fds(pid_t pid, int unset_environment, const char
Zbigniew Jędrzejewski-Szmek ef7b48
         if (msghdr.msg_namelen > sizeof(struct sockaddr_un))
Zbigniew Jędrzejewski-Szmek ef7b48
                 msghdr.msg_namelen = sizeof(struct sockaddr_un);
Zbigniew Jędrzejewski-Szmek ef7b48
 
Zbigniew Jędrzejewski-Szmek ef7b48
-        control = alloca(CMSG_SPACE(sizeof(struct ucred)) + CMSG_SPACE(sizeof(int) * n_fds));
Zbigniew Jędrzejewski-Szmek ef7b48
+        have_pid = pid != 0 && pid != getpid();
Zbigniew Jędrzejewski-Szmek ef7b48
 
Zbigniew Jędrzejewski-Szmek ef7b48
-        if (n_fds > 0) {
Zbigniew Jędrzejewski-Szmek ef7b48
-                msghdr.msg_control = control;
Zbigniew Jędrzejewski-Szmek ef7b48
-                msghdr.msg_controllen = CMSG_LEN(sizeof(int) * n_fds);
Zbigniew Jędrzejewski-Szmek ef7b48
+        if (n_fds > 0 || have_pid) {
Zbigniew Jędrzejewski-Szmek ef7b48
+                msghdr.msg_controllen = CMSG_SPACE(sizeof(int) * n_fds) +
Zbigniew Jędrzejewski-Szmek ef7b48
+                                        CMSG_SPACE(sizeof(struct ucred) * have_pid);
Zbigniew Jędrzejewski-Szmek ef7b48
+                msghdr.msg_control = alloca(msghdr.msg_controllen);
Zbigniew Jędrzejewski-Szmek ef7b48
 
Zbigniew Jędrzejewski-Szmek ef7b48
                 cmsg = CMSG_FIRSTHDR(&msghdr);
Zbigniew Jędrzejewski-Szmek ef7b48
-                cmsg->cmsg_level = SOL_SOCKET;
Zbigniew Jędrzejewski-Szmek ef7b48
-                cmsg->cmsg_type = SCM_RIGHTS;
Zbigniew Jędrzejewski-Szmek ef7b48
-                cmsg->cmsg_len = CMSG_LEN(sizeof(int) * n_fds);
Zbigniew Jędrzejewski-Szmek ef7b48
+                if (n_fds > 0) {
Zbigniew Jędrzejewski-Szmek ef7b48
+                        cmsg->cmsg_level = SOL_SOCKET;
Zbigniew Jędrzejewski-Szmek ef7b48
+                        cmsg->cmsg_type = SCM_RIGHTS;
Zbigniew Jędrzejewski-Szmek ef7b48
+                        cmsg->cmsg_len = CMSG_LEN(sizeof(int) * n_fds);
Zbigniew Jędrzejewski-Szmek ef7b48
 
Zbigniew Jędrzejewski-Szmek ef7b48
-                memcpy(CMSG_DATA(cmsg), fds, sizeof(int) * n_fds);
Zbigniew Jędrzejewski-Szmek ef7b48
-        }
Zbigniew Jędrzejewski-Szmek ef7b48
-
Zbigniew Jędrzejewski-Szmek ef7b48
-        if (pid != 0 && pid != getpid()) {
Zbigniew Jędrzejewski-Szmek ef7b48
-                struct ucred *ucred;
Zbigniew Jędrzejewski-Szmek ef7b48
-
Zbigniew Jędrzejewski-Szmek ef7b48
-                try_without_ucred = true;
Zbigniew Jędrzejewski-Szmek ef7b48
-                controllen_without_ucred = msghdr.msg_controllen;
Zbigniew Jędrzejewski-Szmek ef7b48
+                        memcpy(CMSG_DATA(cmsg), fds, sizeof(int) * n_fds);
Zbigniew Jędrzejewski-Szmek ef7b48
 
Zbigniew Jędrzejewski-Szmek ef7b48
-                msghdr.msg_control = control;
Zbigniew Jędrzejewski-Szmek ef7b48
-                msghdr.msg_controllen += CMSG_LEN(sizeof(struct ucred));
Zbigniew Jędrzejewski-Szmek ef7b48
+                        if (have_pid)
Zbigniew Jędrzejewski-Szmek ef7b48
+                                assert_se(cmsg = CMSG_NXTHDR(&msghdr, cmsg));
Zbigniew Jędrzejewski-Szmek ef7b48
+                }
Zbigniew Jędrzejewski-Szmek ef7b48
 
Zbigniew Jędrzejewski-Szmek ef7b48
-                if (cmsg)
Zbigniew Jędrzejewski-Szmek ef7b48
-                        cmsg = CMSG_NXTHDR(&msghdr, cmsg);
Zbigniew Jędrzejewski-Szmek ef7b48
-                else
Zbigniew Jędrzejewski-Szmek ef7b48
-                        cmsg = CMSG_FIRSTHDR(&msghdr);
Zbigniew Jędrzejewski-Szmek ef7b48
+                if (have_pid) {
Zbigniew Jędrzejewski-Szmek ef7b48
+                        struct ucred *ucred;
Zbigniew Jędrzejewski-Szmek ef7b48
 
Zbigniew Jędrzejewski-Szmek ef7b48
-                cmsg->cmsg_level = SOL_SOCKET;
Zbigniew Jędrzejewski-Szmek ef7b48
-                cmsg->cmsg_type = SCM_CREDENTIALS;
Zbigniew Jędrzejewski-Szmek ef7b48
-                cmsg->cmsg_len = CMSG_LEN(sizeof(struct ucred));
Zbigniew Jędrzejewski-Szmek ef7b48
+                        cmsg->cmsg_level = SOL_SOCKET;
Zbigniew Jędrzejewski-Szmek ef7b48
+                        cmsg->cmsg_type = SCM_CREDENTIALS;
Zbigniew Jędrzejewski-Szmek ef7b48
+                        cmsg->cmsg_len = CMSG_LEN(sizeof(struct ucred));
Zbigniew Jędrzejewski-Szmek ef7b48
 
Zbigniew Jędrzejewski-Szmek ef7b48
-                ucred = (struct ucred*) CMSG_DATA(cmsg);
Zbigniew Jędrzejewski-Szmek ef7b48
-                ucred->pid = pid;
Zbigniew Jędrzejewski-Szmek ef7b48
-                ucred->uid = getuid();
Zbigniew Jędrzejewski-Szmek ef7b48
-                ucred->gid = getgid();
Zbigniew Jędrzejewski-Szmek ef7b48
+                        ucred = (struct ucred*) CMSG_DATA(cmsg);
Zbigniew Jędrzejewski-Szmek ef7b48
+                        ucred->pid = pid;
Zbigniew Jędrzejewski-Szmek ef7b48
+                        ucred->uid = getuid();
Zbigniew Jędrzejewski-Szmek ef7b48
+                        ucred->gid = getgid();
Zbigniew Jędrzejewski-Szmek ef7b48
+                }
Zbigniew Jędrzejewski-Szmek ef7b48
         }
Zbigniew Jędrzejewski-Szmek ef7b48
 
Zbigniew Jędrzejewski-Szmek ef7b48
         /* First try with fake ucred data, as requested */
Zbigniew Jędrzejewski-Szmek ef7b48
@@ -441,10 +434,10 @@ _public_ int sd_pid_notify_with_fds(pid_t pid, int unset_environment, const char
Zbigniew Jędrzejewski-Szmek ef7b48
         }
Zbigniew Jędrzejewski-Szmek ef7b48
 
Zbigniew Jędrzejewski-Szmek ef7b48
         /* If that failed, try with our own ucred instead */
Zbigniew Jędrzejewski-Szmek ef7b48
-        if (try_without_ucred) {
Zbigniew Jędrzejewski-Szmek ef7b48
-                if (controllen_without_ucred <= 0)
Zbigniew Jędrzejewski-Szmek ef7b48
+        if (have_pid) {
Zbigniew Jędrzejewski-Szmek ef7b48
+                msghdr.msg_controllen -= CMSG_SPACE(sizeof(struct ucred));
Zbigniew Jędrzejewski-Szmek ef7b48
+                if (msghdr.msg_controllen == 0)
Zbigniew Jędrzejewski-Szmek ef7b48
                         msghdr.msg_control = NULL;
Zbigniew Jędrzejewski-Szmek ef7b48
-                msghdr.msg_controllen = controllen_without_ucred;
Zbigniew Jędrzejewski-Szmek ef7b48
 
Zbigniew Jędrzejewski-Szmek ef7b48
                 if (sendmsg(fd, &msghdr, MSG_NOSIGNAL) >= 0) {
Zbigniew Jędrzejewski-Szmek ef7b48
                         r = 1;