On 06/15/2010 05:26 PM, Cam Macdonell wrote:
On Tue, Jun 15, 2010 at 10:32 AM, Anthony Liguori<anth...@codemonkey.ws>  wrote:
On 06/15/2010 11:16 AM, Cam Macdonell wrote:
How does this look for marking the device as non-migratable?  It adds a
field
'no_migrate' to the SaveStateEntry and tests for it in vmstate_save.  This
would
replace anything that touches memory.

Cam

---
  hw/hw.h  |    1 +
  savevm.c |   32 +++++++++++++++++++++++++++++---
  2 files changed, 30 insertions(+), 3 deletions(-)

diff --git a/hw/hw.h b/hw/hw.h
index d78d814..7c93f08 100644
--- a/hw/hw.h
+++ b/hw/hw.h
@@ -263,6 +263,7 @@ int register_savevm_live(const char *idstr,
                           void *opaque);

  void unregister_savevm(const char *idstr, void *opaque);
+void mark_no_migrate(const char *idstr, void *opaque);

I'm not thrilled with the name but the functionality is spot on.  I lack the
creativity to offer a better name suggestion :-)

Regards,

Anthony Liguori
Hmmm, in working on this it seems that the memory (from
qemu_ram_map()) is still attached even when the device is removed
(which causes migration to fail because there is an unexpected
memory).

Is something like cpu_unregister_physical_memory()/qemu_ram_free() needed?

Yes. You need to unregister any memory that you have registered upon device removal.

Regards,

Anthony Liguori

Cam



Reply via email to