Property kvm-steal-time is added for kvm steal time feature, it is
specially for kvm mode.
Signed-off-by: Bibo Mao <maobibo@loongson.cn>
---
target/loongarch/cpu.h | 1 +
target/loongarch/kvm/kvm.c | 18 ++++++++++++++++++
target/loongarch/loongarch-qmp-cmds.c | 2 +-
3 files changed, 20 insertions(+), 1 deletion(-)
diff --git a/target/loongarch/cpu.h b/target/loongarch/cpu.h
index 5eae17fcbd..8ee320a720 100644
--- a/target/loongarch/cpu.h
+++ b/target/loongarch/cpu.h
@@ -409,6 +409,7 @@ struct ArchCPU {
OnOffAuto lsx;
OnOffAuto lasx;
OnOffAuto kvm_pv_ipi;
+ OnOffAuto kvm_steal_time;
/* 'compatible' string for this CPU for Linux device trees */
const char *dtb_compatible;
diff --git a/target/loongarch/kvm/kvm.c b/target/loongarch/kvm/kvm.c
index 2a829d58a1..f7e0ea5e40 100644
--- a/target/loongarch/kvm/kvm.c
+++ b/target/loongarch/kvm/kvm.c
@@ -1115,6 +1115,18 @@ static void kvm_pv_ipi_set(Object *obj, bool value, Error **errp)
cpu->kvm_pv_ipi = value ? ON_OFF_AUTO_ON : ON_OFF_AUTO_OFF;
}
+static bool kvm_steal_time_get(Object *obj, Error **errp)
+{
+ return LOONGARCH_CPU(obj)->kvm_steal_time != ON_OFF_AUTO_OFF;
+}
+
+static void kvm_steal_time_set(Object *obj, bool value, Error **errp)
+{
+ LoongArchCPU *cpu = LOONGARCH_CPU(obj);
+
+ cpu->kvm_steal_time = value ? ON_OFF_AUTO_ON : ON_OFF_AUTO_OFF;
+}
+
void kvm_loongarch_cpu_post_init(LoongArchCPU *cpu)
{
cpu->lbt = ON_OFF_AUTO_AUTO;
@@ -1134,6 +1146,12 @@ void kvm_loongarch_cpu_post_init(LoongArchCPU *cpu)
kvm_pv_ipi_set);
object_property_set_description(OBJECT(cpu), "kvm-pv-ipi",
"Set off to disable KVM paravirt IPI.");
+
+ cpu->kvm_steal_time = ON_OFF_AUTO_AUTO;
+ object_property_add_bool(OBJECT(cpu), "kvm-steal-time", kvm_steal_time_get,
+ kvm_steal_time_set);
+ object_property_set_description(OBJECT(cpu), "kvm-steal-time",
+ "Set off to disable KVM steal time.");
}
int kvm_arch_destroy_vcpu(CPUState *cs)
diff --git a/target/loongarch/loongarch-qmp-cmds.c b/target/loongarch/loongarch-qmp-cmds.c
index 4f94a39833..6f732d80f3 100644
--- a/target/loongarch/loongarch-qmp-cmds.c
+++ b/target/loongarch/loongarch-qmp-cmds.c
@@ -40,7 +40,7 @@ CpuDefinitionInfoList *qmp_query_cpu_definitions(Error **errp)
}
static const char *cpu_model_advertised_features[] = {
- "lsx", "lasx", "lbt", "pmu", "kvm-pv-ipi", NULL
+ "lsx", "lasx", "lbt", "pmu", "kvm-pv-ipi", "kvm-steal-time", NULL
};
CpuModelExpansionInfo *qmp_query_cpu_model_expansion(CpuModelExpansionType type,
--
2.39.3