mirror of
https://github.com/u-boot/u-boot.git
synced 2025-05-09 03:21:51 +00:00
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>
This commit is contained in:
parent
41a88ad529
commit
17b45e684a
3 changed files with 52 additions and 2 deletions
|
@ -129,7 +129,7 @@ static int cli_ch_esc(struct cli_ch_state *cch, int ichar,
|
|||
|
||||
*actp = act;
|
||||
|
||||
return act == ESC_CONVERTED ? ichar : 0;
|
||||
return ichar;
|
||||
}
|
||||
|
||||
int cli_ch_process(struct cli_ch_state *cch, int ichar)
|
||||
|
@ -145,6 +145,7 @@ int cli_ch_process(struct cli_ch_state *cch, int ichar)
|
|||
return cch->esc_save[cch->emit_upto++];
|
||||
cch->emit_upto = 0;
|
||||
cch->emitting = false;
|
||||
cch->esc_len = 0;
|
||||
}
|
||||
return 0;
|
||||
} else if (ichar == -ETIMEDOUT) {
|
||||
|
@ -185,7 +186,7 @@ int cli_ch_process(struct cli_ch_state *cch, int ichar)
|
|||
cch->esc_save[cch->esc_len++] = ichar;
|
||||
ichar = cch->esc_save[cch->emit_upto++];
|
||||
cch->emitting = true;
|
||||
break;
|
||||
return ichar;
|
||||
case ESC_CONVERTED:
|
||||
/* valid escape sequence, return the resulting char */
|
||||
cch->esc_len = 0;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue