X-Git-Url: https://scm.lunaixsky.com/lunaix-os.git/blobdiff_plain/7b8a1bcad75628f9add4590db2bb9b8e418ee8eb..0765e7c133eb393d8cd0292af444543c2edf8ccc:/lunaix-os/usr/init/init.c diff --git a/lunaix-os/usr/init/init.c b/lunaix-os/usr/init/init.c index 1b80f49..0a2f541 100644 --- a/lunaix-os/usr/init/init.c +++ b/lunaix-os/usr/init/init.c @@ -2,6 +2,7 @@ #include #include #include +#include #include #include @@ -14,6 +15,32 @@ } \ } while (0) +#define check(statement) \ + do { \ + int err = 0; \ + if ((err = (statement))) { \ + syslog(2, #statement " failed: %d", err); \ + return err; \ + } \ + } while (0) + +int +init_termios(int fd) { + struct termios term; + + check(tcgetattr(fd, &term)); + + term.c_lflag = ICANON | IEXTEN | ISIG | ECHO | ECHOE | ECHONL; + term.c_iflag = ICRNL | IGNBRK; + term.c_oflag = ONLCR | OPOST; + term.c_cflag = CREAD | CLOCAL | CS8 | CPARENB; + term.c_cc[VERASE] = 0x08; + + check(tcsetattr(fd, 0, &term)); + + return 0; +} + int main(int argc, const char** argv) { @@ -32,6 +59,8 @@ main(int argc, const char** argv) return err; } + check(init_termios(err)); + if ((err = dup(err)) < 0) { syslog(2, "fail to setup tty i/o (%d)\n", errno); return err;