inittab: clean up tty opening code, fix console shell job control issues
authorFelix Fietkau <nbd@openwrt.org>
Sat, 8 Nov 2014 18:07:46 +0000 (19:07 +0100)
committerFelix Fietkau <nbd@openwrt.org>
Sat, 8 Nov 2014 18:07:46 +0000 (19:07 +0100)
Signed-off-by: Felix Fietkau <nbd@openwrt.org>
inittab.c

index be1848206bb6f20998470b2b89589f1ec090eab0..2efbf4d69174240bf897ec02df52a16d16671d47 100644 (file)
--- a/inittab.c
+++ b/inittab.c
@@ -14,6 +14,7 @@
 
 #include <sys/types.h>
 #include <sys/stat.h>
+#include <sys/ioctl.h>
 
 #include <fcntl.h>
 #include <stdio.h>
@@ -96,16 +97,25 @@ static void fork_worker(struct init_action *a)
 
        a->proc.pid = fork();
        if (!a->proc.pid) {
-               p = setsid( );
+               p = setsid();
+
+               close(STDIN_FILENO);
+               close(STDOUT_FILENO);
+               close(STDERR_FILENO);
+
                fd = dev_open(a->id);
                if (fd != -1)
                {
                        dup2(fd, STDIN_FILENO);
                        dup2(fd, STDOUT_FILENO);
                        dup2(fd, STDERR_FILENO);
-                       tcsetpgrp(fd, p);
-                       close(fd);
+                       if (fd > STDERR_FILENO)
+                               close(fd);
                }
+
+               ioctl(STDIN_FILENO, TIOCSCTTY, 1);
+               tcsetpgrp(STDIN_FILENO, p);
+
                execvp(a->argv[0], a->argv);
                ERROR("Failed to execute %s\n", a->argv[0]);
                exit(-1);