| 
									
										
										
										
											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-10-25 11:11:07 +02:00
										 |  |  |     /*
 | 
					
						
							|  |  |  |      * Number of bytes transferred with QEMUFile. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     Stat64 qemu_file_transferred; | 
					
						
							| 
									
										
										
										
											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: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-10-25 11:11:13 +02:00
										 |  |  | void migration_rate_reset(void); | 
					
						
							| 
									
										
										
										
											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 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * 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, .... | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2023-10-25 11:11:12 +02:00
										 |  |  | uint64_t migration_transferred_bytes(void); | 
					
						
							| 
									
										
										
										
											2023-04-26 19:04:06 +02:00
										 |  |  | #endif
 |