@@ -2921,6 +2921,40 @@ BlockInfoList *qmp_query_block(Error **errp)
return head;
}
+static void bdrv_get_dedup_metrics(const BlockDriverState *bs,
+ BlockDeviceStats *stats)
+{
+ BlockDriverInfo bdi;
+
+ if (bdrv_get_info((BlockDriverState *) bs, &bdi) < 0) {
+ return;
+ }
+
+ if (!bdi.has_dedup) {
+ return;
+ }
+
+ stats->has_deduplication = true;
+ stats->deduplication = g_malloc0(sizeof(*stats->deduplication));
+ stats->deduplication->deduplicated_clusters =
+ bdi.dedup_metrics.deduplicated_clusters;
+ stats->deduplication->non_deduplicated_clusters =
+ bdi.dedup_metrics.non_deduplicated_clusters;
+ stats->deduplication->missing_data_reads =
+ bdi.dedup_metrics.missing_data_reads;
+ stats->deduplication->ram_hash_creations =
+ bdi.dedup_metrics.ram_hash_creations;
+ stats->deduplication->ram_hash_deletions =
+ bdi.dedup_metrics.ram_hash_deletions;
+ stats->deduplication->ram_usage =
+ bdi.dedup_metrics.ram_usage;
+ stats->deduplication->deleted_clusters =
+ bdi.dedup_metrics.deleted_clusters;
+ stats->deduplication->refcount_overflows =
+ bdi.dedup_metrics.refcount_overflows;
+ stats->deduplication->running = bdi.dedup_running;
+}
+
BlockStats *bdrv_query_stats(const BlockDriverState *bs)
{
BlockStats *s;
@@ -2943,6 +2977,8 @@ BlockStats *bdrv_query_stats(const BlockDriverState *bs)
s->stats->rd_total_time_ns = bs->total_time_ns[BDRV_ACCT_READ];
s->stats->flush_total_time_ns = bs->total_time_ns[BDRV_ACCT_FLUSH];
+ bdrv_get_dedup_metrics(bs, s->stats);
+
if (bs->file) {
s->has_parent = true;
s->parent = bdrv_query_stats(bs->file);