efi: Allow efi_free() to be called with size of 0
authorRoy Franz <roy.franz@linaro.org>
Sun, 22 Sep 2013 22:45:38 +0000 (15:45 -0700)
committerMatt Fleming <matt.fleming@intel.com>
Wed, 25 Sep 2013 11:34:42 +0000 (12:34 +0100)
Make efi_free() safely callable with size of 0, similar to free() being
callable with NULL pointers, and do nothing in that case.
Remove size checks that this makes redundant.  This also avoids some
size checks in the ARM EFI stub code that will be added as well.

Signed-off-by: Roy Franz <roy.franz@linaro.org>
Signed-off-by: Matt Fleming <matt.fleming@intel.com>
arch/x86/boot/compressed/eboot.c
drivers/firmware/efi/efi-stub-helper.c

index bf2c35d5ec1ff99b8df61de120e7bea728ad2d1b..ef2181a96d09600c6c2e2389d60a4cd49a1800e7 100644 (file)
@@ -506,8 +506,7 @@ struct boot_params *make_boot_params(void *handle, efi_system_table_t *_table)
 
        return boot_params;
 fail2:
-       if (options_size)
-               efi_free(sys_table, options_size, hdr->cmd_line_ptr);
+       efi_free(sys_table, options_size, hdr->cmd_line_ptr);
 fail:
        efi_free(sys_table, 0x4000, (unsigned long)boot_params);
        return NULL;
index b314bf720272226088722796ebae0cf66dae708e..fda510fa357941f3c83b418ff0e45d93fdf70e9e 100644 (file)
@@ -255,6 +255,9 @@ static void efi_free(efi_system_table_t *sys_table_arg, unsigned long size,
 {
        unsigned long nr_pages;
 
+       if (!size)
+               return;
+
        nr_pages = round_up(size, EFI_PAGE_SIZE) / EFI_PAGE_SIZE;
        efi_call_phys2(sys_table_arg->boottime->free_pages, addr, nr_pages);
 }