mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-04 08:13:54 -06:00
Support u-boot noload images for arm as used by, NetBSD/evbarm GENERIC kernel.
noload kernels are loaded with the u-boot image header and as a result the header size needs adding to the entry point. Fake up a hdr so the kernel image is loaded at the right address and the entry point is adjusted appropriately. The default location for the uboot file is 32MiB above bottom of DRAM. This matches the recommendation in Documentation/arm/Booting. Clarify the load_uimage API to state the passing of a load address when an image doesn't specify one, or when loading a ramdisk is expected. Adjust callers of load_uimage, etc. Signed-off-by: Nick Hudson <skrll@netbsd.org> Message-id: 11488a08-1fe0-a278-2210-deb64731107f@gmx.co.uk Reviewed-by: Peter Maydell <peter.maydell@linaro.org> Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
parent
619d54a8d8
commit
f831f955d4
9 changed files with 33 additions and 11 deletions
|
@ -613,13 +613,26 @@ static int load_uboot_image(const char *filename, hwaddr *ep, hwaddr *loadaddr,
|
|||
goto out;
|
||||
|
||||
if (hdr->ih_type != image_type) {
|
||||
fprintf(stderr, "Wrong image type %d, expected %d\n", hdr->ih_type,
|
||||
image_type);
|
||||
goto out;
|
||||
if (!(image_type == IH_TYPE_KERNEL &&
|
||||
hdr->ih_type == IH_TYPE_KERNEL_NOLOAD)) {
|
||||
fprintf(stderr, "Wrong image type %d, expected %d\n", hdr->ih_type,
|
||||
image_type);
|
||||
goto out;
|
||||
}
|
||||
}
|
||||
|
||||
/* TODO: Implement other image types. */
|
||||
switch (hdr->ih_type) {
|
||||
case IH_TYPE_KERNEL_NOLOAD:
|
||||
if (!loadaddr || *loadaddr == LOAD_UIMAGE_LOADADDR_INVALID) {
|
||||
fprintf(stderr, "this image format (kernel_noload) cannot be "
|
||||
"loaded on this machine type");
|
||||
goto out;
|
||||
}
|
||||
|
||||
hdr->ih_load = *loadaddr + sizeof(*hdr);
|
||||
hdr->ih_ep += hdr->ih_load;
|
||||
/* fall through */
|
||||
case IH_TYPE_KERNEL:
|
||||
address = hdr->ih_load;
|
||||
if (translate_fn) {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue