From 97fb54e1e49d989a44b64b95fc088b112bd7711c Mon Sep 17 00:00:00 2001 From: Xiantao Zhang Date: Sat, 30 Aug 2008 08:36:03 +0800 Subject: Add get/set_mpstate for ia64 Add get/set_mpstate for Ipf. Signed-off-by: Xiantao Zhang Signed-off-by: Avi Kivity --- qemu-kvm-ia64.c | 37 +++++++++++++++++++++++++++++++++++++ target-ia64/cpu.h | 2 +- target-ia64/machine.c | 12 ++++++++++++ 3 files changed, 50 insertions(+), 1 deletion(-) diff --git a/qemu-kvm-ia64.c b/qemu-kvm-ia64.c index d227d220b..042c7ed19 100644 --- a/qemu-kvm-ia64.c +++ b/qemu-kvm-ia64.c @@ -62,6 +62,43 @@ void kvm_arch_update_regs_for_sipi(CPUState *env) { } +void kvm_save_mpstate(CPUState *env) +{ +#ifdef KVM_CAP_MP_STATE + int r; + struct kvm_mp_state mp_state; + + r = kvm_get_mpstate(kvm_context, env->cpu_index, &mp_state); + if (r < 0) + env->mp_state = -1; + else + env->mp_state = mp_state.mp_state; +#endif +} + +void kvm_load_mpstate(CPUState *env) +{ +#ifdef KVM_CAP_MP_STATE + struct kvm_mp_state mp_state = { .mp_state = env->mp_state }; + + /* + * -1 indicates that the host did not support GET_MP_STATE ioctl, + * so don't touch it. + */ + if (env->mp_state != -1) + kvm_set_mpstate(kvm_context, env->cpu_index, &mp_state); +#endif +} + void kvm_arch_cpu_reset(CPUState *env) { + if (kvm_irqchip_in_kernel(kvm_context)) { +#ifdef KVM_CAP_MP_STATE + kvm_reset_mpstate(kvm_context, env->cpu_index); +#endif + } else { + env->interrupt_request &= ~CPU_INTERRUPT_HARD; + env->halted = 1; + env->exception_index = EXCP_HLT; + } } diff --git a/target-ia64/cpu.h b/target-ia64/cpu.h index a3ff7a87b..e65e62895 100644 --- a/target-ia64/cpu.h +++ b/target-ia64/cpu.h @@ -44,7 +44,7 @@ typedef struct CPUIA64State { CPU_COMMON; uint32_t hflags; - + int mp_state; } CPUIA64State; #define CPUState CPUIA64State diff --git a/target-ia64/machine.c b/target-ia64/machine.c index 4dc5d5e12..a32b01a08 100644 --- a/target-ia64/machine.c +++ b/target-ia64/machine.c @@ -11,9 +11,21 @@ void register_machines(void) void cpu_save(QEMUFile *f, void *opaque) { + CPUState *env = opaque; + + if (kvm_enabled()) { + kvm_save_registers(env); + kvm_save_mpstate(env); + } } int cpu_load(QEMUFile *f, void *opaque, int version_id) { + CPUState *env = opaque; + + if (kvm_enabled()) { + kvm_load_registers(env); + kvm_load_mpstate(env); + } return 0; } -- cgit v1.2.3-65-gdbad