On 10/25/25 4:26 PM, Vladimir Sementsov-Ogievskiy wrote:
In case of pre_save_errp, on error, we continue processing fields,
unlike case of pre_save, where we return immediately. Behavior
for pre_save_errp case is wrong, we must return here, like for
pre_save.

Fixes: 40de712a89
  "migration: Add error-parameterized function variants in VMSD struct"
Signed-off-by: Vladimir Sementsov-Ogievskiy <[email protected]>
Reviewed-by: Philippe Mathieu-Daudé <[email protected]>

Reviewed-by: Stefan Berger <[email protected]>

---
  migration/vmstate.c | 1 +
  1 file changed, 1 insertion(+)

diff --git a/migration/vmstate.c b/migration/vmstate.c
index 81eadde553..fd066f910e 100644
--- a/migration/vmstate.c
+++ b/migration/vmstate.c
@@ -443,6 +443,7 @@ int vmstate_save_state_v(QEMUFile *f, const 
VMStateDescription *vmsd,
          if (ret < 0) {
              error_prepend(errp, "pre-save for %s failed, ret: %d: ",
                            vmsd->name, ret);
+            return ret;
          }
      } else if (vmsd->pre_save) {
          ret = vmsd->pre_save(opaque);


Reply via email to