Zbigniew Jędrzejewski-Szmek 708deb
From 4cd5d5adb6a573d8ffb336b82325e5f2bb188381 Mon Sep 17 00:00:00 2001
Zbigniew Jędrzejewski-Szmek 708deb
From: Tom Gundersen <teg@jklm.no>
Zbigniew Jędrzejewski-Szmek 708deb
Date: Wed, 17 Sep 2014 21:43:57 +0200
Zbigniew Jędrzejewski-Szmek 708deb
Subject: [PATCH] udev: event - modernize spawn_read()
Zbigniew Jędrzejewski-Szmek 708deb
Zbigniew Jędrzejewski-Szmek 708deb
---
Zbigniew Jędrzejewski-Szmek 708deb
 src/udev/udev-event.c | 51 ++++++++++++++++++++++++++-------------------------
Zbigniew Jędrzejewski-Szmek 708deb
 1 file changed, 26 insertions(+), 25 deletions(-)
Zbigniew Jędrzejewski-Szmek 708deb
Zbigniew Jędrzejewski-Szmek 708deb
diff --git a/src/udev/udev-event.c b/src/udev/udev-event.c
Zbigniew Jędrzejewski-Szmek 708deb
index e8d6676616..6b8b5a8efa 100644
Zbigniew Jędrzejewski-Szmek 708deb
--- a/src/udev/udev-event.c
Zbigniew Jędrzejewski-Szmek 708deb
+++ b/src/udev/udev-event.c
Zbigniew Jędrzejewski-Szmek 708deb
@@ -422,9 +422,17 @@ static void spawn_read(struct udev_event *event,
Zbigniew Jędrzejewski-Szmek 708deb
                        const char *cmd,
Zbigniew Jędrzejewski-Szmek 708deb
                        int fd_stdout, int fd_stderr,
Zbigniew Jędrzejewski-Szmek 708deb
                        char *result, size_t ressize) {
Zbigniew Jędrzejewski-Szmek 708deb
+        _cleanup_close_ int fd_ep = -1;
Zbigniew Jędrzejewski-Szmek 708deb
+        struct epoll_event ep_outpipe = {
Zbigniew Jędrzejewski-Szmek 708deb
+                .events = EPOLLIN,
Zbigniew Jędrzejewski-Szmek 708deb
+                .data.ptr = &fd_stdout,
Zbigniew Jędrzejewski-Szmek 708deb
+        };
Zbigniew Jędrzejewski-Szmek 708deb
+        struct epoll_event ep_errpipe = {
Zbigniew Jędrzejewski-Szmek 708deb
+                .events = EPOLLIN,
Zbigniew Jędrzejewski-Szmek 708deb
+                .data.ptr = &fd_stderr,
Zbigniew Jędrzejewski-Szmek 708deb
+        };
Zbigniew Jędrzejewski-Szmek 708deb
         size_t respos = 0;
Zbigniew Jędrzejewski-Szmek 708deb
-        int fd_ep = -1;
Zbigniew Jędrzejewski-Szmek 708deb
-        struct epoll_event ep_outpipe, ep_errpipe;
Zbigniew Jędrzejewski-Szmek 708deb
+        int r;
Zbigniew Jędrzejewski-Szmek 708deb
 
Zbigniew Jędrzejewski-Szmek 708deb
         /* read from child if requested */
Zbigniew Jędrzejewski-Szmek 708deb
         if (fd_stdout < 0 && fd_stderr < 0)
Zbigniew Jędrzejewski-Szmek 708deb
@@ -433,26 +441,22 @@ static void spawn_read(struct udev_event *event,
Zbigniew Jędrzejewski-Szmek 708deb
         fd_ep = epoll_create1(EPOLL_CLOEXEC);
Zbigniew Jędrzejewski-Szmek 708deb
         if (fd_ep < 0) {
Zbigniew Jędrzejewski-Szmek 708deb
                 log_error("error creating epoll fd: %m");
Zbigniew Jędrzejewski-Szmek 708deb
-                goto out;
Zbigniew Jędrzejewski-Szmek 708deb
+                return;
Zbigniew Jędrzejewski-Szmek 708deb
         }
Zbigniew Jędrzejewski-Szmek 708deb
 
Zbigniew Jędrzejewski-Szmek 708deb
         if (fd_stdout >= 0) {
Zbigniew Jędrzejewski-Szmek 708deb
-                memzero(&ep_outpipe, sizeof(struct epoll_event));
Zbigniew Jędrzejewski-Szmek 708deb
-                ep_outpipe.events = EPOLLIN;
Zbigniew Jędrzejewski-Szmek 708deb
-                ep_outpipe.data.ptr = &fd_stdout;
Zbigniew Jędrzejewski-Szmek 708deb
-                if (epoll_ctl(fd_ep, EPOLL_CTL_ADD, fd_stdout, &ep_outpipe) < 0) {
Zbigniew Jędrzejewski-Szmek 708deb
-                        log_error("fail to add fd to epoll: %m");
Zbigniew Jędrzejewski-Szmek 708deb
-                        goto out;
Zbigniew Jędrzejewski-Szmek 708deb
+                r = epoll_ctl(fd_ep, EPOLL_CTL_ADD, fd_stdout, &ep_outpipe);
Zbigniew Jędrzejewski-Szmek 708deb
+                if (r < 0) {
Zbigniew Jędrzejewski-Szmek 708deb
+                        log_error("fail to add stdout fd to epoll: %m");
Zbigniew Jędrzejewski-Szmek 708deb
+                        return;
Zbigniew Jędrzejewski-Szmek 708deb
                 }
Zbigniew Jędrzejewski-Szmek 708deb
         }
Zbigniew Jędrzejewski-Szmek 708deb
 
Zbigniew Jędrzejewski-Szmek 708deb
         if (fd_stderr >= 0) {
Zbigniew Jędrzejewski-Szmek 708deb
-                memzero(&ep_errpipe, sizeof(struct epoll_event));
Zbigniew Jędrzejewski-Szmek 708deb
-                ep_errpipe.events = EPOLLIN;
Zbigniew Jędrzejewski-Szmek 708deb
-                ep_errpipe.data.ptr = &fd_stderr;
Zbigniew Jędrzejewski-Szmek 708deb
-                if (epoll_ctl(fd_ep, EPOLL_CTL_ADD, fd_stderr, &ep_errpipe) < 0) {
Zbigniew Jędrzejewski-Szmek 708deb
-                        log_error("fail to add fd to epoll: %m");
Zbigniew Jędrzejewski-Szmek 708deb
-                        goto out;
Zbigniew Jędrzejewski-Szmek 708deb
+                r = epoll_ctl(fd_ep, EPOLL_CTL_ADD, fd_stderr, &ep_errpipe);
Zbigniew Jędrzejewski-Szmek 708deb
+                if (r < 0) {
Zbigniew Jędrzejewski-Szmek 708deb
+                        log_error("fail to add stderr fd to epoll: %m");
Zbigniew Jędrzejewski-Szmek 708deb
+                        return;
Zbigniew Jędrzejewski-Szmek 708deb
                 }
Zbigniew Jędrzejewski-Szmek 708deb
         }
Zbigniew Jędrzejewski-Szmek 708deb
 
Zbigniew Jędrzejewski-Szmek 708deb
@@ -469,7 +473,7 @@ static void spawn_read(struct udev_event *event,
Zbigniew Jędrzejewski-Szmek 708deb
                         age_usec = now(CLOCK_MONOTONIC) - event->birth_usec;
Zbigniew Jędrzejewski-Szmek 708deb
                         if (age_usec >= timeout_usec) {
Zbigniew Jędrzejewski-Szmek 708deb
                                 log_error("timeout '%s'", cmd);
Zbigniew Jędrzejewski-Szmek 708deb
-                                goto out;
Zbigniew Jędrzejewski-Szmek 708deb
+                                return;
Zbigniew Jędrzejewski-Szmek 708deb
                         }
Zbigniew Jędrzejewski-Szmek 708deb
                         timeout = ((timeout_usec - age_usec) / USEC_PER_MSEC) + MSEC_PER_SEC;
Zbigniew Jędrzejewski-Szmek 708deb
                 } else {
Zbigniew Jędrzejewski-Szmek 708deb
@@ -481,11 +485,10 @@ static void spawn_read(struct udev_event *event,
Zbigniew Jędrzejewski-Szmek 708deb
                         if (errno == EINTR)
Zbigniew Jędrzejewski-Szmek 708deb
                                 continue;
Zbigniew Jędrzejewski-Szmek 708deb
                         log_error("failed to poll: %m");
Zbigniew Jędrzejewski-Szmek 708deb
-                        goto out;
Zbigniew Jędrzejewski-Szmek 708deb
-                }
Zbigniew Jędrzejewski-Szmek 708deb
-                if (fdcount == 0) {
Zbigniew Jędrzejewski-Szmek 708deb
+                        return;
Zbigniew Jędrzejewski-Szmek 708deb
+                } else if (fdcount == 0) {
Zbigniew Jędrzejewski-Szmek 708deb
                         log_error("timeout '%s'", cmd);
Zbigniew Jędrzejewski-Szmek 708deb
-                        goto out;
Zbigniew Jędrzejewski-Szmek 708deb
+                        return;
Zbigniew Jędrzejewski-Szmek 708deb
                 }
Zbigniew Jędrzejewski-Szmek 708deb
 
Zbigniew Jędrzejewski-Szmek 708deb
                 for (i = 0; i < fdcount; i++) {
Zbigniew Jędrzejewski-Szmek 708deb
@@ -522,9 +525,10 @@ static void spawn_read(struct udev_event *event,
Zbigniew Jędrzejewski-Szmek 708deb
                                         }
Zbigniew Jędrzejewski-Szmek 708deb
                                 }
Zbigniew Jędrzejewski-Szmek 708deb
                         } else if (ev[i].events & EPOLLHUP) {
Zbigniew Jędrzejewski-Szmek 708deb
-                                if (epoll_ctl(fd_ep, EPOLL_CTL_DEL, *fd, NULL) < 0) {
Zbigniew Jędrzejewski-Szmek 708deb
+                                r = epoll_ctl(fd_ep, EPOLL_CTL_DEL, *fd, NULL);
Zbigniew Jędrzejewski-Szmek 708deb
+                                if (r < 0) {
Zbigniew Jędrzejewski-Szmek 708deb
                                         log_error("failed to remove fd from epoll: %m");
Zbigniew Jędrzejewski-Szmek 708deb
-                                        goto out;
Zbigniew Jędrzejewski-Szmek 708deb
+                                        return;
Zbigniew Jędrzejewski-Szmek 708deb
                                 }
Zbigniew Jędrzejewski-Szmek 708deb
                                 *fd = -1;
Zbigniew Jędrzejewski-Szmek 708deb
                         }
Zbigniew Jędrzejewski-Szmek 708deb
@@ -534,9 +538,6 @@ static void spawn_read(struct udev_event *event,
Zbigniew Jędrzejewski-Szmek 708deb
         /* return the child's stdout string */
Zbigniew Jędrzejewski-Szmek 708deb
         if (result != NULL)
Zbigniew Jędrzejewski-Szmek 708deb
                 result[respos] = '\0';
Zbigniew Jędrzejewski-Szmek 708deb
-out:
Zbigniew Jędrzejewski-Szmek 708deb
-        if (fd_ep >= 0)
Zbigniew Jędrzejewski-Szmek 708deb
-                close(fd_ep);
Zbigniew Jędrzejewski-Szmek 708deb
 }
Zbigniew Jędrzejewski-Szmek 708deb
 
Zbigniew Jędrzejewski-Szmek 708deb
 static int spawn_wait(struct udev_event *event,