aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPhilippe Mathieu-Daudé <philmd@linaro.org>2023-10-03 14:30:22 +0200
committerRichard Henderson <richard.henderson@linaro.org>2023-10-03 08:00:25 -0700
commit1aa1d8308d46c5ee3b8558f9f916f5da2492a60a (patch)
treef3248adbcbcee7160e536bf44bd7ab2c975186ce
parentbd684b2f3f57dd390ba715fce1597eb7ad97ee8d (diff)
downloadqemu-1aa1d8308d46c5ee3b8558f9f916f5da2492a60a.zip
qemu-1aa1d8308d46c5ee3b8558f9f916f5da2492a60a.tar.gz
qemu-1aa1d8308d46c5ee3b8558f9f916f5da2492a60a.tar.bz2
accel: Introduce accel_cpu_common_unrealize() stub
Prepare the stub for parity with accel_cpu_common_realize(). Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org> Message-Id: <20231003123026.99229-5-philmd@linaro.org> Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
-rw-r--r--accel/accel-common.c4
-rw-r--r--cpu.c4
-rw-r--r--include/qemu/accel.h6
3 files changed, 13 insertions, 1 deletions
diff --git a/accel/accel-common.c b/accel/accel-common.c
index 53cf08a..e9548ea 100644
--- a/accel/accel-common.c
+++ b/accel/accel-common.c
@@ -129,6 +129,10 @@ bool accel_cpu_common_realize(CPUState *cpu, Error **errp)
return true;
}
+void accel_cpu_common_unrealize(CPUState *cpu)
+{
+}
+
int accel_supported_gdbstub_sstep_flags(void)
{
AccelState *accel = current_accel();
diff --git a/cpu.c b/cpu.c
index 1e2649a..2a1eff9 100644
--- a/cpu.c
+++ b/cpu.c
@@ -187,8 +187,10 @@ void cpu_exec_unrealizefn(CPUState *cpu)
cpu_list_remove(cpu);
/*
* Now that the vCPU has been removed from the RCU list, we can call
- * tcg_exec_unrealizefn, which may free fields using call_rcu.
+ * tcg_exec_unrealizefn and
+ * accel_cpu_common_unrealize, which may free fields using call_rcu.
*/
+ accel_cpu_common_unrealize(cpu);
if (tcg_enabled()) {
tcg_exec_unrealizefn(cpu);
}
diff --git a/include/qemu/accel.h b/include/qemu/accel.h
index 898159c..446153b 100644
--- a/include/qemu/accel.h
+++ b/include/qemu/accel.h
@@ -97,6 +97,12 @@ void accel_cpu_instance_init(CPUState *cpu);
bool accel_cpu_common_realize(CPUState *cpu, Error **errp);
/**
+ * accel_cpu_common_unrealize:
+ * @cpu: The CPU that needs to call accel-specific cpu unrealization.
+ */
+void accel_cpu_common_unrealize(CPUState *cpu);
+
+/**
* accel_supported_gdbstub_sstep_flags:
*
* Returns the supported single step modes for the configured