hw/xtensa/xtfpga: treat uImage load address as virtual U-boot for xtensa always treats uImage load address as virtual address. This is important when booting uImage on xtensa core with MMUv2, because MMUv2 has fixed non-identity virtual-to-physical mapping after reset. Always do virtual-to-physical translation of uImage load address and load uImage at the translated address. This fixes booting uImage kernels on dc232b and other MMUv2 cores. Cc: qemu-stable@nongnu.org Reported-by: Waldemar Brodkorb <mail@waldemar-brodkorb.de> Signed-off-by: Max Filippov <jcmvbkbc@gmail.com>
diff --git a/hw/xtensa/xtfpga.c b/hw/xtensa/xtfpga.c index a9b33bc..e5a6bba 100644 --- a/hw/xtensa/xtfpga.c +++ b/hw/xtensa/xtfpga.c
@@ -329,7 +329,7 @@ hwaddr ep; int is_linux; success = load_uimage(kernel_filename, &ep, NULL, &is_linux, - NULL, NULL); + translate_phys_addr, cpu); if (success > 0 && is_linux) { entry_point = ep; } else {