mirror of
https://github.com/ARM-software/arm-trusted-firmware.git
synced 2025-04-18 02:24:18 +00:00

Introduce PLAT_RSS_NOT_SUPPORTED build config to provide a mocked version of PSA APIs. The goal is to test the RSS backend based measured boot and attestation token request integration on such a platform (AEM FVP) where RSS is otherwise unsupported. The mocked PSA API version does not send a request to the RSS, it only returns with success and hard-coded values. Signed-off-by: Tamas Ban <tamas.ban@arm.com> Change-Id: Ice8d174adf828c1df08fc589f0e17abd1e382a4d
129 lines
3.4 KiB
C
129 lines
3.4 KiB
C
/*
|
|
* Copyright (c) 2022, Arm Limited. All rights reserved.
|
|
*
|
|
* SPDX-License-Identifier: BSD-3-Clause
|
|
*
|
|
*/
|
|
|
|
#include <string.h>
|
|
|
|
#include <common/debug.h>
|
|
#include <measured_boot.h>
|
|
#include <psa/client.h>
|
|
#include <psa_manifest/sid.h>
|
|
|
|
#include "measured_boot_private.h"
|
|
|
|
static void print_byte_array(const uint8_t *array, size_t len)
|
|
{
|
|
unsigned int i;
|
|
|
|
if (array == NULL || len == 0U) {
|
|
(void)printf("\n");
|
|
}
|
|
|
|
for (i = 0U; i < len; ++i) {
|
|
(void)printf(" %02x", array[i]);
|
|
if ((i & U(0xF)) == U(0xF)) {
|
|
(void)printf("\n");
|
|
if (i < (len - 1U)) {
|
|
INFO("\t\t:");
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
static void log_measurement(uint8_t index,
|
|
const uint8_t *signer_id,
|
|
size_t signer_id_size,
|
|
const uint8_t *version, /* string */
|
|
uint32_t measurement_algo,
|
|
const uint8_t *sw_type, /* string */
|
|
const uint8_t *measurement_value,
|
|
size_t measurement_value_size,
|
|
bool lock_measurement)
|
|
{
|
|
INFO("Measured boot extend measurement:\n");
|
|
INFO(" - slot : %u\n", index);
|
|
INFO(" - signer_id :");
|
|
print_byte_array(signer_id, signer_id_size);
|
|
INFO(" - version : %s\n", version);
|
|
INFO(" - algorithm : %x\n", measurement_algo);
|
|
INFO(" - sw_type : %s\n", sw_type);
|
|
INFO(" - measurement :");
|
|
print_byte_array(measurement_value, measurement_value_size);
|
|
INFO(" - locking : %s\n", lock_measurement ? "true" : "false");
|
|
}
|
|
|
|
#if !PLAT_RSS_NOT_SUPPORTED
|
|
psa_status_t
|
|
rss_measured_boot_extend_measurement(uint8_t index,
|
|
const uint8_t *signer_id,
|
|
size_t signer_id_size,
|
|
const uint8_t *version,
|
|
size_t version_size,
|
|
uint32_t measurement_algo,
|
|
const uint8_t *sw_type,
|
|
size_t sw_type_size,
|
|
const uint8_t *measurement_value,
|
|
size_t measurement_value_size,
|
|
bool lock_measurement)
|
|
{
|
|
struct measured_boot_extend_iovec_t extend_iov = {
|
|
.index = index,
|
|
.lock_measurement = lock_measurement,
|
|
.measurement_algo = measurement_algo,
|
|
.sw_type = {0},
|
|
.sw_type_size = sw_type_size,
|
|
};
|
|
|
|
psa_invec in_vec[] = {
|
|
{.base = &extend_iov,
|
|
.len = sizeof(struct measured_boot_extend_iovec_t)},
|
|
{.base = signer_id, .len = signer_id_size},
|
|
{.base = version, .len = version_size},
|
|
{.base = measurement_value, .len = measurement_value_size}
|
|
};
|
|
|
|
uint32_t sw_type_size_limited;
|
|
|
|
if (sw_type != NULL) {
|
|
sw_type_size_limited = (sw_type_size < SW_TYPE_MAX_SIZE) ?
|
|
sw_type_size : SW_TYPE_MAX_SIZE;
|
|
memcpy(extend_iov.sw_type, sw_type, sw_type_size_limited);
|
|
}
|
|
|
|
log_measurement(index, signer_id, signer_id_size,
|
|
version, measurement_algo, sw_type,
|
|
measurement_value, measurement_value_size,
|
|
lock_measurement);
|
|
|
|
return psa_call(RSS_MEASURED_BOOT_HANDLE,
|
|
RSS_MEASURED_BOOT_EXTEND,
|
|
in_vec, IOVEC_LEN(in_vec),
|
|
NULL, 0);
|
|
}
|
|
|
|
#else /* !PLAT_RSS_NOT_SUPPORTED */
|
|
|
|
psa_status_t
|
|
rss_measured_boot_extend_measurement(uint8_t index,
|
|
const uint8_t *signer_id,
|
|
size_t signer_id_size,
|
|
const uint8_t *version,
|
|
size_t version_size,
|
|
uint32_t measurement_algo,
|
|
const uint8_t *sw_type,
|
|
size_t sw_type_size,
|
|
const uint8_t *measurement_value,
|
|
size_t measurement_value_size,
|
|
bool lock_measurement)
|
|
{
|
|
log_measurement(index, signer_id, signer_id_size,
|
|
version, measurement_algo, sw_type,
|
|
measurement_value, measurement_value_size,
|
|
lock_measurement);
|
|
|
|
return PSA_SUCCESS;
|
|
}
|
|
#endif /* !PLAT_RSS_NOT_SUPPORTED */
|