Zbigniew Jędrzejewski-Szmek 62fe94
From 3f56f784b98a4b0ad45409a9a19fd787cd7ae455 Mon Sep 17 00:00:00 2001
Zbigniew Jędrzejewski-Szmek 62fe94
From: Tom Gundersen <teg@jklm.no>
Zbigniew Jędrzejewski-Szmek 62fe94
Date: Fri, 12 Sep 2014 16:45:19 +0200
Zbigniew Jędrzejewski-Szmek 62fe94
Subject: [PATCH] udevd: initialize epoll_event structs on allocation
Zbigniew Jędrzejewski-Szmek 62fe94
Zbigniew Jędrzejewski-Szmek 62fe94
Also move the rest of event initialization next to the event loop (no functional change).
Zbigniew Jędrzejewski-Szmek 62fe94
---
Zbigniew Jędrzejewski-Szmek 62fe94
 src/udev/udevd.c | 72 ++++++++++++++++++++++++--------------------------------
Zbigniew Jędrzejewski-Szmek 62fe94
 1 file changed, 31 insertions(+), 41 deletions(-)
Zbigniew Jędrzejewski-Szmek 62fe94
Zbigniew Jędrzejewski-Szmek 62fe94
diff --git a/src/udev/udevd.c b/src/udev/udevd.c
Zbigniew Jędrzejewski-Szmek 62fe94
index e90d9dacb0..04014b468a 100644
Zbigniew Jędrzejewski-Szmek 62fe94
--- a/src/udev/udevd.c
Zbigniew Jędrzejewski-Szmek 62fe94
+++ b/src/udev/udevd.c
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -1085,7 +1085,11 @@ int main(int argc, char *argv[]) {
Zbigniew Jędrzejewski-Szmek 62fe94
         int fd_ctrl = -1;
Zbigniew Jędrzejewski-Szmek 62fe94
         int fd_netlink = -1;
Zbigniew Jędrzejewski-Szmek 62fe94
         int fd_worker = -1;
Zbigniew Jędrzejewski-Szmek 62fe94
-        struct epoll_event ep_ctrl, ep_inotify, ep_signal, ep_netlink, ep_worker;
Zbigniew Jędrzejewski-Szmek 62fe94
+        struct epoll_event ep_ctrl = { .events = EPOLLIN };
Zbigniew Jędrzejewski-Szmek 62fe94
+        struct epoll_event ep_inotify = { .events = EPOLLIN };
Zbigniew Jędrzejewski-Szmek 62fe94
+        struct epoll_event ep_signal = { .events = EPOLLIN };
Zbigniew Jędrzejewski-Szmek 62fe94
+        struct epoll_event ep_netlink = { .events = EPOLLIN };
Zbigniew Jędrzejewski-Szmek 62fe94
+        struct epoll_event ep_worker = { .events = EPOLLIN };
Zbigniew Jędrzejewski-Szmek 62fe94
         struct udev_ctrl_connection *ctrl_conn = NULL;
Zbigniew Jędrzejewski-Szmek 62fe94
         int rc = 1, r;
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -1221,6 +1225,32 @@ int main(int argc, char *argv[]) {
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
         log_info("starting version " VERSION "\n");
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
+        udev_builtin_init(udev);
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+        rules = udev_rules_new(udev, arg_resolve_names);
Zbigniew Jędrzejewski-Szmek 62fe94
+        if (rules == NULL) {
Zbigniew Jędrzejewski-Szmek 62fe94
+                log_error("error reading rules");
Zbigniew Jędrzejewski-Szmek 62fe94
+                goto exit;
Zbigniew Jędrzejewski-Szmek 62fe94
+        }
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+        rc = udev_rules_apply_static_dev_perms(rules);
Zbigniew Jędrzejewski-Szmek 62fe94
+        if (rc < 0)
Zbigniew Jędrzejewski-Szmek 62fe94
+                log_error("failed to apply permissions on static device nodes - %s", strerror(-rc));
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+        if (arg_children_max <= 0) {
Zbigniew Jędrzejewski-Szmek 62fe94
+                cpu_set_t cpu_set;
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+                arg_children_max = 8;
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+                if (sched_getaffinity(0, sizeof (cpu_set), &cpu_set) == 0) {
Zbigniew Jędrzejewski-Szmek 62fe94
+                        arg_children_max +=  CPU_COUNT(&cpu_set) * 2;
Zbigniew Jędrzejewski-Szmek 62fe94
+                }
Zbigniew Jędrzejewski-Szmek 62fe94
+        }
Zbigniew Jędrzejewski-Szmek 62fe94
+        log_debug("set children_max to %u", arg_children_max);
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+        udev_list_node_init(&event_list);
Zbigniew Jędrzejewski-Szmek 62fe94
+        udev_list_node_init(&worker_list);
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
         fd_inotify = udev_watch_init(udev);
Zbigniew Jędrzejewski-Szmek 62fe94
         if (fd_inotify < 0) {
Zbigniew Jędrzejewski-Szmek 62fe94
                 log_error("error initializing inotify");
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -1247,32 +1277,10 @@ int main(int argc, char *argv[]) {
Zbigniew Jędrzejewski-Szmek 62fe94
         }
Zbigniew Jędrzejewski-Szmek 62fe94
         fd_worker = worker_watch[READ_END];
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
-        udev_builtin_init(udev);
Zbigniew Jędrzejewski-Szmek 62fe94
-
Zbigniew Jędrzejewski-Szmek 62fe94
-        rules = udev_rules_new(udev, arg_resolve_names);
Zbigniew Jędrzejewski-Szmek 62fe94
-        if (rules == NULL) {
Zbigniew Jędrzejewski-Szmek 62fe94
-                log_error("error reading rules");
Zbigniew Jędrzejewski-Szmek 62fe94
-                goto exit;
Zbigniew Jędrzejewski-Szmek 62fe94
-        }
Zbigniew Jędrzejewski-Szmek 62fe94
-
Zbigniew Jędrzejewski-Szmek 62fe94
-        memzero(&ep_ctrl, sizeof(struct epoll_event));
Zbigniew Jędrzejewski-Szmek 62fe94
-        ep_ctrl.events = EPOLLIN;
Zbigniew Jędrzejewski-Szmek 62fe94
         ep_ctrl.data.fd = fd_ctrl;
Zbigniew Jędrzejewski-Szmek 62fe94
-
Zbigniew Jędrzejewski-Szmek 62fe94
-        memzero(&ep_inotify, sizeof(struct epoll_event));
Zbigniew Jędrzejewski-Szmek 62fe94
-        ep_inotify.events = EPOLLIN;
Zbigniew Jędrzejewski-Szmek 62fe94
         ep_inotify.data.fd = fd_inotify;
Zbigniew Jędrzejewski-Szmek 62fe94
-
Zbigniew Jędrzejewski-Szmek 62fe94
-        memzero(&ep_signal, sizeof(struct epoll_event));
Zbigniew Jędrzejewski-Szmek 62fe94
-        ep_signal.events = EPOLLIN;
Zbigniew Jędrzejewski-Szmek 62fe94
         ep_signal.data.fd = fd_signal;
Zbigniew Jędrzejewski-Szmek 62fe94
-
Zbigniew Jędrzejewski-Szmek 62fe94
-        memzero(&ep_netlink, sizeof(struct epoll_event));
Zbigniew Jędrzejewski-Szmek 62fe94
-        ep_netlink.events = EPOLLIN;
Zbigniew Jędrzejewski-Szmek 62fe94
         ep_netlink.data.fd = fd_netlink;
Zbigniew Jędrzejewski-Szmek 62fe94
-
Zbigniew Jędrzejewski-Szmek 62fe94
-        memzero(&ep_worker, sizeof(struct epoll_event));
Zbigniew Jędrzejewski-Szmek 62fe94
-        ep_worker.events = EPOLLIN;
Zbigniew Jędrzejewski-Szmek 62fe94
         ep_worker.data.fd = fd_worker;
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
         fd_ep = epoll_create1(EPOLL_CLOEXEC);
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -1289,24 +1297,6 @@ int main(int argc, char *argv[]) {
Zbigniew Jędrzejewski-Szmek 62fe94
                 goto exit;
Zbigniew Jędrzejewski-Szmek 62fe94
         }
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
-        if (arg_children_max <= 0) {
Zbigniew Jędrzejewski-Szmek 62fe94
-                cpu_set_t cpu_set;
Zbigniew Jędrzejewski-Szmek 62fe94
-
Zbigniew Jędrzejewski-Szmek 62fe94
-                arg_children_max = 8;
Zbigniew Jędrzejewski-Szmek 62fe94
-
Zbigniew Jędrzejewski-Szmek 62fe94
-                if (sched_getaffinity(0, sizeof (cpu_set), &cpu_set) == 0) {
Zbigniew Jędrzejewski-Szmek 62fe94
-                        arg_children_max +=  CPU_COUNT(&cpu_set) * 2;
Zbigniew Jędrzejewski-Szmek 62fe94
-                }
Zbigniew Jędrzejewski-Szmek 62fe94
-        }
Zbigniew Jędrzejewski-Szmek 62fe94
-        log_debug("set children_max to %u", arg_children_max);
Zbigniew Jędrzejewski-Szmek 62fe94
-
Zbigniew Jędrzejewski-Szmek 62fe94
-        rc = udev_rules_apply_static_dev_perms(rules);
Zbigniew Jędrzejewski-Szmek 62fe94
-        if (rc < 0)
Zbigniew Jędrzejewski-Szmek 62fe94
-                log_error("failed to apply permissions on static device nodes - %s", strerror(-rc));
Zbigniew Jędrzejewski-Szmek 62fe94
-
Zbigniew Jędrzejewski-Szmek 62fe94
-        udev_list_node_init(&event_list);
Zbigniew Jędrzejewski-Szmek 62fe94
-        udev_list_node_init(&worker_list);
Zbigniew Jędrzejewski-Szmek 62fe94
-
Zbigniew Jędrzejewski-Szmek 62fe94
         for (;;) {
Zbigniew Jędrzejewski-Szmek 62fe94
                 static usec_t last_usec;
Zbigniew Jędrzejewski-Szmek 62fe94
                 struct epoll_event ev[8];