mirror of
https://github.com/u-boot/u-boot.git
synced 2024-12-04 10:03:41 +08:00
menu: Factor out menu-keypress decoding
Move this code into a separate function so that it can be used in the new VBE menu. Signed-off-by: Simon Glass <sjg@chromium.org>
This commit is contained in:
parent
24d8e1b37b
commit
9e7ac0b0be
@ -483,26 +483,11 @@ enum bootmenu_key bootmenu_autoboot_loop(struct bootmenu_data *menu,
|
|||||||
return key;
|
return key;
|
||||||
}
|
}
|
||||||
|
|
||||||
enum bootmenu_key bootmenu_loop(struct bootmenu_data *menu,
|
enum bootmenu_key bootmenu_conv_key(int ichar)
|
||||||
struct cli_ch_state *cch)
|
|
||||||
{
|
{
|
||||||
enum bootmenu_key key = BKEY_NONE;
|
enum bootmenu_key key;
|
||||||
int c;
|
|
||||||
|
|
||||||
c = cli_ch_process(cch, 0);
|
switch (ichar) {
|
||||||
if (!c) {
|
|
||||||
while (!c && !tstc()) {
|
|
||||||
schedule();
|
|
||||||
mdelay(10);
|
|
||||||
c = cli_ch_process(cch, -ETIMEDOUT);
|
|
||||||
}
|
|
||||||
if (!c) {
|
|
||||||
c = getchar();
|
|
||||||
c = cli_ch_process(cch, c);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
switch (c) {
|
|
||||||
case '\n':
|
case '\n':
|
||||||
/* enter key was pressed */
|
/* enter key was pressed */
|
||||||
key = BKEY_SELECT;
|
key = BKEY_SELECT;
|
||||||
@ -527,7 +512,34 @@ enum bootmenu_key bootmenu_loop(struct bootmenu_data *menu,
|
|||||||
case ' ':
|
case ' ':
|
||||||
key = BKEY_SPACE;
|
key = BKEY_SPACE;
|
||||||
break;
|
break;
|
||||||
|
default:
|
||||||
|
key = BKEY_NONE;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
return key;
|
return key;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
enum bootmenu_key bootmenu_loop(struct bootmenu_data *menu,
|
||||||
|
struct cli_ch_state *cch)
|
||||||
|
{
|
||||||
|
enum bootmenu_key key;
|
||||||
|
int c;
|
||||||
|
|
||||||
|
c = cli_ch_process(cch, 0);
|
||||||
|
if (!c) {
|
||||||
|
while (!c && !tstc()) {
|
||||||
|
schedule();
|
||||||
|
mdelay(10);
|
||||||
|
c = cli_ch_process(cch, -ETIMEDOUT);
|
||||||
|
}
|
||||||
|
if (!c) {
|
||||||
|
c = getchar();
|
||||||
|
c = cli_ch_process(cch, c);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
key = bootmenu_conv_key(c);
|
||||||
|
|
||||||
|
return key;
|
||||||
|
}
|
||||||
|
@ -53,6 +53,8 @@ enum bootmenu_key {
|
|||||||
BKEY_PLUS,
|
BKEY_PLUS,
|
||||||
BKEY_MINUS,
|
BKEY_MINUS,
|
||||||
BKEY_SPACE,
|
BKEY_SPACE,
|
||||||
|
|
||||||
|
BKEY_COUNT,
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -101,4 +103,12 @@ enum bootmenu_key bootmenu_autoboot_loop(struct bootmenu_data *menu,
|
|||||||
enum bootmenu_key bootmenu_loop(struct bootmenu_data *menu,
|
enum bootmenu_key bootmenu_loop(struct bootmenu_data *menu,
|
||||||
struct cli_ch_state *cch);
|
struct cli_ch_state *cch);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* bootmenu_conv_key() - Convert a U-Boot keypress into a menu key
|
||||||
|
*
|
||||||
|
* @ichar: Keypress to convert (ASCII, including control characters)
|
||||||
|
* Returns: Menu key that corresponds to @ichar, or BKEY_NONE if none
|
||||||
|
*/
|
||||||
|
enum bootmenu_key bootmenu_conv_key(int ichar);
|
||||||
|
|
||||||
#endif /* __MENU_H__ */
|
#endif /* __MENU_H__ */
|
||||||
|
Loading…
Reference in New Issue
Block a user