Commit 41bd13afdabf62ba513e00fade177749d73e1c09
1 parent
ad067148
Add unregister_savevm() (Mark McLoughlin)
Currently there's no way to unregister a savevm callback, so e.g. if a NIC is hot-unplugged and a savevm is issued, we'll segfault. Signed-off-by: Mark McLoughlin <markmc@redhat.com> Signed-off-by: Anthony Liguori <aliguori@us.ibm.com> git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@7148 c046a42c-6fe2-441c-8c8c-71466251a162
Showing
2 changed files
with
18 additions
and
0 deletions
hw/hw.h
... | ... | @@ -239,6 +239,8 @@ int register_savevm_live(const char *idstr, |
239 | 239 | LoadStateHandler *load_state, |
240 | 240 | void *opaque); |
241 | 241 | |
242 | +void unregister_savevm(const char *idstr, void *opaque); | |
243 | + | |
242 | 244 | typedef void QEMUResetHandler(void *opaque); |
243 | 245 | |
244 | 246 | void qemu_register_reset(QEMUResetHandler *func, void *opaque); | ... | ... |
savevm.c
... | ... | @@ -647,6 +647,22 @@ int register_savevm(const char *idstr, |
647 | 647 | NULL, save_state, load_state, opaque); |
648 | 648 | } |
649 | 649 | |
650 | +void unregister_savevm(const char *idstr, void *opaque) | |
651 | +{ | |
652 | + SaveStateEntry **pse; | |
653 | + | |
654 | + pse = &first_se; | |
655 | + while (*pse != NULL) { | |
656 | + if (strcmp((*pse)->idstr, idstr) == 0 && (*pse)->opaque == opaque) { | |
657 | + SaveStateEntry *next = (*pse)->next; | |
658 | + qemu_free(*pse); | |
659 | + *pse = next; | |
660 | + continue; | |
661 | + } | |
662 | + pse = &(*pse)->next; | |
663 | + } | |
664 | +} | |
665 | + | |
650 | 666 | #define QEMU_VM_FILE_MAGIC 0x5145564d |
651 | 667 | #define QEMU_VM_FILE_VERSION_COMPAT 0x00000002 |
652 | 668 | #define QEMU_VM_FILE_VERSION 0x00000003 | ... | ... |