|
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,
|