[PATCH Libvirt v3 08/10] qemu_monitor: Implement qemuMonitorQueryVcpuDirtyLimit

~hyman posted 10 patches 1 year, 4 months ago
[PATCH Libvirt v3 08/10] qemu_monitor: Implement qemuMonitorQueryVcpuDirtyLimit
Posted by ~hyman 2 years, 5 months ago
From: Hyman Huang(黄勇) <yong.huang@smartx.com>

Implement qemuMonitorQueryVcpuDirtyLimit which query vcpu
dirty limit info by calling qmp 'query-vcpu-dirty-limit'.

Signed-off-by: Hyman Huang(黄勇) <yong.huang@smartx.com>
---
 src/qemu/qemu_monitor.c      | 12 +++++++
 src/qemu/qemu_monitor.h      | 17 ++++++++++
 src/qemu/qemu_monitor_json.c | 64 ++++++++++++++++++++++++++++++++++++
 src/qemu/qemu_monitor_json.h |  4 +++
 4 files changed, 97 insertions(+)

diff --git a/src/qemu/qemu_monitor.c b/src/qemu/qemu_monitor.c
index 90bc0e62c9..9b18b4e46b 100644
--- a/src/qemu/qemu_monitor.c
+++ b/src/qemu/qemu_monitor.c
@@ -4513,3 +4513,15 @@ qemuMonitorSetVcpuDirtyLimit(qemuMonitor *mon,
 
     return qemuMonitorJSONSetVcpuDirtyLimit(mon, vcpu, rate);
 }
+
+
+int
+qemuMonitorQueryVcpuDirtyLimit(qemuMonitor *mon,
+                               qemuMonitorVcpuDirtyLimitInfo *info)
+{
+    VIR_DEBUG("info=%p", info);
+
+    QEMU_CHECK_MONITOR(mon);
+
+    return qemuMonitorJSONQueryVcpuDirtyLimit(mon, info);
+}
diff --git a/src/qemu/qemu_monitor.h b/src/qemu/qemu_monitor.h
index 07a05365cf..1828bb202a 100644
--- a/src/qemu/qemu_monitor.h
+++ b/src/qemu/qemu_monitor.h
@@ -1584,3 +1584,20 @@ int
 qemuMonitorSetVcpuDirtyLimit(qemuMonitor *mon,
                              int vcpu,
                              unsigned long long rate);
+
+typedef struct _qemuMonitorVcpuDirtyLimit qemuMonitorVcpuDirtyLimit;
+struct _qemuMonitorVcpuDirtyLimit {
+    int idx;                        /* virtual cpu index */
+    unsigned long long limit;       /* virtual cpu dirty page rate limit in MB/s */
+    unsigned long long current;     /* virtual cpu dirty page rate in MB/s */
+};
+
+typedef struct _qemuMonitorVcpuDirtyLimitInfo qemuMonitorVcpuDirtyLimitInfo;
+struct _qemuMonitorVcpuDirtyLimitInfo {
+    size_t nvcpus;                      /* number of virtual cpu */
+    qemuMonitorVcpuDirtyLimit *limits;   /* array of dirty page rate limit */
+};
+
+int
+qemuMonitorQueryVcpuDirtyLimit(qemuMonitor *mon,
+                               qemuMonitorVcpuDirtyLimitInfo *info);
diff --git a/src/qemu/qemu_monitor_json.c b/src/qemu/qemu_monitor_json.c
index c8f6069566..8a72abf28d 100644
--- a/src/qemu/qemu_monitor_json.c
+++ b/src/qemu/qemu_monitor_json.c
@@ -8895,3 +8895,67 @@ qemuMonitorJSONSetVcpuDirtyLimit(qemuMonitor *mon,
 
     return 0;
 }
+
+static int
+qemuMonitorJSONExtractVcpuDirtyLimitInfo(virJSONValue *data,
+                                         qemuMonitorVcpuDirtyLimitInfo *info)
+{
+    size_t nvcpus;
+    size_t i;
+
+    nvcpus = virJSONValueArraySize(data);
+    info->nvcpus = nvcpus;
+    info->limits = g_new0(qemuMonitorVcpuDirtyLimit, nvcpus);
+
+    for (i = 0; i < nvcpus; i++) {
+        virJSONValue *entry = virJSONValueArrayGet(data, i);
+        if (virJSONValueObjectGetNumberInt(entry, "cpu-index",
+                                           &info->limits[i].idx) < 0) {
+            virReportError(VIR_ERR_INTERNAL_ERROR, "%s",
+                           _("query-vcpu-dirty-limit reply was missing 'cpu-index' data"));
+            return -1;
+        }
+
+        if (virJSONValueObjectGetNumberUlong(entry, "limit-rate",
+                                             &info->limits[i].limit) < 0) {
+            virReportError(VIR_ERR_INTERNAL_ERROR, "%s",
+                           _("query-vcpu-dirty-limit reply was missing 'limit-rate' data"));
+            return -1;
+        }
+
+        if (virJSONValueObjectGetNumberUlong(entry, "current-rate",
+                                            &info->limits[i].current) < 0) {
+            virReportError(VIR_ERR_INTERNAL_ERROR, "%s",
+                           _("query-vcpu-dirty-limit reply was missing 'current-rate' data"));
+            return -1;
+        }
+    }
+
+    return 0;
+}
+
+int
+qemuMonitorJSONQueryVcpuDirtyLimit(qemuMonitor *mon,
+                                   qemuMonitorVcpuDirtyLimitInfo *info)
+{
+    g_autoptr(virJSONValue) cmd = NULL;
+    g_autoptr(virJSONValue) reply = NULL;
+    virJSONValue *data = NULL;
+
+    if (!(cmd = qemuMonitorJSONMakeCommand("query-vcpu-dirty-limit", NULL)))
+        return -1;
+
+    if (qemuMonitorJSONCommand(mon, cmd, &reply) < 0)
+        return -1;
+
+    if (qemuMonitorJSONCheckError(cmd, reply) < 0)
+        return -1;
+
+    if (!(data = virJSONValueObjectGetArray(reply, "return"))) {
+        virReportError(VIR_ERR_INTERNAL_ERROR, "%s",
+                       _("query-vcpu-dirty-limit reply was missing 'return' data"));
+        return -1;
+    }
+
+    return qemuMonitorJSONExtractVcpuDirtyLimitInfo(data, info);
+}
diff --git a/src/qemu/qemu_monitor_json.h b/src/qemu/qemu_monitor_json.h
index 89f61b3052..bd8131508b 100644
--- a/src/qemu/qemu_monitor_json.h
+++ b/src/qemu/qemu_monitor_json.h
@@ -830,3 +830,7 @@ int
 qemuMonitorJSONSetVcpuDirtyLimit(qemuMonitor *mon,
                                  int vcpu,
                                  unsigned long long rate);
+
+int
+qemuMonitorJSONQueryVcpuDirtyLimit(qemuMonitor *mon,
+                                   qemuMonitorVcpuDirtyLimitInfo *info);
-- 
2.38.5