summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
authorJulius Werner <jwerner@chromium.org>2015-05-15 12:50:07 -0700
committerChromeOS Commit Bot <chromeos-commit-bot@chromium.org>2015-05-16 01:42:20 +0000
commitfb4e4080112d9005f83b57551ab19cbf478da36a (patch)
tree1d7f42ca5856dfc0bda6562c72f553f167df91db /tests
parentdc49a6827670abc0f2dc45178c2623e070ff5961 (diff)
downloadvboot-fb4e4080112d9005f83b57551ab19cbf478da36a.tar.gz
vboot2: Support VB2_GBB_FLAG_DISABLE_FW_ROLLBACK_CHECK
Looks like the DISABLE_FW_ROLLBACK_CHECK GBB flag (0x200) was forgotten in the vboot2 implementation. It's too late for Veyron now, but let's at least fix it for future devices. BRANCH=none BUG=None TEST=make runtests Change-Id: I867f7aada28be3897efda73a6bdc3b0848c23dca Signed-off-by: Julius Werner <jwerner@chromium.org> Reviewed-on: https://chromium-review.googlesource.com/271419 Reviewed-by: Bill Richardson <wfrichar@chromium.org>
Diffstat (limited to 'tests')
-rw-r--r--tests/vb20_misc_tests.c10
-rw-r--r--tests/vb21_misc_tests.c10
2 files changed, 20 insertions, 0 deletions
diff --git a/tests/vb20_misc_tests.c b/tests/vb20_misc_tests.c
index 8021888c..e3a5123f 100644
--- a/tests/vb20_misc_tests.c
+++ b/tests/vb20_misc_tests.c
@@ -268,6 +268,11 @@ static void verify_keyblock_tests(void)
TEST_EQ(vb2_load_fw_keyblock(&cc),
VB2_ERROR_FW_KEYBLOCK_VERSION_ROLLBACK,
"keyblock rollback");
+
+ reset_common_data(FOR_KEYBLOCK);
+ kb->data_key.key_version = 1;
+ sd->gbb_flags |= VB2_GBB_FLAG_DISABLE_FW_ROLLBACK_CHECK;
+ TEST_SUCC(vb2_load_fw_keyblock(&cc), "keyblock rollback with GBB flag");
}
static void verify_preamble_tests(void)
@@ -346,6 +351,11 @@ static void verify_preamble_tests(void)
"preamble version rollback");
reset_common_data(FOR_PREAMBLE);
+ pre->firmware_version = 1;
+ sd->gbb_flags |= VB2_GBB_FLAG_DISABLE_FW_ROLLBACK_CHECK;
+ TEST_SUCC(vb2_load_fw_preamble(&cc), "version rollback with GBB flag");
+
+ reset_common_data(FOR_PREAMBLE);
pre->firmware_version = 3;
TEST_SUCC(vb2_load_fw_preamble(&cc),
"preamble version roll forward");
diff --git a/tests/vb21_misc_tests.c b/tests/vb21_misc_tests.c
index 826c3fb1..d70cabd5 100644
--- a/tests/vb21_misc_tests.c
+++ b/tests/vb21_misc_tests.c
@@ -274,6 +274,11 @@ static void load_keyblock_tests(void)
TEST_EQ(vb2_load_fw_keyblock(&ctx),
VB2_ERROR_FW_KEYBLOCK_VERSION_ROLLBACK,
"keyblock rollback");
+
+ reset_common_data(FOR_KEYBLOCK);
+ dk->key_version = 1;
+ sd->gbb_flags |= VB2_GBB_FLAG_DISABLE_FW_ROLLBACK_CHECK;
+ TEST_SUCC(vb2_load_fw_keyblock(&ctx), "keyblock rollback + GBB flag");
}
static void load_preamble_tests(void)
@@ -353,6 +358,11 @@ static void load_preamble_tests(void)
"preamble version rollback");
reset_common_data(FOR_PREAMBLE);
+ pre->fw_version = 1;
+ sd->gbb_flags |= VB2_GBB_FLAG_DISABLE_FW_ROLLBACK_CHECK;
+ TEST_SUCC(vb2_load_fw_preamble(&ctx), "version rollback with GBB flag");
+
+ reset_common_data(FOR_PREAMBLE);
pre->fw_version = 3;
TEST_SUCC(vb2_load_fw_preamble(&ctx),
"preamble version roll forward");