Changeset 87822ce in mainline for uspace/app/ping/ping.c


Ignore:
Timestamp:
2021-03-04T19:14:30Z (3 years ago)
Author:
Jiri Svoboda <jiri@…>
Branches:
lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
Children:
d6c4d40
Parents:
760a392
Message:

Avoid infinite loop when console communication is broken

Need to make sure callers of console_get_event_timeout() can distinguish
between timeout and I/O error. Fix all callers of console_get_event()
and console_get_event_timeout() not to enter infinite loop when console
connection is broken. Also avoid setting of errno variable.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • uspace/app/ping/ping.c

    r760a392 r87822ce  
    196196        while (true) {
    197197                cons_event_t ev;
    198                 if (!console_get_event(con, &ev))
    199                         break;
     198                errno_t rc;
     199                rc = console_get_event(con, &ev);
     200                if (rc != EOK) {
     201                        ping_signal_received(RECEIVED_INTERRUPT);
     202                        break;
     203                }
    200204
    201205                if ((ev.type == CEV_KEY) && (ev.ev.key.type == KEY_PRESS) &&
Note: See TracChangeset for help on using the changeset viewer.