security/vboot: Remove all tpm 1.2 functions for mrc hash in the tpm
Since MRC_SAVE_HASH_IN_TPM depends on TPM2, we can now remove the tpm 1.2 versions of functions that deal with mrc hash in the tpm as it will not be used by tpm 1.2 boards. Also move all antirollback functions that deal with mrc hash in the tpm under CONFIG(TPM2). BUG=b:150502246 BRANCH=None TEST=make sure boards are still compiling on coreboot Jenkins Change-Id: I446dde36ce2233fc40687892da1fb515ce35b82b Signed-off-by: Shelley Chen <shchen@google.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/46615 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Julius Werner <jwerner@chromium.org> Reviewed-by: Furquan Shaikh <furquan@google.com>
This commit is contained in:
parent
c47ed6e8c3
commit
17df7d634d
1 changed files with 41 additions and 70 deletions
|
@ -71,6 +71,8 @@ uint32_t antirollback_read_space_kernel(struct vb2_context *ctx)
|
||||||
return TPM_SUCCESS;
|
return TPM_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if CONFIG(TPM2)
|
||||||
|
|
||||||
static uint32_t read_space_mrc_hash(uint32_t index, uint8_t *data)
|
static uint32_t read_space_mrc_hash(uint32_t index, uint8_t *data)
|
||||||
{
|
{
|
||||||
RETURN_ON_FAILURE(tlcl_read(index, data,
|
RETURN_ON_FAILURE(tlcl_read(index, data,
|
||||||
|
@ -85,7 +87,6 @@ static uint32_t read_space_mrc_hash(uint32_t index, uint8_t *data)
|
||||||
*/
|
*/
|
||||||
static const uint8_t mrc_hash_data[HASH_NV_SIZE] = { };
|
static const uint8_t mrc_hash_data[HASH_NV_SIZE] = { };
|
||||||
|
|
||||||
#if CONFIG(TPM2)
|
|
||||||
/*
|
/*
|
||||||
* Different sets of NVRAM space attributes apply to the "ro" spaces,
|
* Different sets of NVRAM space attributes apply to the "ro" spaces,
|
||||||
* i.e. those which should not be possible to delete or modify once
|
* i.e. those which should not be possible to delete or modify once
|
||||||
|
@ -208,6 +209,45 @@ uint32_t antirollback_lock_space_firmware(void)
|
||||||
return tlcl_lock_nv_write(FIRMWARE_NV_INDEX);
|
return tlcl_lock_nv_write(FIRMWARE_NV_INDEX);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
uint32_t antirollback_read_space_mrc_hash(uint32_t index, uint8_t *data, uint32_t size)
|
||||||
|
{
|
||||||
|
if (size != HASH_NV_SIZE) {
|
||||||
|
VBDEBUG("TPM: Incorrect buffer size for hash idx 0x%x. "
|
||||||
|
"(Expected=0x%x Actual=0x%x).\n", index, HASH_NV_SIZE,
|
||||||
|
size);
|
||||||
|
return TPM_E_READ_FAILURE;
|
||||||
|
}
|
||||||
|
return read_space_mrc_hash(index, data);
|
||||||
|
}
|
||||||
|
|
||||||
|
uint32_t antirollback_write_space_mrc_hash(uint32_t index, const uint8_t *data, uint32_t size)
|
||||||
|
{
|
||||||
|
uint8_t spc_data[HASH_NV_SIZE];
|
||||||
|
uint32_t rv;
|
||||||
|
|
||||||
|
if (size != HASH_NV_SIZE) {
|
||||||
|
VBDEBUG("TPM: Incorrect buffer size for hash idx 0x%x. "
|
||||||
|
"(Expected=0x%x Actual=0x%x).\n", index, HASH_NV_SIZE,
|
||||||
|
size);
|
||||||
|
return TPM_E_WRITE_FAILURE;
|
||||||
|
}
|
||||||
|
|
||||||
|
rv = read_space_mrc_hash(index, spc_data);
|
||||||
|
if (rv == TPM_E_BADINDEX) {
|
||||||
|
/*
|
||||||
|
* If space is not defined already for hash, define
|
||||||
|
* new space.
|
||||||
|
*/
|
||||||
|
VBDEBUG("TPM: Initializing hash space.\n");
|
||||||
|
return set_mrc_hash_space(index, data);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (rv != TPM_SUCCESS)
|
||||||
|
return rv;
|
||||||
|
|
||||||
|
return safe_write(index, data, size);
|
||||||
|
}
|
||||||
|
|
||||||
uint32_t antirollback_lock_space_mrc_hash(uint32_t index)
|
uint32_t antirollback_lock_space_mrc_hash(uint32_t index)
|
||||||
{
|
{
|
||||||
return tlcl_lock_nv_write(index);
|
return tlcl_lock_nv_write(index);
|
||||||
|
@ -250,18 +290,6 @@ static uint32_t safe_define_space(uint32_t index, uint32_t perm, uint32_t size)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static uint32_t set_mrc_hash_space(uint32_t index, const uint8_t *data)
|
|
||||||
{
|
|
||||||
RETURN_ON_FAILURE(safe_define_space(index,
|
|
||||||
TPM_NV_PER_GLOBALLOCK |
|
|
||||||
TPM_NV_PER_PPWRITE,
|
|
||||||
HASH_NV_SIZE));
|
|
||||||
RETURN_ON_FAILURE(safe_write(index, data,
|
|
||||||
HASH_NV_SIZE));
|
|
||||||
|
|
||||||
return TPM_SUCCESS;
|
|
||||||
}
|
|
||||||
|
|
||||||
static uint32_t _factory_initialize_tpm(struct vb2_context *ctx)
|
static uint32_t _factory_initialize_tpm(struct vb2_context *ctx)
|
||||||
{
|
{
|
||||||
TPM_PERMANENT_FLAGS pflags;
|
TPM_PERMANENT_FLAGS pflags;
|
||||||
|
@ -316,16 +344,6 @@ static uint32_t _factory_initialize_tpm(struct vb2_context *ctx)
|
||||||
ctx->secdata_firmware,
|
ctx->secdata_firmware,
|
||||||
VB2_SECDATA_FIRMWARE_SIZE));
|
VB2_SECDATA_FIRMWARE_SIZE));
|
||||||
|
|
||||||
/*
|
|
||||||
* Define and set rec hash space, if available. No need to
|
|
||||||
* create the RW hash space because we will definitely boot
|
|
||||||
* once in normal mode before shipping, meaning that the space
|
|
||||||
* will get created with correct permissions while still in in
|
|
||||||
* our hands.
|
|
||||||
*/
|
|
||||||
if (CONFIG(VBOOT_HAS_REC_HASH_SPACE))
|
|
||||||
RETURN_ON_FAILURE(set_mrc_hash_space(MRC_REC_HASH_NV_INDEX, mrc_hash_data));
|
|
||||||
|
|
||||||
return TPM_SUCCESS;
|
return TPM_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -334,14 +352,6 @@ uint32_t antirollback_lock_space_firmware(void)
|
||||||
return tlcl_set_global_lock();
|
return tlcl_set_global_lock();
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t antirollback_lock_space_mrc_hash(uint32_t index)
|
|
||||||
{
|
|
||||||
/*
|
|
||||||
* Nothing needs to be done here, since global lock is already set while
|
|
||||||
* locking firmware space.
|
|
||||||
*/
|
|
||||||
return TPM_SUCCESS;
|
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -434,45 +444,6 @@ uint32_t antirollback_write_space_kernel(struct vb2_context *ctx)
|
||||||
return safe_write(KERNEL_NV_INDEX, ctx->secdata_kernel, size);
|
return safe_write(KERNEL_NV_INDEX, ctx->secdata_kernel, size);
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t antirollback_read_space_mrc_hash(uint32_t index, uint8_t *data, uint32_t size)
|
|
||||||
{
|
|
||||||
if (size != HASH_NV_SIZE) {
|
|
||||||
VBDEBUG("TPM: Incorrect buffer size for hash idx 0x%x. "
|
|
||||||
"(Expected=0x%x Actual=0x%x).\n", index, HASH_NV_SIZE,
|
|
||||||
size);
|
|
||||||
return TPM_E_READ_FAILURE;
|
|
||||||
}
|
|
||||||
return read_space_mrc_hash(index, data);
|
|
||||||
}
|
|
||||||
|
|
||||||
uint32_t antirollback_write_space_mrc_hash(uint32_t index, const uint8_t *data, uint32_t size)
|
|
||||||
{
|
|
||||||
uint8_t spc_data[HASH_NV_SIZE];
|
|
||||||
uint32_t rv;
|
|
||||||
|
|
||||||
if (size != HASH_NV_SIZE) {
|
|
||||||
VBDEBUG("TPM: Incorrect buffer size for hash idx 0x%x. "
|
|
||||||
"(Expected=0x%x Actual=0x%x).\n", index, HASH_NV_SIZE,
|
|
||||||
size);
|
|
||||||
return TPM_E_WRITE_FAILURE;
|
|
||||||
}
|
|
||||||
|
|
||||||
rv = read_space_mrc_hash(index, spc_data);
|
|
||||||
if (rv == TPM_E_BADINDEX) {
|
|
||||||
/*
|
|
||||||
* If space is not defined already for hash, define
|
|
||||||
* new space.
|
|
||||||
*/
|
|
||||||
VBDEBUG("TPM: Initializing hash space.\n");
|
|
||||||
return set_mrc_hash_space(index, data);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (rv != TPM_SUCCESS)
|
|
||||||
return rv;
|
|
||||||
|
|
||||||
return safe_write(index, data, size);
|
|
||||||
}
|
|
||||||
|
|
||||||
vb2_error_t vb2ex_tpm_clear_owner(struct vb2_context *ctx)
|
vb2_error_t vb2ex_tpm_clear_owner(struct vb2_context *ctx)
|
||||||
{
|
{
|
||||||
uint32_t rv;
|
uint32_t rv;
|
||||||
|
|
Loading…
Reference in a new issue