target-arm queue:

* fix handling of KVM reset for 32-bit ARM CPUs
  * implement NOR flash alias for vexpress-a9
  * make sure libvixl gets its own utils.h rather than somebody else's
 -----BEGIN PGP SIGNATURE-----
 Version: GnuPG v1
 
 iQIcBAABCAAGBQJTu+AVAAoJEDwlJe0UNgzebnYP/j70i5fMIKvCykZHKKgPrshx
 wuMy/G4ORcVBefItwW3Y8AAb0wKDb7skk7dhvU3eS6sQ0W5BzLIo0hkttULg310/
 hEOo44peBLS14NS6V5Jz+VevKz6fmCladG7Q0bH1QVRJtszLbok0zSR3V1dZ63oe
 Vz60w4uybBbETziPUm3GXXfDPJrfxNM4OCu6Jx6EiHYulI8IBqk8/b2k3MvQ6kM9
 nTmqdeN5YrV+nv9OzlL3DDp4DxMpVWnVnLVItIEO/RphxJUjFwr7fJ7t5TP7qWSk
 E395Ur87/kTZq3W3TqgEg2lboNa+2wOHIfOYhH774L45JquTZPDNtJ33L73UKcoS
 78s7QAAbKykwlXKaqKrfmelcvBDPamHlQ2xjgU43B0+R5sjINAERkuAi0C1ma/2G
 eRa1bxnCwHa2VfnqXORkhSshRKzJl6LqWEiukLbOX1csBOQzQOQ9H/n/OYT6Dlij
 MwaWcbC1qNknHksZHt9Hw15q00z2fawMpW8ChcN5yjL6tx8eW9JAermTAxRqJg2a
 7KclCgs6xPmSixCEDCWpjZxP/sRDZZ3dHBuaY3B8AGJed/swgsfXgjEXtiqW4eC2
 n3GH4jkY1uDzhwflIUlQxUM1cRwAIx+CuKlSldd5R2tw/bKlcYFfi/HdFvdwjuHM
 6b08uihH1azoud9sAmiP
 =Rek4
 -----END PGP SIGNATURE-----

Merge remote-tracking branch 'remotes/pmaydell/tags/pull-target-arm-20140708' into staging

target-arm queue:
 * fix handling of KVM reset for 32-bit ARM CPUs
 * implement NOR flash alias for vexpress-a9
 * make sure libvixl gets its own utils.h rather than somebody else's

# gpg: Signature made Tue 08 Jul 2014 13:12:05 BST using RSA key ID 14360CDE
# gpg: Good signature from "Peter Maydell <peter.maydell@linaro.org>"

* remotes/pmaydell/tags/pull-target-arm-20140708:
  target-arm: Implement vCPU reset via KVM_ARM_VCPU_INIT for 32-bit CPUs
  hw/arm/vexpress: Alias NOR flash at 0 for vexpress-a9
  disas/libvixl: prepend the include path of libvixl header files

Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
Peter Maydell 2014-07-08 14:01:58 +01:00
commit 67d01fb806
4 changed files with 7 additions and 20 deletions

View File

@ -3,6 +3,6 @@ libvixl_OBJS = utils.o \
a64/decoder-a64.o \ a64/decoder-a64.o \
a64/disasm-a64.o a64/disasm-a64.o
$(addprefix $(obj)/,$(libvixl_OBJS)): QEMU_CFLAGS += -I$(SRC_PATH)/disas/libvixl $(addprefix $(obj)/,$(libvixl_OBJS)): QEMU_CFLAGS := -I$(SRC_PATH)/disas/libvixl $(QEMU_CFLAGS)
common-obj-$(CONFIG_ARM_A64_DIS) += $(libvixl_OBJS) common-obj-$(CONFIG_ARM_A64_DIS) += $(libvixl_OBJS)

View File

@ -84,6 +84,7 @@ enum {
}; };
static hwaddr motherboard_legacy_map[] = { static hwaddr motherboard_legacy_map[] = {
[VE_NORFLASHALIAS] = 0,
/* CS7: 0x10000000 .. 0x10020000 */ /* CS7: 0x10000000 .. 0x10020000 */
[VE_SYSREGS] = 0x10000000, [VE_SYSREGS] = 0x10000000,
[VE_SP810] = 0x10001000, [VE_SP810] = 0x10001000,
@ -114,7 +115,6 @@ static hwaddr motherboard_legacy_map[] = {
[VE_VIDEORAM] = 0x4c000000, [VE_VIDEORAM] = 0x4c000000,
[VE_ETHERNET] = 0x4e000000, [VE_ETHERNET] = 0x4e000000,
[VE_USB] = 0x4f000000, [VE_USB] = 0x4f000000,
[VE_NORFLASHALIAS] = -1, /* not present */
}; };
static hwaddr motherboard_aseries_map[] = { static hwaddr motherboard_aseries_map[] = {

View File

@ -72,10 +72,6 @@ typedef struct ARMCPU {
uint64_t *cpreg_indexes; uint64_t *cpreg_indexes;
/* Values of the registers (cpreg_indexes[i]'s value is cpreg_values[i]) */ /* Values of the registers (cpreg_indexes[i]'s value is cpreg_values[i]) */
uint64_t *cpreg_values; uint64_t *cpreg_values;
/* When using KVM, keeps a copy of the initial state of the VCPU,
* so that on reset we can feed the reset values back into the kernel.
*/
uint64_t *cpreg_reset_values;
/* Length of the indexes, values, reset_values arrays */ /* Length of the indexes, values, reset_values arrays */
int32_t cpreg_array_len; int32_t cpreg_array_len;
/* These are used only for migration: incoming data arrives in /* These are used only for migration: incoming data arrives in

View File

@ -270,13 +270,6 @@ int kvm_arch_init_vcpu(CPUState *cs)
goto out; goto out;
} }
/* Save a copy of the initial register values so that we can
* feed it back to the kernel on VCPU reset.
*/
cpu->cpreg_reset_values = g_memdup(cpu->cpreg_values,
cpu->cpreg_array_len *
sizeof(cpu->cpreg_values[0]));
out: out:
g_free(rlp); g_free(rlp);
return ret; return ret;
@ -518,11 +511,9 @@ int kvm_arch_get_registers(CPUState *cs)
void kvm_arm_reset_vcpu(ARMCPU *cpu) void kvm_arm_reset_vcpu(ARMCPU *cpu)
{ {
/* Feed the kernel back its initial register state */ /* Re-init VCPU so that all registers are set to
memmove(cpu->cpreg_values, cpu->cpreg_reset_values, * their respective reset values.
cpu->cpreg_array_len * sizeof(cpu->cpreg_values[0])); */
kvm_arm_vcpu_init(CPU(cpu));
if (!write_list_to_kvmstate(cpu)) { write_kvmstate_to_list(cpu);
abort();
}
} }