|
@@ -206,6 +206,10 @@ typedef struct AccountingInfo {
|
|
|
uint64_t dup_pages;
|
|
|
uint64_t norm_pages;
|
|
|
uint64_t iterations;
|
|
|
+ uint64_t xbzrle_bytes;
|
|
|
+ uint64_t xbzrle_pages;
|
|
|
+ uint64_t xbzrle_cache_miss;
|
|
|
+ uint64_t xbzrle_overflows;
|
|
|
} AccountingInfo;
|
|
|
|
|
|
static AccountingInfo acct_info;
|
|
@@ -235,6 +239,26 @@ uint64_t norm_mig_pages_transferred(void)
|
|
|
return acct_info.norm_pages;
|
|
|
}
|
|
|
|
|
|
+uint64_t xbzrle_mig_bytes_transferred(void)
|
|
|
+{
|
|
|
+ return acct_info.xbzrle_bytes;
|
|
|
+}
|
|
|
+
|
|
|
+uint64_t xbzrle_mig_pages_transferred(void)
|
|
|
+{
|
|
|
+ return acct_info.xbzrle_pages;
|
|
|
+}
|
|
|
+
|
|
|
+uint64_t xbzrle_mig_pages_cache_miss(void)
|
|
|
+{
|
|
|
+ return acct_info.xbzrle_cache_miss;
|
|
|
+}
|
|
|
+
|
|
|
+uint64_t xbzrle_mig_pages_overflow(void)
|
|
|
+{
|
|
|
+ return acct_info.xbzrle_overflows;
|
|
|
+}
|
|
|
+
|
|
|
static void save_block_hdr(QEMUFile *f, RAMBlock *block, ram_addr_t offset,
|
|
|
int cont, int flag)
|
|
|
{
|
|
@@ -259,6 +283,7 @@ static int save_xbzrle_page(QEMUFile *f, uint8_t *current_data,
|
|
|
if (!cache_is_cached(XBZRLE.cache, current_addr)) {
|
|
|
cache_insert(XBZRLE.cache, current_addr,
|
|
|
g_memdup(current_data, TARGET_PAGE_SIZE));
|
|
|
+ acct_info.xbzrle_cache_miss++;
|
|
|
return -1;
|
|
|
}
|
|
|
|
|
@@ -276,6 +301,7 @@ static int save_xbzrle_page(QEMUFile *f, uint8_t *current_data,
|
|
|
return 0;
|
|
|
} else if (encoded_len == -1) {
|
|
|
DPRINTF("Overflow\n");
|
|
|
+ acct_info.xbzrle_overflows++;
|
|
|
/* update data in the cache */
|
|
|
memcpy(prev_cached_page, current_data, TARGET_PAGE_SIZE);
|
|
|
return -1;
|
|
@@ -290,6 +316,8 @@ static int save_xbzrle_page(QEMUFile *f, uint8_t *current_data,
|
|
|
qemu_put_be16(f, encoded_len);
|
|
|
qemu_put_buffer(f, XBZRLE.encoded_buf, encoded_len);
|
|
|
bytes_sent = encoded_len + 1 + 2;
|
|
|
+ acct_info.xbzrle_pages++;
|
|
|
+ acct_info.xbzrle_bytes += bytes_sent;
|
|
|
|
|
|
return bytes_sent;
|
|
|
}
|