libpayload: find source of input characters
This change makes it possible for vboot to avoid an exploit that could cause involuntary switch to dev mode. It gives depthcharge/vboot some information on the type of input device that generated a key. BUG=chrome-os-partner:21729 TEST=manually tested for panther BRANCH=none CQ-DEPEND=CL:182420,CL:182241,CL:182946 Change-Id: I87bdac34bfc50f3adb0b35a2c57a8f95f4fbc35b Signed-off-by: Matt DeVillier <matt.devillier@gmail.com> Signed-off-by: Paul Menzel <paulepanter@users.sourceforge.net> Reviewed-on: https://chromium-review.googlesource.com/182357 Reviewed-by: Luigi Semenzato <semenzato@chromium.org> Tested-by: Luigi Semenzato <semenzato@chromium.org> Commit-Queue: Luigi Semenzato <semenzato@chromium.org> Reviewed-on: http://review.coreboot.org/6003 Tested-by: build bot (Jenkins) Reviewed-by: Patrick Georgi <patrick@georgi-clan.de>
This commit is contained in:
committed by
Patrick Georgi
parent
f4d1f3a4d9
commit
562db3bb3f
@ -247,12 +247,18 @@ int set_option_from_string(const struct nvram_accessor *nvram, struct cb_cmos_op
|
||||
* @defgroup console Console functions
|
||||
* @{
|
||||
*/
|
||||
typedef enum {
|
||||
CONSOLE_INPUT_TYPE_UNKNOWN = 0,
|
||||
CONSOLE_INPUT_TYPE_USB,
|
||||
} console_input_type;
|
||||
|
||||
void console_init(void);
|
||||
int putchar(unsigned int c);
|
||||
int puts(const char *s);
|
||||
int havekey(void);
|
||||
int getchar(void);
|
||||
int getchar_timeout(int *ms);
|
||||
console_input_type last_key_input_type(void);
|
||||
|
||||
extern int last_putchar;
|
||||
|
||||
@ -261,6 +267,7 @@ struct console_input_driver {
|
||||
struct console_input_driver *next;
|
||||
int (*havekey) (void);
|
||||
int (*getchar) (void);
|
||||
console_input_type input_type;
|
||||
};
|
||||
|
||||
struct console_output_driver;
|
||||
|
Reference in New Issue
Block a user