summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorShelley Chen <shchen@google.com>2020-10-17 00:53:41 -0700
committerJulius Werner <jwerner@chromium.org>2020-10-20 23:26:15 +0000
commita45f8959c02cd73d8eebe5e39c0fa9957bc05ae3 (patch)
tree2e7a760cdff1e2114b18f1b1e66e74538d414743 /src
parentc1040f3ef43bf906b71746e3e0a07dbb4a44febe (diff)
downloadcoreboot-a45f8959c02cd73d8eebe5e39c0fa9957bc05ae3.tar.gz
coreboot-a45f8959c02cd73d8eebe5e39c0fa9957bc05ae3.tar.bz2
coreboot-a45f8959c02cd73d8eebe5e39c0fa9957bc05ae3.zip
mrc_cache: Remove unnecessary data checksum calculation
When MRC_SAVE_HASH_IN_TPM is selected, we can just use the TPM hash to verify the MRC_CACHE data. Thus, we don't need to calculate the checksum anymore in this case. BUG=b:150502246 BRANCH=None TEST=make sure memory training still works on nami Change-Id: I1db4469da49755805b541f50c7ef2f9cdb749425 Signed-off-by: Shelley Chen <shchen@google.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/46515 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Furquan Shaikh <furquan@google.com>
Diffstat (limited to 'src')
-rw-r--r--src/drivers/mrc_cache/mrc_cache.c21
1 files changed, 11 insertions, 10 deletions
diff --git a/src/drivers/mrc_cache/mrc_cache.c b/src/drivers/mrc_cache/mrc_cache.c
index 1bbb426b5df5..3b98dbaa637f 100644
--- a/src/drivers/mrc_cache/mrc_cache.c
+++ b/src/drivers/mrc_cache/mrc_cache.c
@@ -193,19 +193,20 @@ static int mrc_data_valid(int type, const struct mrc_metadata *md,
if (md->data_size != data_size)
return -1;
- checksum = compute_ip_checksum(data, data_size);
+ hash_idx = cr->tpm_hash_index;
+ if (hash_idx && CONFIG(MRC_SAVE_HASH_IN_TPM)) {
+ if (!mrc_cache_verify_hash(hash_idx, data, data_size))
+ return -1;
+ } else {
+ checksum = compute_ip_checksum(data, data_size);
- if (md->data_checksum != checksum) {
- printk(BIOS_ERR, "MRC: data checksum mismatch: %x vs %x\n",
- md->data_checksum, checksum);
- return -1;
+ if (md->data_checksum != checksum) {
+ printk(BIOS_ERR, "MRC: data checksum mismatch: %x vs %x\n",
+ md->data_checksum, checksum);
+ return -1;
+ }
}
- hash_idx = cr->tpm_hash_index;
- if (hash_idx && CONFIG(MRC_SAVE_HASH_IN_TPM) &&
- !mrc_cache_verify_hash(hash_idx, data, data_size))
- return -1;
-
return 0;
}