X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fprocd.git;a=blobdiff_plain;f=initd%2Finit.c;h=e453cff21e426bc80bf7bc3cbf92df42aea0db80;hp=0d201bc33ffa46d1fad1488e7cc27082ae64869d;hb=63789e51ed913394c6bd4ac34e40ed0c8fcccccf;hpb=9286d16672b26c9fe7cb9dbf827a43a910df5559 diff --git a/initd/init.c b/initd/init.c index 0d201bc..e453cff 100644 --- a/initd/init.c +++ b/initd/init.c @@ -72,6 +72,8 @@ main(int argc, char **argv) { pid_t pid; + ulog_open(ULOG_KMSG, LOG_DAEMON, "init"); + sigaction(SIGTERM, &sa_shutdown, NULL); sigaction(SIGUSR1, &sa_shutdown, NULL); sigaction(SIGUSR2, &sa_shutdown, NULL); @@ -84,17 +86,9 @@ main(int argc, char **argv) if (!pid) { char *kmod[] = { "/sbin/kmodloader", "/etc/modules-boot.d/", NULL }; - if (debug < 3) { - int fd = open("/dev/null", O_RDWR); + if (debug < 3) + patch_stdio("/dev/null"); - if (fd > -1) { - dup2(fd, STDIN_FILENO); - dup2(fd, STDOUT_FILENO); - dup2(fd, STDERR_FILENO); - if (fd > STDERR_FILENO) - close(fd); - } - } execvp(kmod[0], kmod); ERROR("Failed to start kmodloader\n"); exit(-1); @@ -104,10 +98,10 @@ main(int argc, char **argv) } else { int i; - for (i = 0; i < 120; i++) { + for (i = 0; i < 1200; i++) { if (waitpid(pid, NULL, WNOHANG) > 0) break; - sleep(1); + usleep(10 * 1000); watchdog_ping(); } }