Hello,

I'm very sorry for having submitted a broken patch earlier, I didn't notice I had not committed the efi.h file which is now defining the required grub_efi_free_pool() function.

Renaud.

Le 9/2/25 à 1:55 PM, Renaud Métrich a écrit :
Signed-off-by: Renaud Métrich <[email protected]>
---
  grub-core/commands/efi/lsefi.c |  4 ++++
  include/grub/efi/efi.h         | 27 +++++++++++++++++++++++++++
  2 files changed, 31 insertions(+)

diff --git a/grub-core/commands/efi/lsefi.c b/grub-core/commands/efi/lsefi.c
index 7b8316d41..bda25a3a9 100644
--- a/grub-core/commands/efi/lsefi.c
+++ b/grub-core/commands/efi/lsefi.c
@@ -127,8 +127,12 @@ grub_cmd_lsefi (grub_command_t cmd __attribute__ 
((unused)),
            grub_printf ("  %pG\n", protocols[j]);
        }
+ if (protocols)
+       grub_efi_free_pool (protocols);
      }
+ grub_free (handles);
+
    return 0;
  }
diff --git a/include/grub/efi/efi.h b/include/grub/efi/efi.h
index b4d2f2d46..538bdcda8 100644
--- a/include/grub/efi/efi.h
+++ b/include/grub/efi/efi.h
@@ -71,6 +71,7 @@ EXPORT_FUNC(grub_efi_get_memory_map) (grub_efi_uintn_t 
*memory_map_size,
                                      grub_efi_uintn_t *descriptor_size,
                                      grub_efi_uint32_t *descriptor_version);
  void grub_efi_memory_fini (void);
+
  grub_efi_loaded_image_t *EXPORT_FUNC(grub_efi_get_loaded_image) 
(grub_efi_handle_t image_handle);
  void EXPORT_FUNC(grub_efi_print_device_path) (grub_efi_device_path_t *dp);
  char *EXPORT_FUNC(grub_efi_get_filename) (grub_efi_device_path_t *dp);
@@ -193,4 +194,30 @@ struct grub_net_card;
  grub_efi_handle_t
  grub_efinet_get_device_handle (struct grub_net_card *card);
+static inline grub_efi_status_t
+__attribute__((__unused__))
+grub_efi_allocate_pool (grub_efi_memory_type_t pool_type,
+                       grub_efi_uintn_t buffer_size,
+                       void **buffer)
+{
+  grub_efi_boot_services_t *b;
+  grub_efi_status_t status;
+
+  b = grub_efi_system_table->boot_services;
+  status = b->allocate_pool(pool_type, buffer_size, buffer);
+  return status;
+}
+
+static inline grub_efi_status_t
+__attribute__((__unused__))
+grub_efi_free_pool (void *buffer)
+{
+  grub_efi_boot_services_t *b;
+  grub_efi_status_t status;
+
+  b = grub_efi_system_table->boot_services;
+  status = b->free_pool(buffer);
+  return status;
+}
+
  #endif /* ! GRUB_EFI_EFI_HEADER */

Attachment: OpenPGP_signature.asc
Description: OpenPGP digital signature

_______________________________________________
Grub-devel mailing list
[email protected]
https://lists.gnu.org/mailman/listinfo/grub-devel

Reply via email to