2022-09-03 13:58:19 +00:00
|
|
|
// SPDX-License-Identifier: GPL-2.0+
|
|
|
|
/*
|
|
|
|
* efi_selftest_fdt
|
|
|
|
*
|
|
|
|
* Copyright (c) 2022 Heinrich Schuchardt <xypron.glpk@gmx.de>
|
|
|
|
*
|
|
|
|
* Check the EFI_CONFORMANCE_PROFILE_TABLE
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <efi_selftest.h>
|
|
|
|
|
|
|
|
static const efi_guid_t guid_ecpt = EFI_CONFORMANCE_PROFILES_TABLE_GUID;
|
2022-12-16 16:55:04 +00:00
|
|
|
static const efi_guid_t guid_ebbr_2_1 = EFI_CONFORMANCE_PROFILE_EBBR_2_1_GUID;
|
2022-09-03 13:58:19 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* ecpt_find_guid() - find GUID in EFI Conformance Profile Table
|
|
|
|
*
|
|
|
|
* @ecpt: EFI Conformance Profile Table
|
|
|
|
* @guid: GUID to find
|
|
|
|
* Return: EFI_ST_SUCCESS for success
|
|
|
|
*/
|
|
|
|
static int ecpt_find_guid(struct efi_conformance_profiles_table *ecpt,
|
|
|
|
const efi_guid_t *guid) {
|
|
|
|
int i;
|
|
|
|
|
|
|
|
for (i = 0; i < ecpt->number_of_profiles; ++i) {
|
|
|
|
if (!memcmp(&ecpt->conformance_profiles[i], guid, 16))
|
|
|
|
return EFI_ST_SUCCESS;
|
|
|
|
}
|
|
|
|
efi_st_error("GUID %pU not found\n", guid);
|
|
|
|
return EFI_ST_FAILURE;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Execute unit test.
|
|
|
|
*
|
|
|
|
* Return: EFI_ST_SUCCESS for success
|
|
|
|
*/
|
|
|
|
static int execute(void)
|
|
|
|
{
|
|
|
|
struct efi_conformance_profiles_table *ecpt;
|
|
|
|
int expected_entries = 0;
|
|
|
|
|
|
|
|
ecpt = efi_st_get_config_table(&guid_ecpt);
|
|
|
|
|
|
|
|
if (!ecpt) {
|
|
|
|
efi_st_error("Missing EFI Conformance Profile Table\n");
|
|
|
|
return EFI_ST_FAILURE;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (ecpt->version != EFI_CONFORMANCE_PROFILES_TABLE_VERSION) {
|
|
|
|
efi_st_error("Wrong table version\n");
|
|
|
|
return EFI_ST_FAILURE;
|
|
|
|
}
|
|
|
|
|
2022-12-16 16:55:04 +00:00
|
|
|
if (CONFIG_IS_ENABLED(EFI_EBBR_2_1_CONFORMANCE)) {
|
2022-09-03 13:58:19 +00:00
|
|
|
++expected_entries;
|
2022-12-16 16:55:04 +00:00
|
|
|
if (ecpt_find_guid(ecpt, &guid_ebbr_2_1))
|
2022-09-03 13:58:19 +00:00
|
|
|
return EFI_ST_FAILURE;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (ecpt->number_of_profiles != expected_entries) {
|
|
|
|
efi_st_error("Expected %d entries, found %d\n",
|
|
|
|
expected_entries, ecpt->number_of_profiles);
|
|
|
|
return EFI_ST_FAILURE;
|
|
|
|
}
|
|
|
|
|
|
|
|
return EFI_ST_SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
EFI_UNIT_TEST(ecpt) = {
|
|
|
|
.name = "conformance profile table",
|
|
|
|
.phase = EFI_EXECUTE_BEFORE_BOOTTIME_EXIT,
|
|
|
|
.execute = execute,
|
|
|
|
};
|