]> git.dujemihanovic.xyz Git - u-boot.git/commitdiff
efi_loader: capsule: enforce guid check in api and capsule_on_disk
authorAKASHI Takahiro <takahiro.akashi@linaro.org>
Thu, 27 Jul 2023 00:38:00 +0000 (09:38 +0900)
committerHeinrich Schuchardt <heinrich.schuchardt@canonical.com>
Thu, 3 Aug 2023 07:21:02 +0000 (09:21 +0200)
While UPDATE_CAPSULE api is not fully implemented, this interface and
capsule-on-disk feature should behave in the same way, especially in
handling an empty capsule for fwu multibank, for future enhancement.

So move the guid check into efi_capsule_update_firmware().

Fixed: commit a6aafce494ab ("efi_loader: use efi_update_capsule_firmware() for capsule on disk")
Reported-by: Michal Simek <michal.simek@amd.com>
Signed-off-by: AKASHI Takahiro <takahiro.akashi@linaro.org>
Reported-by: Michal Simek <michal.simek@amd.com>
Signed-off-by: AKASHI Takahiro <takahiro.akashi@linaro.org>
Tested-by: Michal Simek <michal.simek@amd.com>
Reviewed-by: Ilias Apalodimas <ilias.apalodimas@linaro.org>
lib/efi_loader/efi_capsule.c

index 7a6f195cbc02264f2d2ad8858420403cc9a08dc2..ddf8153e09829ca1d9fe3b9474d90e7ec090e790 100644 (file)
@@ -581,6 +581,13 @@ static efi_status_t efi_capsule_update_firmware(
                fw_accept_os = capsule_data->flags & FW_ACCEPT_OS ? 0x1 : 0x0;
        }
 
+       if (guidcmp(&capsule_data->capsule_guid,
+                   &efi_guid_firmware_management_capsule_id)) {
+               log_err("Unsupported capsule type: %pUs\n",
+                       &capsule_data->capsule_guid);
+               return EFI_UNSUPPORTED;
+       }
+
        /* sanity check */
        if (capsule_data->header_size < sizeof(*capsule) ||
            capsule_data->header_size >= capsule_data->capsule_image_size)
@@ -751,15 +758,7 @@ efi_status_t EFIAPI efi_update_capsule(
 
                log_debug("Capsule[%d] (guid:%pUs)\n",
                          i, &capsule->capsule_guid);
-               if (!guidcmp(&capsule->capsule_guid,
-                            &efi_guid_firmware_management_capsule_id)) {
-                       ret  = efi_capsule_update_firmware(capsule);
-               } else {
-                       log_err("Unsupported capsule type: %pUs\n",
-                               &capsule->capsule_guid);
-                       ret = EFI_UNSUPPORTED;
-               }
-
+               ret  = efi_capsule_update_firmware(capsule);
                if (ret != EFI_SUCCESS)
                        goto out;
        }