arm64: Use ELF fields defined in 'struct kimage'
authorLakshmi Ramasubramanian <nramas@linux.microsoft.com>
Sun, 21 Feb 2021 17:49:19 +0000 (09:49 -0800)
committerRob Herring <robh@kernel.org>
Mon, 8 Mar 2021 19:06:28 +0000 (12:06 -0700)
ELF related fields elf_headers, elf_headers_sz, and elf_headers_mem
have been moved from 'struct kimage_arch' to 'struct kimage' as
elf_headers, elf_headers_sz, and elf_load_addr respectively.

Use the ELF fields defined in 'struct kimage'.

Suggested-by: Rob Herring <robh@kernel.org>
Reported-by: kernel test robot <lkp@intel.com>
Signed-off-by: Lakshmi Ramasubramanian <nramas@linux.microsoft.com>
Reviewed-by: Thiago Jung Bauermann <bauerman@linux.ibm.com>
Signed-off-by: Rob Herring <robh@kernel.org>
Link: https://lore.kernel.org/r/20210221174930.27324-3-nramas@linux.microsoft.com
arch/arm64/include/asm/kexec.h
arch/arm64/kernel/machine_kexec_file.c

index 9befcd8..00dbcc7 100644 (file)
@@ -96,10 +96,6 @@ struct kimage_arch {
        void *dtb;
        phys_addr_t dtb_mem;
        phys_addr_t kern_reloc;
-       /* Core ELF header buffer */
-       void *elf_headers;
-       unsigned long elf_headers_mem;
-       unsigned long elf_headers_sz;
 };
 
 #ifdef CONFIG_KEXEC_FILE
index 0cde47a..471b52f 100644 (file)
@@ -43,9 +43,9 @@ int arch_kimage_file_post_load_cleanup(struct kimage *image)
        vfree(image->arch.dtb);
        image->arch.dtb = NULL;
 
-       vfree(image->arch.elf_headers);
-       image->arch.elf_headers = NULL;
-       image->arch.elf_headers_sz = 0;
+       vfree(image->elf_headers);
+       image->elf_headers = NULL;
+       image->elf_headers_sz = 0;
 
        return kexec_image_post_load_cleanup_default(image);
 }
@@ -73,8 +73,8 @@ static int setup_dtb(struct kimage *image,
                /* add linux,elfcorehdr */
                ret = fdt_appendprop_addrrange(dtb, 0, off,
                                FDT_PROP_KEXEC_ELFHDR,
-                               image->arch.elf_headers_mem,
-                               image->arch.elf_headers_sz);
+                               image->elf_load_addr,
+                               image->elf_headers_sz);
                if (ret)
                        return (ret == -FDT_ERR_NOSPACE ? -ENOMEM : -EINVAL);
 
@@ -284,12 +284,12 @@ int load_other_segments(struct kimage *image,
                        vfree(headers);
                        goto out_err;
                }
-               image->arch.elf_headers = headers;
-               image->arch.elf_headers_mem = kbuf.mem;
-               image->arch.elf_headers_sz = headers_sz;
+               image->elf_headers = headers;
+               image->elf_load_addr = kbuf.mem;
+               image->elf_headers_sz = headers_sz;
 
                pr_debug("Loaded elf core header at 0x%lx bufsz=0x%lx memsz=0x%lx\n",
-                        image->arch.elf_headers_mem, kbuf.bufsz, kbuf.memsz);
+                        image->elf_load_addr, kbuf.bufsz, kbuf.memsz);
        }
 
        /* load initrd */