migration: I messed state_pending_exact/estimate

I called the helper function from the wrong top level function.

This code was introduced in:

commit c8df4a7aeffcb46020f610526eea621fa5b0cd47
Author: Juan Quintela <quintela@redhat.com>
Date:   Mon Oct 3 02:00:03 2022 +0200

    migration: Split save_live_pending() into state_pending_*

    We split the function into to:

    - state_pending_estimate: We estimate the remaining state size without
      stopping the machine.

    - state pending_exact: We calculate the exact amount of remaining
      state.

Thanks to Avihai Horon <avihaih@nvidia.com> for finding it.

Fixes:c8df4a7aeffcb46020f610526eea621fa5b0cd47

When we introduced that patch, we enden calling

state_pending_estimate() helper from qemu_savevm_statepending_exact()
and
state_pending_exact() helper from qemu_savevm_statepending_estimate()

This patch fixes it.

Reviewed-by: Dr. David Alan Gilbert <dgilbert@redhat.com>
Signed-off-by: Juan Quintela <quintela@redhat.com>
This commit is contained in:
Juan Quintela 2023-02-09 14:29:45 +01:00
parent 4010ba388d
commit e264705012

View File

@ -1552,7 +1552,7 @@ void qemu_savevm_state_pending_estimate(uint64_t *res_precopy_only,
*res_postcopy_only = 0; *res_postcopy_only = 0;
QTAILQ_FOREACH(se, &savevm_state.handlers, entry) { QTAILQ_FOREACH(se, &savevm_state.handlers, entry) {
if (!se->ops || !se->ops->state_pending_exact) { if (!se->ops || !se->ops->state_pending_estimate) {
continue; continue;
} }
if (se->ops->is_active) { if (se->ops->is_active) {
@ -1560,9 +1560,9 @@ void qemu_savevm_state_pending_estimate(uint64_t *res_precopy_only,
continue; continue;
} }
} }
se->ops->state_pending_exact(se->opaque, se->ops->state_pending_estimate(se->opaque,
res_precopy_only, res_compatible, res_precopy_only, res_compatible,
res_postcopy_only); res_postcopy_only);
} }
} }
@ -1577,7 +1577,7 @@ void qemu_savevm_state_pending_exact(uint64_t *res_precopy_only,
*res_postcopy_only = 0; *res_postcopy_only = 0;
QTAILQ_FOREACH(se, &savevm_state.handlers, entry) { QTAILQ_FOREACH(se, &savevm_state.handlers, entry) {
if (!se->ops || !se->ops->state_pending_estimate) { if (!se->ops || !se->ops->state_pending_exact) {
continue; continue;
} }
if (se->ops->is_active) { if (se->ops->is_active) {
@ -1585,9 +1585,9 @@ void qemu_savevm_state_pending_exact(uint64_t *res_precopy_only,
continue; continue;
} }
} }
se->ops->state_pending_estimate(se->opaque, se->ops->state_pending_exact(se->opaque,
res_precopy_only, res_compatible, res_precopy_only, res_compatible,
res_postcopy_only); res_postcopy_only);
} }
} }