From nobody Fri Oct 24 09:56:14 2025 Delivered-To: importer@patchew.org Received-SPF: pass (zoho.com: domain of gnu.org designates 208.118.235.17 as permitted sender) client-ip=208.118.235.17; envelope-from=qemu-devel-bounces+importer=patchew.org@nongnu.org; helo=lists.gnu.org; Authentication-Results: mx.zohomail.com; spf=pass (zoho.com: domain of gnu.org designates 208.118.235.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org; dmarc=fail(p=none dis=none) header.from=linaro.org Return-Path: Received: from lists.gnu.org (208.118.235.17 [208.118.235.17]) by mx.zohomail.com with SMTPS id 1518717572800680.3617042140941; Thu, 15 Feb 2018 09:59:32 -0800 (PST) Received: from localhost ([::1]:44113 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1emNoc-0001lv-Km for importer@patchew.org; Thu, 15 Feb 2018 12:59:26 -0500 Received: from eggs.gnu.org ([2001:4830:134:3::10]:55305) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1emNmU-00085F-VS for qemu-devel@nongnu.org; Thu, 15 Feb 2018 12:57:16 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1emNmU-0000bi-3h for qemu-devel@nongnu.org; Thu, 15 Feb 2018 12:57:15 -0500 Received: from orth.archaic.org.uk ([2001:8b0:1d0::2]:46422) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_256_CBC_SHA1:32) (Exim 4.71) (envelope-from ) id 1emNmR-0000Xo-69; Thu, 15 Feb 2018 12:57:11 -0500 Received: from pm215 by orth.archaic.org.uk with local (Exim 4.89) (envelope-from ) id 1emNmP-00020Y-0C; Thu, 15 Feb 2018 17:57:09 +0000 From: Peter Maydell To: qemu-arm@nongnu.org, qemu-devel@nongnu.org Date: Thu, 15 Feb 2018 17:57:04 +0000 Message-Id: <20180215175707.15491-2-peter.maydell@linaro.org> X-Mailer: git-send-email 2.16.1 In-Reply-To: <20180215175707.15491-1-peter.maydell@linaro.org> References: <20180215175707.15491-1-peter.maydell@linaro.org> X-detected-operating-system: by eggs.gnu.org: Genre and OS details not recognized. X-Received-From: 2001:8b0:1d0::2 Subject: [Qemu-devel] [PATCH 1/3] loader: Add new load_ramdisk_as() X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.21 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: patches@linaro.org Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org Sender: "Qemu-devel" X-ZohoMail: RSF_0 Z_629925259 SPT_0 Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Add a function load_ramdisk_as() which behaves like the existing load_ramdisk() but allows the caller to specify the AddressSpace to use. This matches the pattern we have already for various other loader functions. Signed-off-by: Peter Maydell Reviewed-by: Philippe Mathieu-Daud=C3=A9 --- include/hw/loader.h | 12 +++++++++++- hw/core/loader.c | 8 +++++++- 2 files changed, 18 insertions(+), 2 deletions(-) diff --git a/include/hw/loader.h b/include/hw/loader.h index 355fe0f5a2..1fd4256782 100644 --- a/include/hw/loader.h +++ b/include/hw/loader.h @@ -163,16 +163,26 @@ int load_uimage(const char *filename, hwaddr *ep, void *translate_opaque); =20 /** - * load_ramdisk: + * load_ramdisk_as: * @filename: Path to the ramdisk image * @addr: Memory address to load the ramdisk to * @max_sz: Maximum allowed ramdisk size (for non-u-boot ramdisks) + * @as: The AddressSpace to load the ELF to. The value of address_space_me= mory + * is used if nothing is supplied here. * * Load a ramdisk image with U-Boot header to the specified memory * address. * * Returns the size of the loaded image on success, -1 otherwise. */ +int load_ramdisk_as(const char *filename, hwaddr addr, uint64_t max_sz, + AddressSpace *as); + +/** + * load_ramdisk: + * Same as load_ramdisk_as(), but doesn't allow the caller to specify + * an AddressSpace. + */ int load_ramdisk(const char *filename, hwaddr addr, uint64_t max_sz); =20 ssize_t gunzip(void *dst, size_t dstlen, uint8_t *src, size_t srclen); diff --git a/hw/core/loader.c b/hw/core/loader.c index 91669d65aa..2b9e7394a1 100644 --- a/hw/core/loader.c +++ b/hw/core/loader.c @@ -729,9 +729,15 @@ int load_uimage_as(const char *filename, hwaddr *ep, h= waddr *loadaddr, =20 /* Load a ramdisk. */ int load_ramdisk(const char *filename, hwaddr addr, uint64_t max_sz) +{ + return load_ramdisk_as(filename, addr, max_sz, NULL); +} + +int load_ramdisk_as(const char *filename, hwaddr addr, uint64_t max_sz, + AddressSpace *as) { return load_uboot_image(filename, NULL, &addr, NULL, IH_TYPE_RAMDISK, - NULL, NULL, NULL); + NULL, NULL, as); } =20 /* Load a gzip-compressed kernel to a dynamically allocated buffer. */ --=20 2.16.1 From nobody Fri Oct 24 09:56:14 2025 Delivered-To: importer@patchew.org Received-SPF: pass (zoho.com: domain of gnu.org designates 208.118.235.17 as permitted sender) client-ip=208.118.235.17; envelope-from=qemu-devel-bounces+importer=patchew.org@nongnu.org; helo=lists.gnu.org; Authentication-Results: mx.zohomail.com; spf=pass (zoho.com: domain of gnu.org designates 208.118.235.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org; dmarc=fail(p=none dis=none) header.from=linaro.org Return-Path: Received: from lists.gnu.org (lists.gnu.org [208.118.235.17]) by mx.zohomail.com with SMTPS id 1518717610938394.7038696861198; Thu, 15 Feb 2018 10:00:10 -0800 (PST) Received: from localhost ([::1]:44123 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1emNpJ-0002TV-Um for importer@patchew.org; Thu, 15 Feb 2018 13:00:10 -0500 Received: from eggs.gnu.org ([2001:4830:134:3::10]:55404) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1emNmZ-0008BF-W1 for qemu-devel@nongnu.org; Thu, 15 Feb 2018 12:57:21 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1emNmY-0000eP-3W for qemu-devel@nongnu.org; Thu, 15 Feb 2018 12:57:20 -0500 Received: from orth.archaic.org.uk ([2001:8b0:1d0::2]:46422) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_256_CBC_SHA1:32) (Exim 4.71) (envelope-from ) id 1emNmT-0000Xo-26; Thu, 15 Feb 2018 12:57:13 -0500 Received: from pm215 by orth.archaic.org.uk with local (Exim 4.89) (envelope-from ) id 1emNmP-00020p-OZ; Thu, 15 Feb 2018 17:57:09 +0000 From: Peter Maydell To: qemu-arm@nongnu.org, qemu-devel@nongnu.org Date: Thu, 15 Feb 2018 17:57:05 +0000 Message-Id: <20180215175707.15491-3-peter.maydell@linaro.org> X-Mailer: git-send-email 2.16.1 In-Reply-To: <20180215175707.15491-1-peter.maydell@linaro.org> References: <20180215175707.15491-1-peter.maydell@linaro.org> X-detected-operating-system: by eggs.gnu.org: Genre and OS details not recognized. X-Received-From: 2001:8b0:1d0::2 Subject: [Qemu-devel] [PATCH 2/3] hw/arm/boot: Honour CPU's address space for image loads X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.21 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: patches@linaro.org Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org Sender: "Qemu-devel" X-ZohoMail: RSF_0 Z_629925259 SPT_0 Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Instead of loading kernels, device trees, and the like to the system address space, use the CPU's address space. This is important if we're trying to load the file to memory or via an alias memory region that is provided by an SoC object and thus not mapped into the system address space. Signed-off-by: Peter Maydell --- hw/arm/boot.c | 119 +++++++++++++++++++++++++++++++++++++-----------------= ---- 1 file changed, 76 insertions(+), 43 deletions(-) diff --git a/hw/arm/boot.c b/hw/arm/boot.c index 9b174b982c..0eac655c98 100644 --- a/hw/arm/boot.c +++ b/hw/arm/boot.c @@ -35,6 +35,25 @@ #define ARM64_TEXT_OFFSET_OFFSET 8 #define ARM64_MAGIC_OFFSET 56 =20 +static AddressSpace *arm_boot_addressspace(ARMCPU *cpu, + const struct arm_boot_info *inf= o) +{ + /* Return the address space to use for bootloader reads and writes. + * We prefer the secure address space if the CPU has it and we're + * going to boot the guest into it. + */ + int asidx; + CPUState *cs =3D CPU(cpu); + + if (arm_feature(&cpu->env, ARM_FEATURE_EL3) && info->secure_boot) { + asidx =3D ARMASIdx_S; + } else { + asidx =3D ARMASIdx_NS; + } + + return cpu_get_address_space(cs, asidx); +} + typedef enum { FIXUP_NONE =3D 0, /* do nothing */ FIXUP_TERMINATOR, /* end of insns */ @@ -124,7 +143,8 @@ static const ARMInsnFixup smpboot[] =3D { }; =20 static void write_bootloader(const char *name, hwaddr addr, - const ARMInsnFixup *insns, uint32_t *fixupcon= text) + const ARMInsnFixup *insns, uint32_t *fixupcon= text, + AddressSpace *as) { /* Fix up the specified bootloader fragment and write it into * guest memory using rom_add_blob_fixed(). fixupcontext is @@ -163,7 +183,7 @@ static void write_bootloader(const char *name, hwaddr a= ddr, code[i] =3D tswap32(insn); } =20 - rom_add_blob_fixed(name, code, len * sizeof(uint32_t), addr); + rom_add_blob_fixed_as(name, code, len * sizeof(uint32_t), addr, as); =20 g_free(code); } @@ -172,6 +192,7 @@ static void default_write_secondary(ARMCPU *cpu, const struct arm_boot_info *info) { uint32_t fixupcontext[FIXUP_MAX]; + AddressSpace *as =3D CPU(cpu)->as; =20 fixupcontext[FIXUP_GIC_CPU_IF] =3D info->gic_cpu_if_addr; fixupcontext[FIXUP_BOOTREG] =3D info->smp_bootreg_addr; @@ -182,13 +203,14 @@ static void default_write_secondary(ARMCPU *cpu, } =20 write_bootloader("smpboot", info->smp_loader_start, - smpboot, fixupcontext); + smpboot, fixupcontext, as); } =20 void arm_write_secure_board_setup_dummy_smc(ARMCPU *cpu, const struct arm_boot_info *in= fo, hwaddr mvbar_addr) { + AddressSpace *as =3D CPU(cpu)->as; int n; uint32_t mvbar_blob[] =3D { /* mvbar_addr: secure monitor vectors @@ -226,22 +248,23 @@ void arm_write_secure_board_setup_dummy_smc(ARMCPU *c= pu, for (n =3D 0; n < ARRAY_SIZE(mvbar_blob); n++) { mvbar_blob[n] =3D tswap32(mvbar_blob[n]); } - rom_add_blob_fixed("board-setup-mvbar", mvbar_blob, sizeof(mvbar_blob), - mvbar_addr); + rom_add_blob_fixed_as("board-setup-mvbar", mvbar_blob, sizeof(mvbar_bl= ob), + mvbar_addr, as); =20 for (n =3D 0; n < ARRAY_SIZE(board_setup_blob); n++) { board_setup_blob[n] =3D tswap32(board_setup_blob[n]); } - rom_add_blob_fixed("board-setup", board_setup_blob, - sizeof(board_setup_blob), info->board_setup_addr); + rom_add_blob_fixed_as("board-setup", board_setup_blob, + sizeof(board_setup_blob), info->board_setup_addr= , as); } =20 static void default_reset_secondary(ARMCPU *cpu, const struct arm_boot_info *info) { + AddressSpace *as =3D arm_boot_addressspace(cpu, info); CPUState *cs =3D CPU(cpu); =20 - address_space_stl_notdirty(&address_space_memory, info->smp_bootreg_ad= dr, + address_space_stl_notdirty(as, info->smp_bootreg_addr, 0, MEMTXATTRS_UNSPECIFIED, NULL); cpu_set_pc(cs, info->smp_loader_start); } @@ -252,12 +275,12 @@ static inline bool have_dtb(const struct arm_boot_inf= o *info) } =20 #define WRITE_WORD(p, value) do { \ - address_space_stl_notdirty(&address_space_memory, p, value, \ + address_space_stl_notdirty(as, p, value, \ MEMTXATTRS_UNSPECIFIED, NULL); \ p +=3D 4; \ } while (0) =20 -static void set_kernel_args(const struct arm_boot_info *info) +static void set_kernel_args(const struct arm_boot_info *info, AddressSpace= *as) { int initrd_size =3D info->initrd_size; hwaddr base =3D info->loader_start; @@ -288,8 +311,9 @@ static void set_kernel_args(const struct arm_boot_info = *info) int cmdline_size; =20 cmdline_size =3D strlen(info->kernel_cmdline); - cpu_physical_memory_write(p + 8, info->kernel_cmdline, - cmdline_size + 1); + address_space_write(as, p + 8, MEMTXATTRS_UNSPECIFIED, + (const uint8_t *)info->kernel_cmdline, + cmdline_size + 1); cmdline_size =3D (cmdline_size >> 2) + 1; WRITE_WORD(p, cmdline_size + 2); WRITE_WORD(p, 0x54410009); @@ -303,7 +327,8 @@ static void set_kernel_args(const struct arm_boot_info = *info) atag_board_len =3D (info->atag_board(info, atag_board_buf) + 3) & = ~3; WRITE_WORD(p, (atag_board_len + 8) >> 2); WRITE_WORD(p, 0x414f4d50); - cpu_physical_memory_write(p, atag_board_buf, atag_board_len); + address_space_write(as, p, MEMTXATTRS_UNSPECIFIED, + atag_board_buf, atag_board_len); p +=3D atag_board_len; } /* ATAG_END */ @@ -311,7 +336,8 @@ static void set_kernel_args(const struct arm_boot_info = *info) WRITE_WORD(p, 0); } =20 -static void set_kernel_args_old(const struct arm_boot_info *info) +static void set_kernel_args_old(const struct arm_boot_info *info, + AddressSpace *as) { hwaddr p; const char *s; @@ -379,7 +405,8 @@ static void set_kernel_args_old(const struct arm_boot_i= nfo *info) } s =3D info->kernel_cmdline; if (s) { - cpu_physical_memory_write(p, s, strlen(s) + 1); + address_space_write(as, p, MEMTXATTRS_UNSPECIFIED, + (const uint8_t *)s, strlen(s) + 1); } else { WRITE_WORD(p, 0); } @@ -453,6 +480,7 @@ static void fdt_add_psci_node(void *fdt) * @addr: the address to load the image at * @binfo: struct describing the boot environment * @addr_limit: upper limit of the available memory area at @addr + * @as: address space to load image to * * Load a device tree supplied by the machine or by the user with the * '-dtb' command line option, and put it at offset @addr in target @@ -469,7 +497,7 @@ static void fdt_add_psci_node(void *fdt) * Note: Must not be called unless have_dtb(binfo) is true. */ static int load_dtb(hwaddr addr, const struct arm_boot_info *binfo, - hwaddr addr_limit) + hwaddr addr_limit, AddressSpace *as) { void *fdt =3D NULL; int size, rc; @@ -615,7 +643,7 @@ static int load_dtb(hwaddr addr, const struct arm_boot_= info *binfo, /* Put the DTB into the memory map as a ROM image: this will ensure * the DTB is copied again upon reset, even if addr points into RAM. */ - rom_add_blob_fixed("dtb", fdt, size, addr); + rom_add_blob_fixed_as("dtb", fdt, size, addr, as); =20 g_free(fdt); =20 @@ -702,13 +730,15 @@ static void do_cpu_reset(void *opaque) } =20 if (cs =3D=3D first_cpu) { + AddressSpace *as =3D arm_boot_addressspace(cpu, info); + cpu_set_pc(cs, info->loader_start); =20 if (!have_dtb(info)) { if (old_param) { - set_kernel_args_old(info); + set_kernel_args_old(info, as); } else { - set_kernel_args(info); + set_kernel_args(info, as); } } } else { @@ -783,7 +813,7 @@ static int do_arm_linux_init(Object *obj, void *opaque) =20 static uint64_t arm_load_elf(struct arm_boot_info *info, uint64_t *pentry, uint64_t *lowaddr, uint64_t *highaddr, - int elf_machine) + int elf_machine, AddressSpace *as) { bool elf_is64; union { @@ -826,9 +856,9 @@ static uint64_t arm_load_elf(struct arm_boot_info *info= , uint64_t *pentry, } } =20 - ret =3D load_elf(info->kernel_filename, NULL, NULL, - pentry, lowaddr, highaddr, big_endian, elf_machine, - 1, data_swab); + ret =3D load_elf_as(info->kernel_filename, NULL, NULL, + pentry, lowaddr, highaddr, big_endian, elf_machine, + 1, data_swab, as); if (ret <=3D 0) { /* The header loaded but the image didn't */ exit(1); @@ -838,7 +868,7 @@ static uint64_t arm_load_elf(struct arm_boot_info *info= , uint64_t *pentry, } =20 static uint64_t load_aarch64_image(const char *filename, hwaddr mem_base, - hwaddr *entry) + hwaddr *entry, AddressSpace *as) { hwaddr kernel_load_offset =3D KERNEL64_LOAD_ADDR; uint8_t *buffer; @@ -873,7 +903,7 @@ static uint64_t load_aarch64_image(const char *filename= , hwaddr mem_base, } =20 *entry =3D mem_base + kernel_load_offset; - rom_add_blob_fixed(filename, buffer, size, *entry); + rom_add_blob_fixed_as(filename, buffer, size, *entry, as); =20 g_free(buffer); =20 @@ -895,6 +925,7 @@ static void arm_load_kernel_notify(Notifier *notifier, = void *data) ARMCPU *cpu =3D n->cpu; struct arm_boot_info *info =3D container_of(n, struct arm_boot_info, load_kernel_notifier); + AddressSpace *as =3D arm_boot_addressspace(cpu, info); =20 /* The board code is not supposed to set secure_board_setup unless * running its code in secure mode is actually possible, and KVM @@ -912,7 +943,7 @@ static void arm_load_kernel_notify(Notifier *notifier, = void *data) * the kernel is supposed to be loaded by the bootloader), cop= y the * DTB to the base of RAM for the bootloader to pick up. */ - if (load_dtb(info->loader_start, info, 0) < 0) { + if (load_dtb(info->loader_start, info, 0, as) < 0) { exit(1); } } @@ -987,7 +1018,7 @@ static void arm_load_kernel_notify(Notifier *notifier,= void *data) =20 /* Assume that raw images are linux kernels, and ELF images are not. = */ kernel_size =3D arm_load_elf(info, &elf_entry, &elf_low_addr, - &elf_high_addr, elf_machine); + &elf_high_addr, elf_machine, as); if (kernel_size > 0 && have_dtb(info)) { /* If there is still some room left at the base of RAM, try and put * the DTB there like we do for images loaded with -bios or -pflas= h. @@ -1000,25 +1031,26 @@ static void arm_load_kernel_notify(Notifier *notifi= er, void *data) if (elf_low_addr < info->loader_start) { elf_low_addr =3D 0; } - if (load_dtb(info->loader_start, info, elf_low_addr) < 0) { + if (load_dtb(info->loader_start, info, elf_low_addr, as) < 0) { exit(1); } } } entry =3D elf_entry; if (kernel_size < 0) { - kernel_size =3D load_uimage(info->kernel_filename, &entry, NULL, - &is_linux, NULL, NULL); + kernel_size =3D load_uimage_as(info->kernel_filename, &entry, NULL, + &is_linux, NULL, NULL, as); } if (arm_feature(&cpu->env, ARM_FEATURE_AARCH64) && kernel_size < 0) { kernel_size =3D load_aarch64_image(info->kernel_filename, - info->loader_start, &entry); + info->loader_start, &entry, as); is_linux =3D 1; } else if (kernel_size < 0) { /* 32-bit ARM */ entry =3D info->loader_start + KERNEL_LOAD_ADDR; - kernel_size =3D load_image_targphys(info->kernel_filename, entry, - info->ram_size - KERNEL_LOAD_ADD= R); + kernel_size =3D load_image_targphys_as(info->kernel_filename, entr= y, + info->ram_size - KERNEL_LOAD_= ADDR, + as); is_linux =3D 1; } if (kernel_size < 0) { @@ -1030,15 +1062,16 @@ static void arm_load_kernel_notify(Notifier *notifi= er, void *data) uint32_t fixupcontext[FIXUP_MAX]; =20 if (info->initrd_filename) { - initrd_size =3D load_ramdisk(info->initrd_filename, - info->initrd_start, - info->ram_size - - info->initrd_start); + initrd_size =3D load_ramdisk_as(info->initrd_filename, + info->initrd_start, + info->ram_size - info->initrd_st= art, + as); if (initrd_size < 0) { - initrd_size =3D load_image_targphys(info->initrd_filename, - info->initrd_start, - info->ram_size - - info->initrd_start); + initrd_size =3D load_image_targphys_as(info->initrd_filena= me, + info->initrd_start, + info->ram_size - + info->initrd_start, + as); } if (initrd_size < 0) { error_report("could not load initrd '%s'", @@ -1079,7 +1112,7 @@ static void arm_load_kernel_notify(Notifier *notifier= , void *data) =20 /* Place the DTB after the initrd in memory with alignment. */ dtb_start =3D QEMU_ALIGN_UP(info->initrd_start + initrd_size, = align); - if (load_dtb(dtb_start, info, 0) < 0) { + if (load_dtb(dtb_start, info, 0, as) < 0) { exit(1); } fixupcontext[FIXUP_ARGPTR] =3D dtb_start; @@ -1095,7 +1128,7 @@ static void arm_load_kernel_notify(Notifier *notifier= , void *data) fixupcontext[FIXUP_ENTRYPOINT] =3D entry; =20 write_bootloader("bootloader", info->loader_start, - primary_loader, fixupcontext); + primary_loader, fixupcontext, as); =20 if (info->nb_cpus > 1) { info->write_secondary_boot(cpu, info); --=20 2.16.1 From nobody Fri Oct 24 09:56:14 2025 Delivered-To: importer@patchew.org Received-SPF: pass (zoho.com: domain of gnu.org designates 208.118.235.17 as permitted sender) client-ip=208.118.235.17; envelope-from=qemu-devel-bounces+importer=patchew.org@nongnu.org; helo=lists.gnu.org; Authentication-Results: mx.zohomail.com; spf=pass (zoho.com: domain of gnu.org designates 208.118.235.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org; dmarc=fail(p=none dis=none) header.from=linaro.org Return-Path: Received: from lists.gnu.org (lists.gnu.org [208.118.235.17]) by mx.zohomail.com with SMTPS id 1518717786324992.9472684793664; Thu, 15 Feb 2018 10:03:06 -0800 (PST) Received: from localhost ([::1]:44407 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1emNs9-000589-Jq for importer@patchew.org; Thu, 15 Feb 2018 13:03:05 -0500 Received: from eggs.gnu.org ([2001:4830:134:3::10]:55325) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1emNmV-00086L-PL for qemu-devel@nongnu.org; Thu, 15 Feb 2018 12:57:16 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1emNmU-0000cW-PX for qemu-devel@nongnu.org; Thu, 15 Feb 2018 12:57:15 -0500 Received: from orth.archaic.org.uk ([2001:8b0:1d0::2]:46422) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_256_CBC_SHA1:32) (Exim 4.71) (envelope-from ) id 1emNmS-0000Xo-3u; Thu, 15 Feb 2018 12:57:12 -0500 Received: from pm215 by orth.archaic.org.uk with local (Exim 4.89) (envelope-from ) id 1emNmQ-000215-JJ; Thu, 15 Feb 2018 17:57:10 +0000 From: Peter Maydell To: qemu-arm@nongnu.org, qemu-devel@nongnu.org Date: Thu, 15 Feb 2018 17:57:06 +0000 Message-Id: <20180215175707.15491-4-peter.maydell@linaro.org> X-Mailer: git-send-email 2.16.1 In-Reply-To: <20180215175707.15491-1-peter.maydell@linaro.org> References: <20180215175707.15491-1-peter.maydell@linaro.org> X-detected-operating-system: by eggs.gnu.org: Genre and OS details not recognized. X-Received-From: 2001:8b0:1d0::2 Subject: [Qemu-devel] [PATCH 3/3] hw/arm/armv7m: Honour CPU's address space for image loads X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.21 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: patches@linaro.org Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org Sender: "Qemu-devel" X-ZohoMail: RSF_0 Z_629925259 SPT_0 Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Instead of loading guest images to the system address space, use the CPU's address space. This is important if we're trying to load the file to memory or via an alias memory region that is provided by an SoC object and thus not mapped into the system address space. Signed-off-by: Peter Maydell --- hw/arm/armv7m.c | 17 ++++++++++++++--- 1 file changed, 14 insertions(+), 3 deletions(-) diff --git a/hw/arm/armv7m.c b/hw/arm/armv7m.c index 56770a7048..facc536b07 100644 --- a/hw/arm/armv7m.c +++ b/hw/arm/armv7m.c @@ -270,6 +270,9 @@ void armv7m_load_kernel(ARMCPU *cpu, const char *kernel= _filename, int mem_size) uint64_t entry; uint64_t lowaddr; int big_endian; + AddressSpace *as; + int asidx; + CPUState *cs =3D CPU(cpu); =20 #ifdef TARGET_WORDS_BIGENDIAN big_endian =3D 1; @@ -282,11 +285,19 @@ void armv7m_load_kernel(ARMCPU *cpu, const char *kern= el_filename, int mem_size) exit(1); } =20 + if (arm_feature(&cpu->env, ARM_FEATURE_EL3)) { + asidx =3D ARMASIdx_S; + } else { + asidx =3D ARMASIdx_NS; + } + as =3D cpu_get_address_space(cs, asidx); + if (kernel_filename) { - image_size =3D load_elf(kernel_filename, NULL, NULL, &entry, &lowa= ddr, - NULL, big_endian, EM_ARM, 1, 0); + image_size =3D load_elf_as(kernel_filename, NULL, NULL, &entry, &l= owaddr, + NULL, big_endian, EM_ARM, 1, 0, as); if (image_size < 0) { - image_size =3D load_image_targphys(kernel_filename, 0, mem_siz= e); + image_size =3D load_image_targphys_as(kernel_filename, 0, + mem_size, as); lowaddr =3D 0; } if (image_size < 0) { --=20 2.16.1