summaryrefslogtreecommitdiff
path: root/firmware
diff options
context:
space:
mode:
authorMathew King <mathewk@chromium.org>2019-03-13 10:24:06 -0600
committerchrome-bot <chrome-bot@chromium.org>2019-03-26 04:43:06 -0700
commit06a65e7f3b6a8b5d4f3d8c91ca2447ba399c77d2 (patch)
tree8e8b7fd9a13f7be64205e8d971101c2972220f6c /firmware
parent4cab32fbf65910513e2e6cbda1d283d6afce59a5 (diff)
downloadvboot-06a65e7f3b6a8b5d4f3d8c91ca2447ba399c77d2.tar.gz
Don't allow vowels in vendor data except first char
BUG=b:128419534 TEST=make runmisctests BRANCH=none Change-Id: I1b3403cbe9ce93d9341c7ce32277d75462da894f Signed-off-by: Mathew King <mathewk@chromium.org> Reviewed-on: https://chromium-review.googlesource.com/1521216 Commit-Ready: ChromeOS CL Exonerator Bot <chromiumos-cl-exonerator@appspot.gserviceaccount.com> Reviewed-by: Julius Werner <jwerner@chromium.org>
Diffstat (limited to 'firmware')
-rw-r--r--firmware/lib/vboot_ui.c12
1 files changed, 9 insertions, 3 deletions
diff --git a/firmware/lib/vboot_ui.c b/firmware/lib/vboot_ui.c
index 65f47986..14f8aabe 100644
--- a/firmware/lib/vboot_ui.c
+++ b/firmware/lib/vboot_ui.c
@@ -227,6 +227,11 @@ VbError_t vb2_altfw_ui(struct vb2_context *ctx)
return 0;
}
+static inline int is_vowel(uint32_t key) {
+ return key == 'A' || key == 'E' || key == 'I' ||
+ key == 'O' || key == 'U';
+}
+
/*
* Prompt the user to enter the vendor data
*/
@@ -262,13 +267,14 @@ VbError_t vb2_enter_vendor_data_ui(struct vb2_context *ctx, char *data_value)
key = toupper(key);
case '0'...'9':
case 'A'...'Z':
- if (len < VENDOR_DATA_LENGTH) {
+ if ((len > 0 && is_vowel(key)) ||
+ len >= VENDOR_DATA_LENGTH) {
+ vb2_error_beep(VB_BEEP_NOT_ALLOWED);
+ } else {
data_value[len++] = key;
data_value[len] = '\0';
VbDisplayScreen(ctx, VB_SCREEN_SET_VENDOR_DATA,
1, &data);
- } else {
- vb2_error_beep(VB_BEEP_NOT_ALLOWED);
}
VB2_DEBUG("Vendor Data UI - vendor_data: %s\n",