efi_loader: overflow in efi_allocate_pages
authorHeinrich Schuchardt <heinrich.schuchardt@canonical.com>
Sun, 30 Jul 2023 09:31:08 +0000 (11:31 +0200)
committerHeinrich Schuchardt <heinrich.schuchardt@canonical.com>
Thu, 3 Aug 2023 07:21:02 +0000 (09:21 +0200)
On 32bit systems (pages << EFI_PAGE_SHIFT) may lead to an overflow which
does not occur in 64bit arithmetics.

An overflow of (pages << EFI_PAGE_SHIFT) on 64bit systems should be treated
as an error.

Signed-off-by: Heinrich Schuchardt <heinrich.schuchardt@canonical.com>
lib/efi_loader/efi_memory.c

index 2c5d522..4630387 100644 (file)
@@ -489,7 +489,7 @@ efi_status_t efi_allocate_pages(enum efi_allocate_type type,
                                enum efi_memory_type memory_type,
                                efi_uintn_t pages, uint64_t *memory)
 {
-       u64 len = pages << EFI_PAGE_SHIFT;
+       u64 len;
        efi_status_t ret;
        uint64_t addr;
 
@@ -499,6 +499,11 @@ efi_status_t efi_allocate_pages(enum efi_allocate_type type,
                return EFI_INVALID_PARAMETER;
        if (!memory)
                return EFI_INVALID_PARAMETER;
+       len = (u64)pages << EFI_PAGE_SHIFT;
+       /* Catch possible overflow on 64bit systems */
+       if (sizeof(efi_uintn_t) == sizeof(u64) &&
+           (len >> EFI_PAGE_SHIFT) != (u64)pages)
+               return EFI_OUT_OF_RESOURCES;
 
        switch (type) {
        case EFI_ALLOCATE_ANY_PAGES: