cli: Correct handling of invalid escape sequences in cread_line()
The second call to cli_ch_process() is in the wrong place, meaning that the one of the characters of an invalid escape sequence is swallowed instead of being returned. Fix the bug and add a test to cover this. This behaviour matches that of the code before cli_getch() was introduced. This was verified on the commit beforeb08e9d4b66
i.e.:7d850f85aa
("sandbox: Enable mmc command and legacy images") Signed-off-by: Simon Glass <sjg@chromium.org> Reported-by: Heinrich Schuchardt <xypron.glpk@gmx.de>
This commit is contained in:
parent
17b45e684a
commit
be0169f07e
3 changed files with 48 additions and 4 deletions
|
@ -284,10 +284,9 @@ static int cread_line(const char *const prompt, char *buf, unsigned int *len,
|
||||||
}
|
}
|
||||||
|
|
||||||
ichar = getcmd_getch();
|
ichar = getcmd_getch();
|
||||||
|
ichar = cli_ch_process(cch, ichar);
|
||||||
}
|
}
|
||||||
|
|
||||||
ichar = cli_ch_process(cch, ichar);
|
|
||||||
|
|
||||||
/* ichar=0x0 when error occurs in U-Boot getc */
|
/* ichar=0x0 when error occurs in U-Boot getc */
|
||||||
if (!ichar)
|
if (!ichar)
|
||||||
continue;
|
continue;
|
||||||
|
|
|
@ -98,8 +98,8 @@ int cli_readline(const char *const prompt);
|
||||||
*
|
*
|
||||||
* @prompt: Prompt to display
|
* @prompt: Prompt to display
|
||||||
* @buffer: Place to put the line that is entered
|
* @buffer: Place to put the line that is entered
|
||||||
* @timeout: Timeout in milliseconds, 0 if none
|
* @timeout: Timeout in seconds, 0 if none
|
||||||
* Return: command line length excluding terminator, or -ve on error: of the
|
* Return: command line length excluding terminator, or -ve on error: if the
|
||||||
* timeout is exceeded (either CONFIG_BOOT_RETRY_TIME or the timeout
|
* timeout is exceeded (either CONFIG_BOOT_RETRY_TIME or the timeout
|
||||||
* parameter), then -2 is returned. If a break is detected (Ctrl-C) then
|
* parameter), then -2 is returned. If a break is detected (Ctrl-C) then
|
||||||
* -1 is returned.
|
* -1 is returned.
|
||||||
|
|
|
@ -46,3 +46,48 @@ static int cli_ch_test(struct unit_test_state *uts)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
COMMON_TEST(cli_ch_test, 0);
|
COMMON_TEST(cli_ch_test, 0);
|
||||||
|
|
||||||
|
static int cread_test(struct unit_test_state *uts)
|
||||||
|
{
|
||||||
|
int duration;
|
||||||
|
ulong start;
|
||||||
|
char buf[10];
|
||||||
|
|
||||||
|
/*
|
||||||
|
* useful for debugging
|
||||||
|
*
|
||||||
|
* gd->flags &= ~GD_FLG_RECORD;
|
||||||
|
* print_buffer(0, buf, 1, 7, 0);
|
||||||
|
*/
|
||||||
|
|
||||||
|
console_record_reset_enable();
|
||||||
|
|
||||||
|
/* simple input */
|
||||||
|
*buf = '\0';
|
||||||
|
ut_asserteq(4, console_in_puts("abc\n"));
|
||||||
|
ut_asserteq(3, cli_readline_into_buffer("-> ", buf, 1));
|
||||||
|
ut_asserteq_str("abc", buf);
|
||||||
|
|
||||||
|
/* try an escape sequence (cursor left after the 'c') */
|
||||||
|
*buf = '\0';
|
||||||
|
ut_asserteq(8, console_in_puts("abc\e[Dx\n"));
|
||||||
|
ut_asserteq(4, cli_readline_into_buffer("-> ", buf, 1));
|
||||||
|
ut_asserteq_str("abxc", buf);
|
||||||
|
|
||||||
|
/* invalid escape sequence */
|
||||||
|
*buf = '\0';
|
||||||
|
ut_asserteq(8, console_in_puts("abc\e[Xx\n"));
|
||||||
|
ut_asserteq(7, cli_readline_into_buffer("-> ", buf, 1));
|
||||||
|
ut_asserteq_str("abc\e[Xx", buf);
|
||||||
|
|
||||||
|
/* check timeout, should be between 1000 and 1050ms */
|
||||||
|
start = get_timer(0);
|
||||||
|
*buf = '\0';
|
||||||
|
ut_asserteq(-2, cli_readline_into_buffer("-> ", buf, 1));
|
||||||
|
duration = get_timer(start) - 1000;
|
||||||
|
ut_assert(duration >= 0);
|
||||||
|
ut_assert(duration < 50);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
COMMON_TEST(cread_test, 0);
|
||||||
|
|
Loading…
Reference in a new issue