aboutsummaryrefslogtreecommitdiff
path: root/target/s390x/machine.c
diff options
context:
space:
mode:
authorRichard Henderson <rth@twiddle.net>2017-05-21 09:50:00 -0700
committerRichard Henderson <rth@twiddle.net>2017-06-06 14:34:32 -0700
commit303c681a8f50eb88fbafc2bf6a7e4c5813ac2be0 (patch)
tree73c0154cfb153d248aaa6a50db1dbd4e774c8495 /target/s390x/machine.c
parent06fc03486cf9b825f8afd9defe80a255364ed02c (diff)
downloadqemu-303c681a8f50eb88fbafc2bf6a7e4c5813ac2be0.zip
qemu-303c681a8f50eb88fbafc2bf6a7e4c5813ac2be0.tar.gz
qemu-303c681a8f50eb88fbafc2bf6a7e4c5813ac2be0.tar.bz2
target/s390x: Implement EXECUTE via new TranslationBlock
Previously, helper_ex would construct the insn and then implement the insn via direct calls other helpers. This was sufficient to boot Linux but that is all. It is easy enough to go the whole nine yards by stashing state for EXECUTE within the cpu, and then rely on a new TB to be created that properly and completely interprets the insn. Reviewed-by: Aurelien Jarno <aurelien@aurel32.net> Signed-off-by: Richard Henderson <rth@twiddle.net>
Diffstat (limited to 'target/s390x/machine.c')
-rw-r--r--target/s390x/machine.c19
1 files changed, 19 insertions, 0 deletions
diff --git a/target/s390x/machine.c b/target/s390x/machine.c
index 8503fa1..8f908bb 100644
--- a/target/s390x/machine.c
+++ b/target/s390x/machine.c
@@ -34,6 +34,7 @@ static int cpu_post_load(void *opaque, int version_id)
return 0;
}
+
static void cpu_pre_save(void *opaque)
{
S390CPU *cpu = opaque;
@@ -156,6 +157,23 @@ const VMStateDescription vmstate_riccb = {
}
};
+static bool exval_needed(void *opaque)
+{
+ S390CPU *cpu = opaque;
+ return cpu->env.ex_value != 0;
+}
+
+const VMStateDescription vmstate_exval = {
+ .name = "cpu/exval",
+ .version_id = 1,
+ .minimum_version_id = 1,
+ .needed = exval_needed,
+ .fields = (VMStateField[]) {
+ VMSTATE_UINT64(env.ex_value, S390CPU),
+ VMSTATE_END_OF_LIST()
+ }
+};
+
const VMStateDescription vmstate_s390_cpu = {
.name = "cpu",
.post_load = cpu_post_load,
@@ -188,6 +206,7 @@ const VMStateDescription vmstate_s390_cpu = {
&vmstate_fpu,
&vmstate_vregs,
&vmstate_riccb,
+ &vmstate_exval,
NULL
},
};