]> git.proxmox.com Git - mirror_qemu.git/commitdiff
accel: Introduce cpu_exec_reset_hold()
authorPhilippe Mathieu-Daudé <philmd@linaro.org>
Fri, 15 Sep 2023 20:55:33 +0000 (22:55 +0200)
committerPhilippe Mathieu-Daudé <philmd@linaro.org>
Tue, 7 Nov 2023 11:13:27 +0000 (12:13 +0100)
Introduce cpu_exec_reset_hold() which call an accelerator
specific AccelOpsClass::cpu_reset_hold() handler.

Define a stub on TCG user emulation, because CPU reset is
irrelevant there.

Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Reviewed-by: Anton Johansson <anjo@rev.ng>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
Message-Id: <20230918104153.24433-3-philmd@linaro.org>

accel/tcg/user-exec-stub.c
hw/core/cpu-common.c
include/hw/core/cpu.h
include/sysemu/accel-ops.h
system/cpus.c

index 2dc6fd9c4e8c1798b54ce2b6429ca7321b19ec01..4fbe2dbdc883eb67f26f51aba76a5649faaea795 100644 (file)
@@ -14,6 +14,10 @@ void qemu_init_vcpu(CPUState *cpu)
 {
 }
 
+void cpu_exec_reset_hold(CPUState *cpu)
+{
+}
+
 /* User mode emulation does not support record/replay yet.  */
 
 bool replay_exception(void)
index 29c917c5dc44cf0ba246f5cef26f5ae8fec0a305..7d266c36ace67f924cf1e74ef70c3b1852aecb5d 100644 (file)
@@ -137,6 +137,7 @@ static void cpu_common_reset_hold(Object *obj)
     cpu->crash_occurred = false;
     cpu->cflags_next_tb = -1;
 
+    cpu_exec_reset_hold(cpu);
     if (tcg_enabled()) {
         tcg_flush_jmp_cache(cpu);
         tcg_flush_softmmu_tlb(cpu);
index 18593db5b20eca32bc87a84643a364de746b9270..6373aa4501addb9991e89693c963f14cf031ca5c 100644 (file)
@@ -1153,6 +1153,7 @@ void cpu_class_init_props(DeviceClass *dc);
 void cpu_exec_initfn(CPUState *cpu);
 void cpu_exec_realizefn(CPUState *cpu, Error **errp);
 void cpu_exec_unrealizefn(CPUState *cpu);
+void cpu_exec_reset_hold(CPUState *cpu);
 
 /**
  * target_words_bigendian:
index 3c1fab4b1e62f4f3fdf0a20a73e28fb6d36adbb6..ef91fc28bbdfa3dab181e11c5a4dc42fce1bad92 100644 (file)
@@ -30,6 +30,7 @@ struct AccelOpsClass {
     void (*ops_init)(AccelOpsClass *ops);
 
     bool (*cpus_are_resettable)(void);
+    void (*cpu_reset_hold)(CPUState *cpu);
 
     void (*create_vcpu_thread)(CPUState *cpu); /* MANDATORY NON-NULL */
     void (*kick_vcpu_thread)(CPUState *cpu);
index 0848e0dbdb3f89baf0399c88e45f52e7b47b8bdb..952f15868c9e353391f1163e1b0e19d681d34adc 100644 (file)
@@ -201,6 +201,13 @@ bool cpus_are_resettable(void)
     return true;
 }
 
+void cpu_exec_reset_hold(CPUState *cpu)
+{
+    if (cpus_accel->cpu_reset_hold) {
+        cpus_accel->cpu_reset_hold(cpu);
+    }
+}
+
 int64_t cpus_get_virtual_clock(void)
 {
     /*