chiark / gitweb /
journald: ignore failure to watch hostname_fd on older kernels
authorDave Reisner <dreisner@archlinux.org>
Fri, 21 Feb 2014 15:31:26 +0000 (10:31 -0500)
committerDave Reisner <dreisner@archlinux.org>
Fri, 21 Feb 2014 17:49:05 +0000 (12:49 -0500)
Prior to 3.2, /proc/sys/kernel/hostname isn't a pollable file and
sd_event_add_io will return EPERM. Ignore this failure, since it isn't
critical to journald operation.

Reported and tested by user sraue on IRC.

src/journal/journald-server.c

index 5872e91fba414a8e8a4b5d27032c13b6f75c86dd..96ef66db5fa95b1b14c08b9a6f938e98632259bb 100644 (file)
@@ -1430,6 +1430,16 @@ static int server_open_hostname(Server *s) {
 
         r = sd_event_add_io(s->event, &s->hostname_event_source, s->hostname_fd, 0, dispatch_hostname_change, s);
         if (r < 0) {
+                /* kernels prior to 3.2 don't support polling this file. Ignore
+                 * the failure. */
+                if (r == -EPERM) {
+                        log_warning("Failed to register hostname fd in event loop: %s. Ignoring.",
+                                        strerror(-r));
+                        close_nointr_nofail(s->hostname_fd);
+                        s->hostname_fd = -1;
+                        return 0;
+                }
+
                 log_error("Failed to register hostname fd in event loop: %s", strerror(-r));
                 return r;
         }