Igor Mitsyanko <i.mitsya...@samsung.com> wrote: > On 06/28/2012 11:22 PM, Juan Quintela wrote: >> Notice that the live migration users never unregister, so no problem >> about freeing the ops structure. >> >> Signed-off-by: Juan Quintela <quint...@redhat.com> >> --- >> arch_init.c | 9 +++++++-- >> block-migration.c | 10 ++++++++-- >> migration.h | 4 ++-- >> savevm.c | 18 +++++++----------- >> vl.c | 3 +-- >> vmstate.h | 5 +---- >> 6 files changed, 26 insertions(+), 23 deletions(-) >>
>> @@ -1234,16 +1231,12 @@ int register_savevm_live(DeviceState *dev, >> se = g_malloc0(sizeof(SaveStateEntry)); >> se->version_id = version_id; >> se->section_id = global_section_id++; >> - se->ops = g_malloc0(sizeof(SaveVMHandlers)); >> - se->ops->set_params = set_params; >> - se->ops->save_live_state = save_live_state; >> - se->ops->save_state = save_state; >> - se->ops->load_state = load_state; >> + se->ops = ops; >> se->opaque = opaque; >> se->vmsd = NULL; >> se->no_migrate = 0; >> /* if this is a live_savem then set is_ram */ >> - if (save_live_state != NULL) { >> + if (ops->save_live_state != NULL) { > > Maybe add assert on ops==NULL before dereferencing it here? I audited all callers. See that I create the ops before calling it. If ops is NULL, we have big problems, so no problem to crash there. Later, Juan.