diff --git a/etc.BSD/rc b/etc.BSD/rc index 64fb4df9..13a192a1 100644 --- a/etc.BSD/rc +++ b/etc.BSD/rc @@ -11,4 +11,12 @@ RUNLEVEL="1" /sbin/rc sysinit || exit 1 RUNLEVEL="1" /sbin/rc boot || exit 1 -/sbin/rc default || exit 1 +PREVLEVEL="1" /sbin/rc default + +# If we return non zero after starting rc then 2 things may happen +# 1) We get the message "init: can't get /dev/console for controlling terminal" +# every few seconds +# 2) We get no error and console freezes. +# This is probably a bug somewhere in rc, but until that is fixed we have to +# return 0. +exit 0 diff --git a/src/rc.c b/src/rc.c index 2b9629f7..16d45eb5 100644 --- a/src/rc.c +++ b/src/rc.c @@ -458,26 +458,11 @@ static void wait_for_services () static void handle_signal (int sig) { - pid_t pid; - int status; int serrno = errno; char signame[10] = { '\0' }; switch (sig) { - case SIGCHLD: - do - { - pid = waitpid (-1, &status, WNOHANG); - if (pid < 0) - { - if (errno && errno != ECHILD) - eerror ("waitpid: %s", strerror (errno)); - return; - } - } while (! WIFEXITED (status) && ! WIFSIGNALED (status)); - break; - case SIGINT: if (! signame[0]) snprintf (signame, sizeof (signame), "SIGINT"); @@ -557,7 +542,6 @@ int main (int argc, char **argv) signal (SIGINT, handle_signal); signal (SIGQUIT, handle_signal); signal (SIGTERM, handle_signal); - signal (SIGCHLD, handle_signal); /* Ensure our environment is pure Also, add our configuration to it */