Prechádzať zdrojové kódy

Merge tag 'for-upstream' of https://gitlab.com/bonzini/qemu into staging

* Boolean statistics for KVM
* Fix build on Haiku

# gpg: Signature made Tue 19 Jul 2022 10:32:34 BST
# gpg:                using RSA key F13338574B662389866C7682BFFBD25F78C7AE83
# gpg:                issuer "pbonzini@redhat.com"
# gpg: Good signature from "Paolo Bonzini <bonzini@gnu.org>" [full]
# gpg:                 aka "Paolo Bonzini <pbonzini@redhat.com>" [full]
# Primary key fingerprint: 46F5 9FBD 57D6 12E7 BFD4  E2F7 7E15 100C CD36 69B1
#      Subkey fingerprint: F133 3857 4B66 2389 866C  7682 BFFB D25F 78C7 AE83

* tag 'for-upstream' of https://gitlab.com/bonzini/qemu:
  util: Fix broken build on Haiku
  kvm: add support for boolean statistics
  monitor: add support for boolean statistics

Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
Peter Maydell 3 rokov pred
rodič
commit
5288bee45f
4 zmenil súbory, kde vykonal 15 pridanie a 2 odobranie
  1. 9 1
      accel/kvm/kvm-all.c
  2. 1 0
      linux-headers/linux/kvm.h
  3. 2 0
      monitor/hmp-cmds.c
  4. 3 1
      qapi/stats.json

+ 9 - 1
accel/kvm/kvm-all.c

@@ -3769,6 +3769,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;
@@ -3787,7 +3788,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 {
@@ -3835,6 +3839,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;

+ 1 - 0
linux-headers/linux/kvm.h

@@ -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

+ 2 - 0
monitor/hmp-cmds.c

@@ -2342,6 +2342,8 @@ static void print_stats_results(Monitor *mon, StatsTarget target,
 
 
         if (stats_value->type == QTYPE_QNUM) {
         if (stats_value->type == QTYPE_QNUM) {
             monitor_printf(mon, ": %" PRId64 "\n", stats_value->u.scalar);
             monitor_printf(mon, ": %" PRId64 "\n", stats_value->u.scalar);
+        } else if (stats_value->type == QTYPE_QBOOL) {
+            monitor_printf(mon, ": %s\n", stats_value->u.boolean ? "yes" : "no");
         } else if (stats_value->type == QTYPE_QLIST) {
         } else if (stats_value->type == QTYPE_QLIST) {
             uint64List *list;
             uint64List *list;
             int i;
             int i;

+ 3 - 1
qapi/stats.json

@@ -38,11 +38,12 @@
 # @bytes: stat reported in bytes.
 # @bytes: stat reported in bytes.
 # @seconds: stat reported in seconds.
 # @seconds: stat reported in seconds.
 # @cycles: stat reported in clock cycles.
 # @cycles: stat reported in clock cycles.
+# @boolean: stat is a boolean value.
 #
 #
 # Since: 7.1
 # Since: 7.1
 ##
 ##
 { 'enum' : 'StatsUnit',
 { 'enum' : 'StatsUnit',
-  'data' : [ 'bytes', 'seconds', 'cycles' ] }
+  'data' : [ 'bytes', 'seconds', 'cycles', 'boolean' ] }
 
 
 ##
 ##
 # @StatsProvider:
 # @StatsProvider:
@@ -123,6 +124,7 @@
 ##
 ##
 { 'alternate': 'StatsValue',
 { 'alternate': 'StatsValue',
   'data': { 'scalar': 'uint64',
   'data': { 'scalar': 'uint64',
+            'boolean': 'bool',
             'list': [ 'uint64' ] } }
             'list': [ 'uint64' ] } }
 
 
 ##
 ##