]> git.baikalelectronics.ru Git - uboot.git/commit
cli: Correct several bugs in cli_getch()
authorSimon Glass <sjg@chromium.org>
Mon, 27 Mar 2023 19:34:13 +0000 (08:34 +1300)
committerTom Rini <trini@konsulko.com>
Tue, 28 Mar 2023 13:25:51 +0000 (09:25 -0400)
commit09a9309756f98c9be7b8135f2cbaea493c69149d
tree2453033d5e2077a2541844b4781e4d24623db11a
parentff986e6a383f2cc470159d1d8f2fa59e3bb94619
cli: Correct several bugs in cli_getch()

This function does not behave as expected when unknown escape sequences
are sent to it:

- it fails to store (and thus echo) the last character of the invalid
  sequence
- it fails to set esc_len to 0 when it finishes emitting the invalid
  sequence, meaning that the following character will appear to be part
  of a new escape sequence
- it processes the first character of the rejected sequence as a valid
  character, just starting the sequence all over again

The last two bugs conspire to produce an "impossible condition #876"
message which is the main symptom of this behaviour.

Fix these bugs and add a test to verify the behaviour.

Signed-off-by: Simon Glass <sjg@chromium.org>
Reported-by: Heinrich Schuchardt <xypron.glpk@gmx.de>
common/cli_getch.c
test/common/Makefile
test/common/cread.c [new file with mode: 0644]