> On 3 Sep 2025, at 12.06, Philippe Mathieu-Daudé <phi...@linaro.org> wrote:
> 
> Call hv_vcpu_destroy() to destroy our vCPU context.
> 
> As hv_vcpu_destroy() must be called by the owning thread,
> document hvf_arch_vcpu_destroy() also does.
> 
> Signed-off-by: Philippe Mathieu-Daudé <phi...@linaro.org>
> ---
> include/system/hvf_int.h | 3 ++-
> target/arm/hvf/hvf.c     | 4 ++++
> 2 files changed, 6 insertions(+), 1 deletion(-)
> 
> diff --git a/include/system/hvf_int.h b/include/system/hvf_int.h
> index 241c668795e..195d64dcf18 100644
> --- a/include/system/hvf_int.h
> +++ b/include/system/hvf_int.h
> @@ -71,13 +71,14 @@ void assert_hvf_ok_impl(hv_return_t ret, const char 
> *file, unsigned int line,
> const char *hvf_return_string(hv_return_t ret);
> int hvf_arch_init(void);
> hv_return_t hvf_arch_vm_create(MachineState *ms, uint32_t pa_range);
> -void hvf_arch_vcpu_destroy(CPUState *cpu);
> hvf_slot *hvf_find_overlap_slot(uint64_t, uint64_t);
> void hvf_kick_vcpu_thread(CPUState *cpu);
> 
> /* Must be called by the owning thread */
> int hvf_arch_init_vcpu(CPUState *cpu);
> /* Must be called by the owning thread */
> +void hvf_arch_vcpu_destroy(CPUState *cpu);
> +/* Must be called by the owning thread */
> int hvf_arch_vcpu_exec(CPUState *);
> /* Must be called by the owning thread */
> int hvf_arch_put_registers(CPUState *);
> diff --git a/target/arm/hvf/hvf.c b/target/arm/hvf/hvf.c
> index 4a535d65b7e..5b3c34014a5 100644
> --- a/target/arm/hvf/hvf.c
> +++ b/target/arm/hvf/hvf.c
> @@ -992,6 +992,10 @@ void hvf_arm_set_cpu_features_from_host(ARMCPU *cpu)
> 
> void hvf_arch_vcpu_destroy(CPUState *cpu)
> {
> +    hv_return_t ret;
> +
> +    ret = hv_vcpu_destroy(cpu->accel->fd);
> +    assert_hvf_ok(ret);

Interesting that this was missing. I can see x86 is missing it too.

> }
> 
> hv_return_t hvf_arch_vm_create(MachineState *ms, uint32_t pa_range)
> -- 
> 2.51.0
> 

Reviewed-by: Mads Ynddal <m...@ynddal.dk>

Reply via email to