diff options
author | Dr. David Alan Gilbert <dgilbert@redhat.com> | 2022-01-13 19:44:51 +0000 |
---|---|---|
committer | Juan Quintela <quintela@redhat.com> | 2023-02-06 19:22:56 +0100 |
commit | 89c568489122de996920b760c34e81b925cc8181 (patch) | |
tree | 0e850cd4c9cc0626d856c70aa97102f1d7d7429b /migration/vmstate.c | |
parent | 74ecf6ac2b7e53cf480f1f2dc7a3af41525fb588 (diff) | |
download | qemu-89c568489122de996920b760c34e81b925cc8181.zip qemu-89c568489122de996920b760c34e81b925cc8181.tar.gz qemu-89c568489122de996920b760c34e81b925cc8181.tar.bz2 |
migration: Add canary to VMSTATE_END_OF_LIST
We fairly regularly forget VMSTATE_END_OF_LIST markers off descriptions;
given that the current check is only for ->name being NULL, sometimes
we get unlucky and the code apparently works and no one spots the error.
Explicitly add a flag, VMS_END that should be set, and assert it is
set during the traversal.
Note: This can't go in until we update the copy of vmstate.h in slirp.
Suggested-by: Peter Maydell <peter.maydell@linaro.org>
Signed-off-by: Dr. David Alan Gilbert <dgilbert@redhat.com>
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
Reviewed-by: Juan Quintela <quintela@redhat.com>
Signed-off-by: Juan Quintela <quintela@redhat.com>
Diffstat (limited to 'migration/vmstate.c')
-rw-r--r-- | migration/vmstate.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/migration/vmstate.c b/migration/vmstate.c index 924494b..83ca4c7 100644 --- a/migration/vmstate.c +++ b/migration/vmstate.c @@ -154,6 +154,7 @@ int vmstate_load_state(QEMUFile *f, const VMStateDescription *vmsd, } field++; } + assert(field->flags == VMS_END); ret = vmstate_subsection_load(f, vmsd, opaque); if (ret != 0) { return ret; @@ -408,6 +409,7 @@ int vmstate_save_state_v(QEMUFile *f, const VMStateDescription *vmsd, } field++; } + assert(field->flags == VMS_END); if (vmdesc) { json_writer_end_array(vmdesc); |