Commit 5b3c9638 authored by Juan Quintela's avatar Juan Quintela
Browse files

Only calculate expected_time for stage 2



ram_save_remaining() is an expensive operation when there is a lot of memory.
So we only call the function when we need it.

Signed-off-by: default avatarJuan Quintela <quintela@redhat.com>
parent d24981d3
Loading
Loading
Loading
Loading
+8 −5
Original line number Diff line number Diff line
@@ -314,7 +314,6 @@ int ram_save_live(QEMUFile *f, int stage, void *opaque)
    ram_addr_t addr;
    uint64_t bytes_transferred_last;
    double bwidth = 0;
    uint64_t expected_time = 0;
    int ret;

    if (stage < 0) {
@@ -391,12 +390,16 @@ int ram_save_live(QEMUFile *f, int stage, void *opaque)

    qemu_put_be64(f, RAM_SAVE_FLAG_EOS);

    if (stage == 2) {
        uint64_t expected_time;
        expected_time = ram_save_remaining() * TARGET_PAGE_SIZE / bwidth;

        DPRINTF("ram_save_live: expected(" PRIu64 ") <= max(" PRIu64 ")?\n",
                expected_time, migrate_max_downtime());

    return (stage == 2) && (expected_time <= migrate_max_downtime());
        return expected_time <= migrate_max_downtime();
    }
    return 0;
}

static inline void *host_from_stream_offset(QEMUFile *f,