teknoraver / rpms / systemd

Forked from rpms/systemd 2 months ago
Clone

Blame 0285-udev-event-modernize-spawn_exec.patch

Zbigniew Jędrzejewski-Szmek 62fe94
From 19c784c414e6f2b35a268034905e1db226e905f6 Mon Sep 17 00:00:00 2001
Zbigniew Jędrzejewski-Szmek 62fe94
From: Tom Gundersen <teg@jklm.no>
Zbigniew Jędrzejewski-Szmek 62fe94
Date: Wed, 17 Sep 2014 21:53:20 +0200
Zbigniew Jędrzejewski-Szmek 62fe94
Subject: [PATCH] udev: event - modernize spawn_exec()
Zbigniew Jędrzejewski-Szmek 62fe94
Zbigniew Jędrzejewski-Szmek 62fe94
---
Zbigniew Jędrzejewski-Szmek 62fe94
 src/udev/udev-event.c | 15 ++++++---------
Zbigniew Jędrzejewski-Szmek 62fe94
 1 file changed, 6 insertions(+), 9 deletions(-)
Zbigniew Jędrzejewski-Szmek 62fe94
Zbigniew Jędrzejewski-Szmek 62fe94
diff --git a/src/udev/udev-event.c b/src/udev/udev-event.c
Zbigniew Jędrzejewski-Szmek 62fe94
index c8b142077e..dc1f682bfe 100644
Zbigniew Jędrzejewski-Szmek 62fe94
--- a/src/udev/udev-event.c
Zbigniew Jędrzejewski-Szmek 62fe94
+++ b/src/udev/udev-event.c
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -376,8 +376,7 @@ out:
Zbigniew Jędrzejewski-Szmek 62fe94
 static int spawn_exec(struct udev_event *event,
Zbigniew Jędrzejewski-Szmek 62fe94
                       const char *cmd, char *const argv[], char **envp, const sigset_t *sigmask,
Zbigniew Jędrzejewski-Szmek 62fe94
                       int fd_stdout, int fd_stderr) {
Zbigniew Jędrzejewski-Szmek 62fe94
-        int err;
Zbigniew Jędrzejewski-Szmek 62fe94
-        int fd;
Zbigniew Jędrzejewski-Szmek 62fe94
+        _cleanup_close_ int fd = -1;
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
         /* discard child output or connect to pipe */
Zbigniew Jędrzejewski-Szmek 62fe94
         fd = open("/dev/null", O_RDWR);
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -387,19 +386,17 @@ static int spawn_exec(struct udev_event *event,
Zbigniew Jędrzejewski-Szmek 62fe94
                         dup2(fd, STDOUT_FILENO);
Zbigniew Jędrzejewski-Szmek 62fe94
                 if (fd_stderr < 0)
Zbigniew Jędrzejewski-Szmek 62fe94
                         dup2(fd, STDERR_FILENO);
Zbigniew Jędrzejewski-Szmek 62fe94
-                close(fd);
Zbigniew Jędrzejewski-Szmek 62fe94
-        } else {
Zbigniew Jędrzejewski-Szmek 62fe94
+        } else
Zbigniew Jędrzejewski-Szmek 62fe94
                 log_error("open /dev/null failed: %m");
Zbigniew Jędrzejewski-Szmek 62fe94
-        }
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
         /* connect pipes to std{out,err} */
Zbigniew Jędrzejewski-Szmek 62fe94
         if (fd_stdout >= 0) {
Zbigniew Jędrzejewski-Szmek 62fe94
                 dup2(fd_stdout, STDOUT_FILENO);
Zbigniew Jędrzejewski-Szmek 62fe94
-                        close(fd_stdout);
Zbigniew Jędrzejewski-Szmek 62fe94
+                safe_close(fd_stdout);
Zbigniew Jędrzejewski-Szmek 62fe94
         }
Zbigniew Jędrzejewski-Szmek 62fe94
         if (fd_stderr >= 0) {
Zbigniew Jędrzejewski-Szmek 62fe94
                 dup2(fd_stderr, STDERR_FILENO);
Zbigniew Jędrzejewski-Szmek 62fe94
-                close(fd_stderr);
Zbigniew Jędrzejewski-Szmek 62fe94
+                safe_close(fd_stderr);
Zbigniew Jędrzejewski-Szmek 62fe94
         }
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
         /* terminate child in case parent goes away */
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -412,9 +409,9 @@ static int spawn_exec(struct udev_event *event,
Zbigniew Jędrzejewski-Szmek 62fe94
         execve(argv[0], argv, envp);
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
         /* exec failed */
Zbigniew Jędrzejewski-Szmek 62fe94
-        err = -errno;
Zbigniew Jędrzejewski-Szmek 62fe94
         log_error("failed to execute '%s' '%s': %m", argv[0], cmd);
Zbigniew Jędrzejewski-Szmek 62fe94
-        return err;
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+        return -errno;
Zbigniew Jędrzejewski-Szmek 62fe94
 }
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
 static void spawn_read(struct udev_event *event,