On 2025/2/8 上午12:20, Igor Mammedov wrote:
> Reseting vcpu before its thread is created, caused various issues in the past
> for other targets. It doesn't cause issues for loongarch at the moment but
> to be consistent with the rest of targets, move reset during realize time
> after qemu_init_vcpu().
>
> That basically prevents reset being run when when vCPU is in incositent state
> (i.e. accelerator hasn't initialized vCPU yet).
>
> Signed-off-by: Igor Mammedov <imammedo@redhat.com>
> ---
> CC: Song Gao <gaosong@loongson.cn>
> ---
> target/loongarch/cpu.c | 2 +-
> 1 file changed, 1 insertion(+), 1 deletion(-)
>
> diff --git a/target/loongarch/cpu.c b/target/loongarch/cpu.c
> index e91f4a5239..15018d43ae 100644
> --- a/target/loongarch/cpu.c
> +++ b/target/loongarch/cpu.c
> @@ -634,8 +634,8 @@ static void loongarch_cpu_realizefn(DeviceState *dev, Error **errp)
>
> loongarch_cpu_register_gdb_regs_for_features(cs);
>
> - cpu_reset(cs);
> qemu_init_vcpu(cs);
> + cpu_reset(cs);
>
> lacc->parent_realize(dev, errp);
> }
>
yes, that is actually a problem in kvm mode. vCPU thread should be
created and kvm_fd for the vCPU need valid before cpu_reset().
Reviewed-by: Bibo Mao <maobibo@loongson.cn>