aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--networking/telnetd.c18
1 files changed, 16 insertions, 2 deletions
diff --git a/networking/telnetd.c b/networking/telnetd.c
index a6bafa21d..caef15181 100644
--- a/networking/telnetd.c
+++ b/networking/telnetd.c
@@ -865,11 +865,25 @@ int telnetd_main(int argc UNUSED_PARAM, char **argv)
865 skip3: 865 skip3:
866 if (/*ts->size2 < BUFSIZE &&*/ FD_ISSET(ts->ptyfd, &rdfdset)) { 866 if (/*ts->size2 < BUFSIZE &&*/ FD_ISSET(ts->ptyfd, &rdfdset)) {
867 /* Read from pty to buffer 2 */ 867 /* Read from pty to buffer 2 */
868 int eio = 0;
869 read_pty:
868 count = MIN(BUFSIZE - ts->rdidx2, BUFSIZE - ts->size2); 870 count = MIN(BUFSIZE - ts->rdidx2, BUFSIZE - ts->size2);
869 count = safe_read(ts->ptyfd, TS_BUF2(ts) + ts->rdidx2, count); 871 count = safe_read(ts->ptyfd, TS_BUF2(ts) + ts->rdidx2, count);
870 if (count <= 0) { 872 if (count <= 0) {
871 if (count < 0 && errno == EAGAIN) 873 if (count < 0) {
872 goto skip4; 874 if (errno == EAGAIN)
875 goto skip4;
876 /* login process might call vhangup(),
877 * which causes intermittent EIOs on read above
878 * (observed on kernel 4.12.0). Try up to 10 ms.
879 */
880 if (errno == EIO && eio < 10) {
881 eio++;
882 //bb_error_msg("EIO pty %u", eio);
883 usleep(1000);
884 goto read_pty;
885 }
886 }
873 goto kill_session; 887 goto kill_session;
874 } 888 }
875 ts->size2 += count; 889 ts->size2 += count;