kvm: add support for boolean statistics
The next version of Linux will introduce boolean statistics, which can only have 0 or 1 values. Convert them to the new QAPI fields added in the previous commit. Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
parent
1ca1a7ec36
commit
105bb7cdbe
@ -3743,6 +3743,7 @@ static StatsList *add_kvmstat_entry(struct kvm_stats_desc *pdesc,
|
|||||||
case KVM_STATS_UNIT_BYTES:
|
case KVM_STATS_UNIT_BYTES:
|
||||||
case KVM_STATS_UNIT_CYCLES:
|
case KVM_STATS_UNIT_CYCLES:
|
||||||
case KVM_STATS_UNIT_SECONDS:
|
case KVM_STATS_UNIT_SECONDS:
|
||||||
|
case KVM_STATS_UNIT_BOOLEAN:
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
return stats_list;
|
return stats_list;
|
||||||
@ -3761,7 +3762,10 @@ static StatsList *add_kvmstat_entry(struct kvm_stats_desc *pdesc,
|
|||||||
stats->name = g_strdup(pdesc->name);
|
stats->name = g_strdup(pdesc->name);
|
||||||
stats->value = g_new0(StatsValue, 1);;
|
stats->value = g_new0(StatsValue, 1);;
|
||||||
|
|
||||||
if (pdesc->size == 1) {
|
if ((pdesc->flags & KVM_STATS_UNIT_MASK) == KVM_STATS_UNIT_BOOLEAN) {
|
||||||
|
stats->value->u.boolean = *stats_data;
|
||||||
|
stats->value->type = QTYPE_QBOOL;
|
||||||
|
} else if (pdesc->size == 1) {
|
||||||
stats->value->u.scalar = *stats_data;
|
stats->value->u.scalar = *stats_data;
|
||||||
stats->value->type = QTYPE_QNUM;
|
stats->value->type = QTYPE_QNUM;
|
||||||
} else {
|
} else {
|
||||||
@ -3809,6 +3813,10 @@ static StatsSchemaValueList *add_kvmschema_entry(struct kvm_stats_desc *pdesc,
|
|||||||
switch (pdesc->flags & KVM_STATS_UNIT_MASK) {
|
switch (pdesc->flags & KVM_STATS_UNIT_MASK) {
|
||||||
case KVM_STATS_UNIT_NONE:
|
case KVM_STATS_UNIT_NONE:
|
||||||
break;
|
break;
|
||||||
|
case KVM_STATS_UNIT_BOOLEAN:
|
||||||
|
schema_entry->value->has_unit = true;
|
||||||
|
schema_entry->value->unit = STATS_UNIT_BOOLEAN;
|
||||||
|
break;
|
||||||
case KVM_STATS_UNIT_BYTES:
|
case KVM_STATS_UNIT_BYTES:
|
||||||
schema_entry->value->has_unit = true;
|
schema_entry->value->has_unit = true;
|
||||||
schema_entry->value->unit = STATS_UNIT_BYTES;
|
schema_entry->value->unit = STATS_UNIT_BYTES;
|
||||||
|
@ -2031,6 +2031,7 @@ struct kvm_stats_header {
|
|||||||
#define KVM_STATS_UNIT_BYTES (0x1 << KVM_STATS_UNIT_SHIFT)
|
#define KVM_STATS_UNIT_BYTES (0x1 << KVM_STATS_UNIT_SHIFT)
|
||||||
#define KVM_STATS_UNIT_SECONDS (0x2 << KVM_STATS_UNIT_SHIFT)
|
#define KVM_STATS_UNIT_SECONDS (0x2 << KVM_STATS_UNIT_SHIFT)
|
||||||
#define KVM_STATS_UNIT_CYCLES (0x3 << KVM_STATS_UNIT_SHIFT)
|
#define KVM_STATS_UNIT_CYCLES (0x3 << KVM_STATS_UNIT_SHIFT)
|
||||||
|
#define KVM_STATS_UNIT_BOOLEAN (0x4 << KVM_STATS_UNIT_SHIFT)
|
||||||
#define KVM_STATS_UNIT_MAX KVM_STATS_UNIT_CYCLES
|
#define KVM_STATS_UNIT_MAX KVM_STATS_UNIT_CYCLES
|
||||||
|
|
||||||
#define KVM_STATS_BASE_SHIFT 8
|
#define KVM_STATS_BASE_SHIFT 8
|
||||||
|
Loading…
Reference in New Issue
Block a user