// SPDX-License-Identifier: GPL-2.0+ /* * efi_selftest_fdt * * Copyright (c) 2022 Heinrich Schuchardt * * Check the EFI_CONFORMANCE_PROFILE_TABLE */ #include static const efi_guid_t guid_ecpt = EFI_CONFORMANCE_PROFILES_TABLE_GUID; static const efi_guid_t guid_ebbr_2_1 = EFI_CONFORMANCE_PROFILE_EBBR_2_1_GUID; /* * 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; } if (CONFIG_IS_ENABLED(EFI_EBBR_2_1_CONFORMANCE)) { ++expected_entries; if (ecpt_find_guid(ecpt, &guid_ebbr_2_1)) 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, };