@@ -129,6 +129,8 @@ struct KVMState
KVMMemoryListener *ml;
AddressSpace *as;
} *as;
+
+ set_memory_region_debug_ops set_mr_debug_ops;
};
KVMState *kvm_state;
@@ -3157,6 +3159,21 @@ static void kvm_set_kernel_irqchip(Object *obj, Visitor *v,
}
}
+void kvm_setup_memory_region_debug_ops(struct KVMState *s,
+ set_memory_region_debug_ops new_ops)
+{
+ if (s)
+ s->set_mr_debug_ops = new_ops;
+}
+
+void kvm_set_memory_region_debug_ops(void *handle, MemoryRegion *mr)
+{
+ if (!kvm_state || !kvm_state->set_mr_debug_ops)
+ return;
+
+ kvm_state->set_mr_debug_ops(handle, mr);
+}
+
bool kvm_kernel_irqchip_allowed(void)
{
return kvm_state->kernel_irqchip_allowed;
@@ -148,4 +148,15 @@ bool kvm_arm_supports_user_irq(void)
{
return false;
}
+
+void kvm_setup_memory_region_debug_ops(struct KVMState *s,
+ set_memory_region_debug_ops new_ops)
+{
+
+}
+
+void kvm_set_memory_region_debug_ops(void *handle, MemoryRegion *mr)
+{
+
+}
#endif
@@ -547,4 +547,9 @@ bool kvm_cpu_check_are_resettable(void);
bool kvm_arch_cpu_check_are_resettable(void);
+typedef void (*set_memory_region_debug_ops)(void *handle, MemoryRegion *mr);
+void kvm_setup_memory_region_debug_ops(struct KVMState *s, set_memory_region_debug_ops new_ops);
+
+void kvm_set_memory_region_debug_ops(void *handle, MemoryRegion *mr);
+
#endif