On Tue, 05 Nov, at 04:20:10PM, dyoung at redhat.com wrote: > Add two small functions: > efi_merge_regions and efi_map_regions, efi_enter_virtual_mode > calls them instead of embedding two long for loop. > > v1->v2: > refresh; coding style fixes. > > Signed-off-by: Dave Young <dyoung at redhat.com> > --- > arch/x86/platform/efi/efi.c | 107 +++++++++++++++++++++++++------------------- > 1 file changed, 63 insertions(+), 44 deletions(-) [...] > @@ -860,17 +840,59 @@ void __init efi_enter_virtual_mode(void) > efi.systab = (efi_system_table_t *) (unsigned long) systab; > } > > - new_memmap = krealloc(new_memmap, > - (count + 1) * memmap.desc_size, > - GFP_KERNEL); > - if (!new_memmap) > + *new_memmap = krealloc(*new_memmap, > + (*count + 1) * memmap.desc_size, > + GFP_KERNEL); > + if (!*new_memmap) > goto err_out; > > - memcpy(new_memmap + (count * memmap.desc_size), md, > + memcpy(*new_memmap + (*count * memmap.desc_size), md, > memmap.desc_size); > - count++; > + (*count)++; > } > > +err_out: > + pr_err("Error reallocating memory, EFI runtime non-functional!\n"); > +} You should really return an error value here so that we don't dereference 'new_memmap' below if it's NULL. In fact, just return the memmap... > + > + efi_merge_regions(); > + > + efi_map_regions(&new_memmap, &count); > + and make sure to check the return value here. -- Matt Fleming, Intel Open Source Technology Center