chiark / gitweb /
Fix previous commit for !HAVE_AUDIT
[elogind.git] / src / nspawn / nspawn.c
index 09153c87ce2694de46835467aa19f99838ae75b8..33153c950777b7591c64c35536cafbf4e4072336 100644 (file)
@@ -1219,6 +1219,19 @@ finish:
         return r;
 }
 
+static bool audit_enabled(void) {
+#ifdef HAVE_AUDIT
+        int fd;
+
+        fd = socket(AF_NETLINK, SOCK_RAW, NETLINK_AUDIT);
+        if (fd >= 0) {
+                close_nointr_nofail(fd);
+                return true;
+        }
+#endif
+        return false;
+}
+
 int main(int argc, char *argv[]) {
         pid_t pid = 0;
         int r = EXIT_FAILURE, k;
@@ -1284,6 +1297,13 @@ int main(int argc, char *argv[]) {
                 goto finish;
         }
 
+        if (audit_enabled()) {
+                log_warning("The kernel auditing subsystem is known to be incompatible with containers.\n"
+                            "Please make sure to turn off auditing with 'audit=0' on the kernel command\n"
+                            "line before using systemd-nspawn. Sleeping for 5s...\n");
+                sleep(5);
+        }
+
         if (path_equal(arg_directory, "/")) {
                 log_error("Spawning container on root directory not supported.");
                 goto finish;