From: Lennart Poettering Date: Fri, 11 Nov 2022 15:05:03 +0000 (+0100) Subject: efi: add efi_guid_equal() helper X-Git-Tag: v253-rc1~276^2~1 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=50b0b0d351e892d57a562a28dd8362b1e8cd76a9;p=thirdparty%2Fsystemd.git efi: add efi_guid_equal() helper --- diff --git a/src/boot/efi/devicetree.c b/src/boot/efi/devicetree.c index 03126706135..daba5582aad 100644 --- a/src/boot/efi/devicetree.c +++ b/src/boot/efi/devicetree.c @@ -10,7 +10,7 @@ static void *get_dtb_table(void) { for (UINTN i = 0; i < ST->NumberOfTableEntries; i++) - if (memcmp(&EfiDtbTableGuid, &ST->ConfigurationTable[i].VendorGuid, sizeof(EfiDtbTableGuid)) == 0) + if (efi_guid_equal(&ST->ConfigurationTable[i].VendorGuid, &EfiDtbTableGuid)) return ST->ConfigurationTable[i].VendorTable; return NULL; } diff --git a/src/boot/efi/part-discovery.c b/src/boot/efi/part-discovery.c index 14479c06eae..2659a5b6b47 100644 --- a/src/boot/efi/part-discovery.c +++ b/src/boot/efi/part-discovery.c @@ -134,7 +134,7 @@ static EFI_STATUS try_gpt( EFI_PARTITION_ENTRY *entry = (EFI_PARTITION_ENTRY *) ((uint8_t *) entries + gpt.gpt_header.SizeOfPartitionEntry * i); - if (memcmp(&entry->PartitionTypeGUID, type, sizeof(entry->PartitionTypeGUID)) != 0) + if (!efi_guid_equal(&entry->PartitionTypeGUID, type)) continue; if (entry->EndingLBA < entry->StartingLBA) /* Bogus? */ diff --git a/src/boot/efi/random-seed.c b/src/boot/efi/random-seed.c index 22ba1c5a30e..bdaed2625a6 100644 --- a/src/boot/efi/random-seed.c +++ b/src/boot/efi/random-seed.c @@ -142,8 +142,7 @@ EFI_STATUS process_random_seed(EFI_FILE *root_dir) { sha256_process_bytes(HASH_LABEL, sizeof(HASH_LABEL) - 1, &hash); for (size_t i = 0; i < ST->NumberOfTableEntries; ++i) - if (memcmp(&(const EFI_GUID)LINUX_EFI_RANDOM_SEED_TABLE_GUID, - &ST->ConfigurationTable[i].VendorGuid, sizeof(EFI_GUID)) == 0) { + if (efi_guid_equal(&ST->ConfigurationTable[i].VendorGuid, &(const EFI_GUID) LINUX_EFI_RANDOM_SEED_TABLE_GUID)) { previous_seed_table = ST->ConfigurationTable[i].VendorTable; break; } diff --git a/src/boot/efi/util.h b/src/boot/efi/util.h index fb525ba6363..bacc114114f 100644 --- a/src/boot/efi/util.h +++ b/src/boot/efi/util.h @@ -242,3 +242,7 @@ static inline bool in_hypervisor(void) { return false; } #endif + +static inline bool efi_guid_equal(const EFI_GUID *a, const EFI_GUID *b) { + return memcmp(a, b, sizeof(EFI_GUID)) == 0; +} diff --git a/src/boot/efi/vmm.c b/src/boot/efi/vmm.c index 2260b217b79..10d4a75ab20 100644 --- a/src/boot/efi/vmm.c +++ b/src/boot/efi/vmm.c @@ -18,7 +18,7 @@ /* detect direct boot */ bool is_direct_boot(EFI_HANDLE device) { EFI_STATUS err; - VENDOR_DEVICE_PATH *dp; + VENDOR_DEVICE_PATH *dp; /* NB: Alignment of this structure might be quirky! */ err = BS->HandleProtocol(device, &DevicePathProtocol, (void **) &dp); if (err != EFI_SUCCESS) @@ -27,7 +27,7 @@ bool is_direct_boot(EFI_HANDLE device) { /* 'qemu -kernel systemd-bootx64.efi' */ if (dp->Header.Type == MEDIA_DEVICE_PATH && dp->Header.SubType == MEDIA_VENDOR_DP && - memcmp(&dp->Guid, &(EFI_GUID)QEMU_KERNEL_LOADER_FS_MEDIA_GUID, sizeof(EFI_GUID)) == 0) + memcmp(&dp->Guid, &(EFI_GUID)QEMU_KERNEL_LOADER_FS_MEDIA_GUID, sizeof(EFI_GUID)) == 0) /* Don't change to efi_guid_equal() because EFI device path objects are not necessarily aligned! */ return true; /* loaded from firmware volume (sd-boot added to ovmf) */