summaryrefslogtreecommitdiffstats
path: root/inittab.c
diff options
context:
space:
mode:
authorFelix Fietkau <nbd@openwrt.org>2014-11-08 19:07:46 +0100
committerFelix Fietkau <nbd@openwrt.org>2014-11-08 19:07:46 +0100
commit0f49ab0feab67aac4a399bbad58f5f230f625833 (patch)
treeabc5d69a19dad4e3a8f1423ec63847d1a4fa9087 /inittab.c
parentb899234bd657fa1ae1c71315326c3fe2cd9b6cec (diff)
downloadunitd-0f49ab0feab67aac4a399bbad58f5f230f625833.tar
unitd-0f49ab0feab67aac4a399bbad58f5f230f625833.zip
inittab: clean up tty opening code, fix console shell job control issues
Signed-off-by: Felix Fietkau <nbd@openwrt.org>
Diffstat (limited to 'inittab.c')
-rw-r--r--inittab.c16
1 files changed, 13 insertions, 3 deletions
diff --git a/inittab.c b/inittab.c
index be18482..2efbf4d 100644
--- 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);