提交 7b558cc3 编写于 作者: L Lakshmi Ramasubramanian 提交者: Rob Herring

arm64: Use ELF fields defined in 'struct kimage'

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: NRob Herring <robh@kernel.org>
Reported-by: Nkernel test robot <lkp@intel.com>
Signed-off-by: NLakshmi Ramasubramanian <nramas@linux.microsoft.com>
Reviewed-by: NThiago Jung Bauermann <bauerman@linux.ibm.com>
Signed-off-by: NRob Herring <robh@kernel.org>
Link: https://lore.kernel.org/r/20210221174930.27324-3-nramas@linux.microsoft.com
上级 9336a5f6
...@@ -96,10 +96,6 @@ struct kimage_arch { ...@@ -96,10 +96,6 @@ struct kimage_arch {
void *dtb; void *dtb;
phys_addr_t dtb_mem; phys_addr_t dtb_mem;
phys_addr_t kern_reloc; 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 #ifdef CONFIG_KEXEC_FILE
......
...@@ -43,9 +43,9 @@ int arch_kimage_file_post_load_cleanup(struct kimage *image) ...@@ -43,9 +43,9 @@ int arch_kimage_file_post_load_cleanup(struct kimage *image)
vfree(image->arch.dtb); vfree(image->arch.dtb);
image->arch.dtb = NULL; image->arch.dtb = NULL;
vfree(image->arch.elf_headers); vfree(image->elf_headers);
image->arch.elf_headers = NULL; image->elf_headers = NULL;
image->arch.elf_headers_sz = 0; image->elf_headers_sz = 0;
return kexec_image_post_load_cleanup_default(image); return kexec_image_post_load_cleanup_default(image);
} }
...@@ -73,8 +73,8 @@ static int setup_dtb(struct kimage *image, ...@@ -73,8 +73,8 @@ static int setup_dtb(struct kimage *image,
/* add linux,elfcorehdr */ /* add linux,elfcorehdr */
ret = fdt_appendprop_addrrange(dtb, 0, off, ret = fdt_appendprop_addrrange(dtb, 0, off,
FDT_PROP_KEXEC_ELFHDR, FDT_PROP_KEXEC_ELFHDR,
image->arch.elf_headers_mem, image->elf_load_addr,
image->arch.elf_headers_sz); image->elf_headers_sz);
if (ret) if (ret)
return (ret == -FDT_ERR_NOSPACE ? -ENOMEM : -EINVAL); return (ret == -FDT_ERR_NOSPACE ? -ENOMEM : -EINVAL);
...@@ -284,12 +284,12 @@ int load_other_segments(struct kimage *image, ...@@ -284,12 +284,12 @@ int load_other_segments(struct kimage *image,
vfree(headers); vfree(headers);
goto out_err; goto out_err;
} }
image->arch.elf_headers = headers; image->elf_headers = headers;
image->arch.elf_headers_mem = kbuf.mem; image->elf_load_addr = kbuf.mem;
image->arch.elf_headers_sz = headers_sz; image->elf_headers_sz = headers_sz;
pr_debug("Loaded elf core header at 0x%lx bufsz=0x%lx memsz=0x%lx\n", 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 */ /* load initrd */
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册