Silently keeping entries in the list if the address matches, but the
page count doesn't is a bad idea, and can lead to double frees.
grub_efi_free_pages() have already freed parts of this block by this
point, and thus keeping the whole block in the list and freeing it again
at exit can lead to double frees.
Signed-off-by: Mate Kukri <mate.kukri@canonical.com>
Reviewed-by: Daniel Kiper <daniel.kiper@oracle.com>
for (eap = NULL, ea = efi_allocated_memory; ea; eap = ea, ea = ea->next)
{
- if (ea->address != address || ea->pages != pages)
- continue;
+ if (ea->address != address)
+ continue;
+ if (ea->pages != pages)
+ grub_fatal ("grub_efi_drop_alloc() called with wrong page count");
/* Remove the current entry from the list. */
if (eap)