teknoraver / rpms / systemd

Forked from rpms/systemd 4 months ago
Clone

Blame 0024-sd-daemon-replace-VLA-with-alloca-to-make-llvm-happy.patch

Zbigniew Jędrzejewski-Szmek e4a83a
From 3f0c8096f3d5e3b37d6e0e26f0562c1a8669f0d8 Mon Sep 17 00:00:00 2001
Zbigniew Jędrzejewski-Szmek e4a83a
From: Lennart Poettering <lennart@poettering.net>
Zbigniew Jędrzejewski-Szmek e4a83a
Date: Mon, 2 Mar 2015 20:55:38 +0100
Zbigniew Jędrzejewski-Szmek e4a83a
Subject: [PATCH] sd-daemon: replace VLA with alloca(), to make llvm happy
Zbigniew Jędrzejewski-Szmek e4a83a
Zbigniew Jędrzejewski-Szmek e4a83a
https://bugs.freedesktop.org/show_bug.cgi?id=89379
Zbigniew Jędrzejewski-Szmek e4a83a
(cherry picked from commit d4a144fadf89bca681724c6c9a65b4a165fa0f90)
Zbigniew Jędrzejewski-Szmek e4a83a
---
Zbigniew Jędrzejewski-Szmek e4a83a
 src/libsystemd/sd-daemon/sd-daemon.c | 12 +++++-------
Zbigniew Jędrzejewski-Szmek e4a83a
 1 file changed, 5 insertions(+), 7 deletions(-)
Zbigniew Jędrzejewski-Szmek e4a83a
Zbigniew Jędrzejewski-Szmek e4a83a
diff --git a/src/libsystemd/sd-daemon/sd-daemon.c b/src/libsystemd/sd-daemon/sd-daemon.c
Zbigniew Jędrzejewski-Szmek e4a83a
index 028c2a7a5b..22a3a5347a 100644
Zbigniew Jędrzejewski-Szmek e4a83a
--- a/src/libsystemd/sd-daemon/sd-daemon.c
Zbigniew Jędrzejewski-Szmek e4a83a
+++ b/src/libsystemd/sd-daemon/sd-daemon.c
Zbigniew Jędrzejewski-Szmek e4a83a
@@ -352,11 +352,7 @@ _public_ int sd_pid_notify_with_fds(pid_t pid, int unset_environment, const char
Zbigniew Jędrzejewski-Szmek e4a83a
                 .msg_iovlen = 1,
Zbigniew Jędrzejewski-Szmek e4a83a
                 .msg_name = &sockaddr,
Zbigniew Jędrzejewski-Szmek e4a83a
         };
Zbigniew Jędrzejewski-Szmek e4a83a
-        union {
Zbigniew Jędrzejewski-Szmek e4a83a
-                struct cmsghdr cmsghdr;
Zbigniew Jędrzejewski-Szmek e4a83a
-                uint8_t buf[CMSG_SPACE(sizeof(struct ucred)) +
Zbigniew Jędrzejewski-Szmek e4a83a
-                            CMSG_SPACE(sizeof(int) * n_fds)];
Zbigniew Jędrzejewski-Szmek e4a83a
-        } control;
Zbigniew Jędrzejewski-Szmek e4a83a
+        struct cmsghdr *control;
Zbigniew Jędrzejewski-Szmek e4a83a
         _cleanup_close_ int fd = -1;
Zbigniew Jędrzejewski-Szmek e4a83a
         struct cmsghdr *cmsg = NULL;
Zbigniew Jędrzejewski-Szmek e4a83a
         const char *e;
Zbigniew Jędrzejewski-Szmek e4a83a
@@ -400,8 +396,10 @@ _public_ int sd_pid_notify_with_fds(pid_t pid, int unset_environment, const char
Zbigniew Jędrzejewski-Szmek e4a83a
         if (msghdr.msg_namelen > sizeof(struct sockaddr_un))
Zbigniew Jędrzejewski-Szmek e4a83a
                 msghdr.msg_namelen = sizeof(struct sockaddr_un);
Zbigniew Jędrzejewski-Szmek e4a83a
 
Zbigniew Jędrzejewski-Szmek e4a83a
+        control = alloca(CMSG_SPACE(sizeof(struct ucred)) + CMSG_SPACE(sizeof(int) * n_fds));
Zbigniew Jędrzejewski-Szmek e4a83a
+
Zbigniew Jędrzejewski-Szmek e4a83a
         if (n_fds > 0) {
Zbigniew Jędrzejewski-Szmek e4a83a
-                msghdr.msg_control = &control;
Zbigniew Jędrzejewski-Szmek e4a83a
+                msghdr.msg_control = control;
Zbigniew Jędrzejewski-Szmek e4a83a
                 msghdr.msg_controllen = CMSG_LEN(sizeof(int) * n_fds);
Zbigniew Jędrzejewski-Szmek e4a83a
 
Zbigniew Jędrzejewski-Szmek e4a83a
                 cmsg = CMSG_FIRSTHDR(&msghdr);
Zbigniew Jędrzejewski-Szmek e4a83a
@@ -418,7 +416,7 @@ _public_ int sd_pid_notify_with_fds(pid_t pid, int unset_environment, const char
Zbigniew Jędrzejewski-Szmek e4a83a
                 try_without_ucred = true;
Zbigniew Jędrzejewski-Szmek e4a83a
                 controllen_without_ucred = msghdr.msg_controllen;
Zbigniew Jędrzejewski-Szmek e4a83a
 
Zbigniew Jędrzejewski-Szmek e4a83a
-                msghdr.msg_control = &control;
Zbigniew Jędrzejewski-Szmek e4a83a
+                msghdr.msg_control = control;
Zbigniew Jędrzejewski-Szmek e4a83a
                 msghdr.msg_controllen += CMSG_LEN(sizeof(struct ucred));
Zbigniew Jędrzejewski-Szmek e4a83a
 
Zbigniew Jędrzejewski-Szmek e4a83a
                 if (cmsg)