@@ -1235,6 +1235,26 @@ static void x86_set_hv_spinlocks(Object *obj, Visitor *v, void *opaque,
}
hyperv_set_spinlock_retries(value);
}
+
+static void x86_get_hv_relaxed(Object *obj, Visitor *v, void *opaque,
+ const char *name, Error **errp)
+{
+ bool value = hyperv_relaxed_timing_enabled();
+
+ visit_type_bool(v, &value, name, errp);
+}
+
+static void x86_set_hv_relaxed(Object *obj, Visitor *v, void *opaque,
+ const char *name, Error **errp)
+{
+ bool value;
+
+ visit_type_bool(v, &value, name, errp);
+ if (error_is_set(errp)) {
+ return;
+ }
+ hyperv_enable_relaxed_timing(value);
+}
#endif
static void cpudef_2_x86_cpu(X86CPU *cpu, x86_def_t *def, Error **errp)
@@ -2073,6 +2093,9 @@ static void x86_cpu_initfn(Object *obj)
object_property_add(obj, "hv_spinlocks", "int",
x86_get_hv_spinlocks,
x86_set_hv_spinlocks, NULL, NULL, NULL);
+ object_property_add(obj, "hv_relaxed", "bool",
+ x86_get_hv_relaxed,
+ x86_set_hv_relaxed, NULL, NULL, NULL);
#endif
x86_register_cpuid_properties(obj, feature_name);
x86_register_cpuid_properties(obj, ext_feature_name);
Signed-off-by: Igor Mammedov <imammedo@redhat.com> --- target-i386/cpu.c | 23 +++++++++++++++++++++++ 1 files changed, 23 insertions(+), 0 deletions(-)