2023-04-26 19:04:06 +02:00
|
|
|
/*
|
|
|
|
* Migration stats
|
|
|
|
*
|
|
|
|
* Copyright (c) 2012-2023 Red Hat Inc
|
|
|
|
*
|
|
|
|
* Authors:
|
|
|
|
* Juan Quintela <quintela@redhat.com>
|
|
|
|
*
|
|
|
|
* This work is licensed under the terms of the GNU GPL, version 2 or later.
|
|
|
|
* See the COPYING file in the top-level directory.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef QEMU_MIGRATION_STATS_H
|
|
|
|
#define QEMU_MIGRATION_STATS_H
|
|
|
|
|
|
|
|
#include "qemu/stats64.h"
|
|
|
|
|
2023-05-15 21:56:58 +02:00
|
|
|
/*
|
|
|
|
* Amount of time to allocate to each "chunk" of bandwidth-throttled
|
|
|
|
* data.
|
|
|
|
*/
|
|
|
|
#define BUFFER_DELAY 100
|
|
|
|
|
2023-05-15 21:56:54 +02:00
|
|
|
/*
|
|
|
|
* If rate_limit_max is 0, there is special code to remove the rate
|
|
|
|
* limit.
|
|
|
|
*/
|
|
|
|
#define RATE_LIMIT_DISABLED 0
|
|
|
|
|
2023-04-26 19:04:06 +02:00
|
|
|
/*
|
|
|
|
* These are the ram migration statistic counters. It is loosely
|
|
|
|
* based on MigrationStats. We change to Stat64 any counter that
|
|
|
|
* needs to be updated using atomic ops (can be accessed by more than
|
|
|
|
* one thread).
|
|
|
|
*/
|
|
|
|
typedef struct {
|
2023-05-04 12:33:56 +02:00
|
|
|
/*
|
|
|
|
* Number of bytes that were dirty last time that we synced with
|
|
|
|
* the guest memory. We use that to calculate the downtime. As
|
|
|
|
* the remaining dirty amounts to what we know that is still dirty
|
|
|
|
* since last iteration, not counting what the guest has dirtied
|
|
|
|
* since we synchronized bitmaps.
|
|
|
|
*/
|
2023-04-26 19:04:06 +02:00
|
|
|
Stat64 dirty_bytes_last_sync;
|
2023-05-04 12:33:56 +02:00
|
|
|
/*
|
|
|
|
* Number of pages dirtied per second.
|
|
|
|
*/
|
2023-04-26 19:04:06 +02:00
|
|
|
Stat64 dirty_pages_rate;
|
2023-05-04 12:33:56 +02:00
|
|
|
/*
|
|
|
|
* Number of times we have synchronized guest bitmaps.
|
|
|
|
*/
|
2023-04-26 19:04:06 +02:00
|
|
|
Stat64 dirty_sync_count;
|
2023-05-04 12:33:56 +02:00
|
|
|
/*
|
|
|
|
* Number of times zero copy failed to send any page using zero
|
|
|
|
* copy.
|
|
|
|
*/
|
2023-04-26 19:04:06 +02:00
|
|
|
Stat64 dirty_sync_missed_zero_copy;
|
2023-05-04 12:33:56 +02:00
|
|
|
/*
|
|
|
|
* Number of bytes sent at migration completion stage while the
|
|
|
|
* guest is stopped.
|
|
|
|
*/
|
2023-04-26 19:04:06 +02:00
|
|
|
Stat64 downtime_bytes;
|
2023-05-04 12:33:56 +02:00
|
|
|
/*
|
|
|
|
* Number of bytes sent through multifd channels.
|
|
|
|
*/
|
2023-04-26 19:04:06 +02:00
|
|
|
Stat64 multifd_bytes;
|
2023-05-04 12:33:56 +02:00
|
|
|
/*
|
|
|
|
* Number of pages transferred that were not full of zeros.
|
|
|
|
*/
|
2023-04-26 19:04:06 +02:00
|
|
|
Stat64 normal_pages;
|
2023-05-04 12:33:56 +02:00
|
|
|
/*
|
|
|
|
* Number of bytes sent during postcopy.
|
|
|
|
*/
|
2023-04-26 19:04:06 +02:00
|
|
|
Stat64 postcopy_bytes;
|
2023-05-04 12:33:56 +02:00
|
|
|
/*
|
|
|
|
* Number of postcopy page faults that we have handled during
|
|
|
|
* postcopy stage.
|
|
|
|
*/
|
2023-04-26 19:04:06 +02:00
|
|
|
Stat64 postcopy_requests;
|
2023-05-04 12:33:56 +02:00
|
|
|
/*
|
|
|
|
* Number of bytes sent during precopy stage.
|
|
|
|
*/
|
2023-04-26 19:04:06 +02:00
|
|
|
Stat64 precopy_bytes;
|
2023-05-15 21:57:01 +02:00
|
|
|
/*
|
|
|
|
* Amount of transferred data at the start of current cycle.
|
|
|
|
*/
|
|
|
|
Stat64 rate_limit_start;
|
2023-05-15 21:56:58 +02:00
|
|
|
/*
|
|
|
|
* Maximum amount of data we can send in a cycle.
|
|
|
|
*/
|
|
|
|
Stat64 rate_limit_max;
|
2023-05-15 21:57:03 +02:00
|
|
|
/*
|
|
|
|
* Number of bytes sent through RDMA.
|
|
|
|
*/
|
|
|
|
Stat64 rdma_bytes;
|
2023-05-04 12:33:56 +02:00
|
|
|
/*
|
|
|
|
* Total number of bytes transferred.
|
|
|
|
*/
|
2023-04-26 19:04:06 +02:00
|
|
|
Stat64 transferred;
|
2023-05-04 12:33:57 +02:00
|
|
|
/*
|
|
|
|
* Number of pages transferred that were full of zeros.
|
|
|
|
*/
|
|
|
|
Stat64 zero_pages;
|
2023-04-26 19:40:13 +02:00
|
|
|
} MigrationAtomicStats;
|
2023-04-26 19:04:06 +02:00
|
|
|
|
2023-04-26 19:40:13 +02:00
|
|
|
extern MigrationAtomicStats mig_stats;
|
2023-04-26 19:04:06 +02:00
|
|
|
|
2023-05-15 21:56:58 +02:00
|
|
|
/**
|
|
|
|
* migration_rate_get: Get the maximum amount that can be transferred.
|
|
|
|
*
|
|
|
|
* Returns the maximum number of bytes that can be transferred in a cycle.
|
|
|
|
*/
|
|
|
|
uint64_t migration_rate_get(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* migration_rate_reset: Reset the rate limit counter.
|
|
|
|
*
|
|
|
|
* This is called when we know we start a new transfer cycle.
|
2023-05-15 21:57:01 +02:00
|
|
|
*
|
|
|
|
* @f: QEMUFile used for main migration channel
|
2023-05-15 21:56:58 +02:00
|
|
|
*/
|
2023-05-15 21:57:01 +02:00
|
|
|
void migration_rate_reset(QEMUFile *f);
|
2023-05-15 21:56:58 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* migration_rate_set: Set the maximum amount that can be transferred.
|
|
|
|
*
|
|
|
|
* Sets the maximum amount of bytes that can be transferred in one cycle.
|
|
|
|
*
|
|
|
|
* @new_rate: new maximum amount
|
|
|
|
*/
|
|
|
|
void migration_rate_set(uint64_t new_rate);
|
2023-05-15 21:56:59 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* migration_transferred_bytes: Return number of bytes transferred
|
|
|
|
*
|
|
|
|
* @f: QEMUFile used for main migration channel
|
|
|
|
*
|
|
|
|
* Returns how many bytes have we transferred since the beginning of
|
|
|
|
* the migration. It accounts for bytes sent through any migration
|
|
|
|
* channel, multifd, qemu_file, rdma, ....
|
|
|
|
*/
|
|
|
|
uint64_t migration_transferred_bytes(QEMUFile *f);
|
2023-04-26 19:04:06 +02:00
|
|
|
#endif
|