diff options
author | Paul Fox <pgf@brightstareng.com> | 2008-04-23 15:31:29 +0000 |
---|---|---|
committer | Paul Fox <pgf@brightstareng.com> | 2008-04-23 15:31:29 +0000 |
commit | a50a9b0fdf3d752fc88182bccd47a1eaac79cb4b (patch) | |
tree | 753926c07ace7bc20ab9621bfed7bdcf0e2a94e0 | |
parent | 765c1c3c31493787b9cb53cc80574734e42a8844 (diff) | |
download | busybox-a50a9b0fdf3d752fc88182bccd47a1eaac79cb4b.tar.gz |
delay reconfig of input tty until target device has been both opened
and configured correctly.
-rw-r--r-- | miscutils/microcom.c | 20 |
1 files changed, 9 insertions, 11 deletions
diff --git a/miscutils/microcom.c b/miscutils/microcom.c index 5ce430a03..1608960e9 100644 --- a/miscutils/microcom.c +++ b/miscutils/microcom.c @@ -96,14 +96,6 @@ int microcom_main(int argc ATTRIBUTE_UNUSED, char **argv) // error exit code if we fail to open the device signalled = 1; - // put stdin to "raw mode" (if stdin is a TTY), - // handle one character at a time - if (isatty(STDIN_FILENO)) { - xget1(STDIN_FILENO, &tio, &tio0); - if (xset1(STDIN_FILENO, &tio, "stdin")) - goto done; - } - // open device sfd = open_or_warn(argv[0], O_RDWR | O_NOCTTY | O_NONBLOCK); if (sfd < 0) @@ -112,11 +104,18 @@ int microcom_main(int argc ATTRIBUTE_UNUSED, char **argv) // put device to "raw mode" xget1(sfd, &tio, &tiosfd); -// tio.c_cflag |= (CREAD|HUPCL); // we just bail out on any device error // set device speed cfsetspeed(&tio, tty_value_to_baud(speed)); if (xset1(sfd, &tio, argv[0])) - goto restore0_and_done; + goto done; + + // put stdin to "raw mode" (if stdin is a TTY), + // handle one character at a time + if (isatty(STDIN_FILENO)) { + xget1(STDIN_FILENO, &tio, &tio0); + if (xset1(STDIN_FILENO, &tio, "stdin")) + goto done; + } // main loop: check with poll(), then read/write bytes across pfd[0].fd = sfd; @@ -169,7 +168,6 @@ skip_write: ; // restore device mode tcsetattr(sfd, TCSAFLUSH, &tiosfd); -restore0_and_done: if (isatty(STDIN_FILENO)) tcsetattr(STDIN_FILENO, TCSAFLUSH, &tio0); |