From: "Michael S. Tsirkin" <mst@redhat.com>
To: qemu-devel@nongnu.org
Cc: Peter Maydell <peter.maydell@linaro.org>,
Laurent Vivier <lvivier@redhat.com>,
Jonah Palmer <jonah.palmer@oracle.com>,
"Dr. David Alan Gilbert" <dgilbert@redhat.com>
Subject: [PULL 35/55] hmp: add virtio commands
Date: Mon, 10 Oct 2022 13:31:14 -0400 [thread overview]
Message-ID: <20221010172813.204597-36-mst@redhat.com> (raw)
In-Reply-To: <20221010172813.204597-1-mst@redhat.com>
From: Laurent Vivier <lvivier@redhat.com>
This patch implements the HMP versions of the virtio QMP commands.
[Jonah: Adjusted hmp monitor output format for features / statuses
with their descriptions.]
Signed-off-by: Laurent Vivier <lvivier@redhat.com>
Signed-off-by: Jonah Palmer <jonah.palmer@oracle.com>
Message-Id: <1660220684-24909-7-git-send-email-jonah.palmer@oracle.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
---
include/monitor/hmp.h | 5 +
monitor/hmp-cmds.c | 310 ++++++++++++++++++++++++++++++++++++++++++
hmp-commands-info.hx | 70 ++++++++++
3 files changed, 385 insertions(+)
diff --git a/include/monitor/hmp.h b/include/monitor/hmp.h
index a618eb1e4e..a9cf064ee8 100644
--- a/include/monitor/hmp.h
+++ b/include/monitor/hmp.h
@@ -95,6 +95,11 @@ void hmp_qom_list(Monitor *mon, const QDict *qdict);
void hmp_qom_get(Monitor *mon, const QDict *qdict);
void hmp_qom_set(Monitor *mon, const QDict *qdict);
void hmp_info_qom_tree(Monitor *mon, const QDict *dict);
+void hmp_virtio_query(Monitor *mon, const QDict *qdict);
+void hmp_virtio_status(Monitor *mon, const QDict *qdict);
+void hmp_virtio_queue_status(Monitor *mon, const QDict *qdict);
+void hmp_vhost_queue_status(Monitor *mon, const QDict *qdict);
+void hmp_virtio_queue_element(Monitor *mon, const QDict *qdict);
void object_add_completion(ReadLineState *rs, int nb_args, const char *str);
void object_del_completion(ReadLineState *rs, int nb_args, const char *str);
void device_add_completion(ReadLineState *rs, int nb_args, const char *str);
diff --git a/monitor/hmp-cmds.c b/monitor/hmp-cmds.c
index f90eea8d01..bab86c5537 100644
--- a/monitor/hmp-cmds.c
+++ b/monitor/hmp-cmds.c
@@ -43,6 +43,8 @@
#include "qapi/qapi-commands-stats.h"
#include "qapi/qapi-commands-tpm.h"
#include "qapi/qapi-commands-ui.h"
+#include "qapi/qapi-commands-virtio.h"
+#include "qapi/qapi-visit-virtio.h"
#include "qapi/qapi-visit-net.h"
#include "qapi/qapi-visit-migration.h"
#include "qapi/qmp/qdict.h"
@@ -2472,3 +2474,311 @@ exit:
exit_no_print:
error_free(err);
}
+
+static void hmp_virtio_dump_protocols(Monitor *mon,
+ VhostDeviceProtocols *pcol)
+{
+ strList *pcol_list = pcol->protocols;
+ while (pcol_list) {
+ monitor_printf(mon, "\t%s", pcol_list->value);
+ pcol_list = pcol_list->next;
+ if (pcol_list != NULL) {
+ monitor_printf(mon, ",\n");
+ }
+ }
+ monitor_printf(mon, "\n");
+ if (pcol->has_unknown_protocols) {
+ monitor_printf(mon, " unknown-protocols(0x%016"PRIx64")\n",
+ pcol->unknown_protocols);
+ }
+}
+
+static void hmp_virtio_dump_status(Monitor *mon,
+ VirtioDeviceStatus *status)
+{
+ strList *status_list = status->statuses;
+ while (status_list) {
+ monitor_printf(mon, "\t%s", status_list->value);
+ status_list = status_list->next;
+ if (status_list != NULL) {
+ monitor_printf(mon, ",\n");
+ }
+ }
+ monitor_printf(mon, "\n");
+ if (status->has_unknown_statuses) {
+ monitor_printf(mon, " unknown-statuses(0x%016"PRIx32")\n",
+ status->unknown_statuses);
+ }
+}
+
+static void hmp_virtio_dump_features(Monitor *mon,
+ VirtioDeviceFeatures *features)
+{
+ strList *transport_list = features->transports;
+ while (transport_list) {
+ monitor_printf(mon, "\t%s", transport_list->value);
+ transport_list = transport_list->next;
+ if (transport_list != NULL) {
+ monitor_printf(mon, ",\n");
+ }
+ }
+
+ monitor_printf(mon, "\n");
+ strList *list = features->dev_features;
+ if (list) {
+ while (list) {
+ monitor_printf(mon, "\t%s", list->value);
+ list = list->next;
+ if (list != NULL) {
+ monitor_printf(mon, ",\n");
+ }
+ }
+ monitor_printf(mon, "\n");
+ }
+
+ if (features->has_unknown_dev_features) {
+ monitor_printf(mon, " unknown-features(0x%016"PRIx64")\n",
+ features->unknown_dev_features);
+ }
+}
+
+void hmp_virtio_query(Monitor *mon, const QDict *qdict)
+{
+ Error *err = NULL;
+ VirtioInfoList *list = qmp_x_query_virtio(&err);
+ VirtioInfoList *node;
+
+ if (err != NULL) {
+ hmp_handle_error(mon, err);
+ return;
+ }
+
+ if (list == NULL) {
+ monitor_printf(mon, "No VirtIO devices\n");
+ return;
+ }
+
+ node = list;
+ while (node) {
+ monitor_printf(mon, "%s [%s]\n", node->value->path,
+ node->value->name);
+ node = node->next;
+ }
+ qapi_free_VirtioInfoList(list);
+}
+
+void hmp_virtio_status(Monitor *mon, const QDict *qdict)
+{
+ Error *err = NULL;
+ const char *path = qdict_get_try_str(qdict, "path");
+ VirtioStatus *s = qmp_x_query_virtio_status(path, &err);
+
+ if (err != NULL) {
+ hmp_handle_error(mon, err);
+ return;
+ }
+
+ monitor_printf(mon, "%s:\n", path);
+ monitor_printf(mon, " device_name: %s %s\n",
+ s->name, s->has_vhost_dev ? "(vhost)" : "");
+ monitor_printf(mon, " device_id: %d\n", s->device_id);
+ monitor_printf(mon, " vhost_started: %s\n",
+ s->vhost_started ? "true" : "false");
+ monitor_printf(mon, " bus_name: %s\n", s->bus_name);
+ monitor_printf(mon, " broken: %s\n",
+ s->broken ? "true" : "false");
+ monitor_printf(mon, " disabled: %s\n",
+ s->disabled ? "true" : "false");
+ monitor_printf(mon, " disable_legacy_check: %s\n",
+ s->disable_legacy_check ? "true" : "false");
+ monitor_printf(mon, " started: %s\n",
+ s->started ? "true" : "false");
+ monitor_printf(mon, " use_started: %s\n",
+ s->use_started ? "true" : "false");
+ monitor_printf(mon, " start_on_kick: %s\n",
+ s->start_on_kick ? "true" : "false");
+ monitor_printf(mon, " use_guest_notifier_mask: %s\n",
+ s->use_guest_notifier_mask ? "true" : "false");
+ monitor_printf(mon, " vm_running: %s\n",
+ s->vm_running ? "true" : "false");
+ monitor_printf(mon, " num_vqs: %"PRId64"\n", s->num_vqs);
+ monitor_printf(mon, " queue_sel: %d\n",
+ s->queue_sel);
+ monitor_printf(mon, " isr: %d\n", s->isr);
+ monitor_printf(mon, " endianness: %s\n",
+ s->device_endian);
+ monitor_printf(mon, " status:\n");
+ hmp_virtio_dump_status(mon, s->status);
+ monitor_printf(mon, " Guest features:\n");
+ hmp_virtio_dump_features(mon, s->guest_features);
+ monitor_printf(mon, " Host features:\n");
+ hmp_virtio_dump_features(mon, s->host_features);
+ monitor_printf(mon, " Backend features:\n");
+ hmp_virtio_dump_features(mon, s->backend_features);
+
+ if (s->has_vhost_dev) {
+ monitor_printf(mon, " VHost:\n");
+ monitor_printf(mon, " nvqs: %d\n",
+ s->vhost_dev->nvqs);
+ monitor_printf(mon, " vq_index: %"PRId64"\n",
+ s->vhost_dev->vq_index);
+ monitor_printf(mon, " max_queues: %"PRId64"\n",
+ s->vhost_dev->max_queues);
+ monitor_printf(mon, " n_mem_sections: %"PRId64"\n",
+ s->vhost_dev->n_mem_sections);
+ monitor_printf(mon, " n_tmp_sections: %"PRId64"\n",
+ s->vhost_dev->n_tmp_sections);
+ monitor_printf(mon, " backend_cap: %"PRId64"\n",
+ s->vhost_dev->backend_cap);
+ monitor_printf(mon, " log_enabled: %s\n",
+ s->vhost_dev->log_enabled ? "true" : "false");
+ monitor_printf(mon, " log_size: %"PRId64"\n",
+ s->vhost_dev->log_size);
+ monitor_printf(mon, " Features:\n");
+ hmp_virtio_dump_features(mon, s->vhost_dev->features);
+ monitor_printf(mon, " Acked features:\n");
+ hmp_virtio_dump_features(mon, s->vhost_dev->acked_features);
+ monitor_printf(mon, " Backend features:\n");
+ hmp_virtio_dump_features(mon, s->vhost_dev->backend_features);
+ monitor_printf(mon, " Protocol features:\n");
+ hmp_virtio_dump_protocols(mon, s->vhost_dev->protocol_features);
+ }
+
+ qapi_free_VirtioStatus(s);
+}
+
+void hmp_vhost_queue_status(Monitor *mon, const QDict *qdict)
+{
+ Error *err = NULL;
+ const char *path = qdict_get_try_str(qdict, "path");
+ int queue = qdict_get_int(qdict, "queue");
+ VirtVhostQueueStatus *s =
+ qmp_x_query_virtio_vhost_queue_status(path, queue, &err);
+
+ if (err != NULL) {
+ hmp_handle_error(mon, err);
+ return;
+ }
+
+ monitor_printf(mon, "%s:\n", path);
+ monitor_printf(mon, " device_name: %s (vhost)\n",
+ s->name);
+ monitor_printf(mon, " kick: %"PRId64"\n", s->kick);
+ monitor_printf(mon, " call: %"PRId64"\n", s->call);
+ monitor_printf(mon, " VRing:\n");
+ monitor_printf(mon, " num: %"PRId64"\n", s->num);
+ monitor_printf(mon, " desc: 0x%016"PRIx64"\n", s->desc);
+ monitor_printf(mon, " desc_phys: 0x%016"PRIx64"\n",
+ s->desc_phys);
+ monitor_printf(mon, " desc_size: %"PRId32"\n", s->desc_size);
+ monitor_printf(mon, " avail: 0x%016"PRIx64"\n", s->avail);
+ monitor_printf(mon, " avail_phys: 0x%016"PRIx64"\n",
+ s->avail_phys);
+ monitor_printf(mon, " avail_size: %"PRId32"\n", s->avail_size);
+ monitor_printf(mon, " used: 0x%016"PRIx64"\n", s->used);
+ monitor_printf(mon, " used_phys: 0x%016"PRIx64"\n",
+ s->used_phys);
+ monitor_printf(mon, " used_size: %"PRId32"\n", s->used_size);
+
+ qapi_free_VirtVhostQueueStatus(s);
+}
+
+void hmp_virtio_queue_status(Monitor *mon, const QDict *qdict)
+{
+ Error *err = NULL;
+ const char *path = qdict_get_try_str(qdict, "path");
+ int queue = qdict_get_int(qdict, "queue");
+ VirtQueueStatus *s = qmp_x_query_virtio_queue_status(path, queue, &err);
+
+ if (err != NULL) {
+ hmp_handle_error(mon, err);
+ return;
+ }
+
+ monitor_printf(mon, "%s:\n", path);
+ monitor_printf(mon, " device_name: %s\n", s->name);
+ monitor_printf(mon, " queue_index: %d\n", s->queue_index);
+ monitor_printf(mon, " inuse: %d\n", s->inuse);
+ monitor_printf(mon, " used_idx: %d\n", s->used_idx);
+ monitor_printf(mon, " signalled_used: %d\n",
+ s->signalled_used);
+ monitor_printf(mon, " signalled_used_valid: %s\n",
+ s->signalled_used_valid ? "true" : "false");
+ if (s->has_last_avail_idx) {
+ monitor_printf(mon, " last_avail_idx: %d\n",
+ s->last_avail_idx);
+ }
+ if (s->has_shadow_avail_idx) {
+ monitor_printf(mon, " shadow_avail_idx: %d\n",
+ s->shadow_avail_idx);
+ }
+ monitor_printf(mon, " VRing:\n");
+ monitor_printf(mon, " num: %"PRId32"\n", s->vring_num);
+ monitor_printf(mon, " num_default: %"PRId32"\n",
+ s->vring_num_default);
+ monitor_printf(mon, " align: %"PRId32"\n",
+ s->vring_align);
+ monitor_printf(mon, " desc: 0x%016"PRIx64"\n",
+ s->vring_desc);
+ monitor_printf(mon, " avail: 0x%016"PRIx64"\n",
+ s->vring_avail);
+ monitor_printf(mon, " used: 0x%016"PRIx64"\n",
+ s->vring_used);
+
+ qapi_free_VirtQueueStatus(s);
+}
+
+void hmp_virtio_queue_element(Monitor *mon, const QDict *qdict)
+{
+ Error *err = NULL;
+ const char *path = qdict_get_try_str(qdict, "path");
+ int queue = qdict_get_int(qdict, "queue");
+ int index = qdict_get_try_int(qdict, "index", -1);
+ VirtioQueueElement *e;
+ VirtioRingDescList *list;
+
+ e = qmp_x_query_virtio_queue_element(path, queue, index != -1,
+ index, &err);
+ if (err != NULL) {
+ hmp_handle_error(mon, err);
+ return;
+ }
+
+ monitor_printf(mon, "%s:\n", path);
+ monitor_printf(mon, " device_name: %s\n", e->name);
+ monitor_printf(mon, " index: %d\n", e->index);
+ monitor_printf(mon, " desc:\n");
+ monitor_printf(mon, " descs:\n");
+
+ list = e->descs;
+ while (list) {
+ monitor_printf(mon, " addr 0x%"PRIx64" len %d",
+ list->value->addr, list->value->len);
+ if (list->value->flags) {
+ strList *flag = list->value->flags;
+ monitor_printf(mon, " (");
+ while (flag) {
+ monitor_printf(mon, "%s", flag->value);
+ flag = flag->next;
+ if (flag) {
+ monitor_printf(mon, ", ");
+ }
+ }
+ monitor_printf(mon, ")");
+ }
+ list = list->next;
+ if (list) {
+ monitor_printf(mon, ",\n");
+ }
+ }
+ monitor_printf(mon, "\n");
+ monitor_printf(mon, " avail:\n");
+ monitor_printf(mon, " flags: %d\n", e->avail->flags);
+ monitor_printf(mon, " idx: %d\n", e->avail->idx);
+ monitor_printf(mon, " ring: %d\n", e->avail->ring);
+ monitor_printf(mon, " used:\n");
+ monitor_printf(mon, " flags: %d\n", e->used->flags);
+ monitor_printf(mon, " idx: %d\n", e->used->idx);
+
+ qapi_free_VirtioQueueElement(e);
+}
diff --git a/hmp-commands-info.hx b/hmp-commands-info.hx
index e012035541..754b1e8408 100644
--- a/hmp-commands-info.hx
+++ b/hmp-commands-info.hx
@@ -923,3 +923,73 @@ SRST
``stats``
Show runtime-collected statistics
ERST
+
+ {
+ .name = "virtio",
+ .args_type = "",
+ .params = "",
+ .help = "List all available virtio devices",
+ .cmd = hmp_virtio_query,
+ .flags = "p",
+ },
+
+SRST
+ ``info virtio``
+ List all available virtio devices
+ERST
+
+ {
+ .name = "virtio-status",
+ .args_type = "path:s",
+ .params = "path",
+ .help = "Display status of a given virtio device",
+ .cmd = hmp_virtio_status,
+ .flags = "p",
+ },
+
+SRST
+ ``info virtio-status`` *path*
+ Display status of a given virtio device
+ERST
+
+ {
+ .name = "virtio-queue-status",
+ .args_type = "path:s,queue:i",
+ .params = "path queue",
+ .help = "Display status of a given virtio queue",
+ .cmd = hmp_virtio_queue_status,
+ .flags = "p",
+ },
+
+SRST
+ ``info virtio-queue-status`` *path* *queue*
+ Display status of a given virtio queue
+ERST
+
+ {
+ .name = "virtio-vhost-queue-status",
+ .args_type = "path:s,queue:i",
+ .params = "path queue",
+ .help = "Display status of a given vhost queue",
+ .cmd = hmp_vhost_queue_status,
+ .flags = "p",
+ },
+
+SRST
+ ``info virtio-vhost-queue-status`` *path* *queue*
+ Display status of a given vhost queue
+ERST
+
+ {
+ .name = "virtio-queue-element",
+ .args_type = "path:s,queue:i,index:i?",
+ .params = "path queue [index]",
+ .help = "Display element of a given virtio queue",
+ .cmd = hmp_virtio_queue_element,
+ .flags = "p",
+ },
+
+SRST
+ ``info virtio-queue-element`` *path* *queue* [*index*]
+ Display element of a given virtio queue
+ERST
--
MST
next prev parent reply other threads:[~2022-10-10 18:36 UTC|newest]
Thread overview: 72+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-10-10 17:28 [PULL 00/55] pc,virtio: features, tests, fixes, cleanups Michael S. Tsirkin
2022-10-10 17:28 ` [PULL 01/55] hw/virtio: incorporate backend features in features Michael S. Tsirkin
2022-10-10 17:28 ` [PULL 02/55] include/hw/virtio: more comment for VIRTIO_F_BAD_FEATURE Michael S. Tsirkin
2022-10-10 17:28 ` [PULL 03/55] include/hw: document vhost_dev feature life-cycle Michael S. Tsirkin
2022-10-10 17:28 ` [PULL 04/55] hw/virtio: fix some coding style issues Michael S. Tsirkin
2022-10-10 17:28 ` [PULL 05/55] hw/virtio: log potentially buggy guest drivers Michael S. Tsirkin
2022-10-10 17:29 ` [PULL 06/55] hw/virtio: add some vhost-user trace events Michael S. Tsirkin
2022-10-10 17:29 ` [PULL 07/55] hw/virtio: move vm_running check to virtio_device_started Michael S. Tsirkin
2022-10-14 7:30 ` Regression save/restore of vsock: (was [PULL 07/55] hw/virtio: move vm_running check to virtio_device_started) Christian Borntraeger
2022-10-14 8:31 ` Christian Borntraeger
2022-10-14 11:07 ` Alex Bennée
2022-10-14 11:58 ` Christian Borntraeger
2022-10-14 8:37 ` Alex Bennée
2022-10-14 8:44 ` Christian Borntraeger
2022-11-05 16:45 ` [PULL 07/55] hw/virtio: move vm_running check to virtio_device_started Michael S. Tsirkin
2022-11-07 9:21 ` Alex Bennée
2022-10-10 17:29 ` [PULL 08/55] hw/virtio: move vhd->started check into helper and add FIXME Michael S. Tsirkin
2022-10-10 17:29 ` [PULL 09/55] hw/virtio: add boilerplate for vhost-user-gpio device Michael S. Tsirkin
2022-10-10 17:29 ` [PULL 10/55] hw/virtio: add vhost-user-gpio-pci boilerplate Michael S. Tsirkin
2022-10-10 17:29 ` [PULL 11/55] tests/qtest: pass stdout/stderr down to subtests Michael S. Tsirkin
2022-10-10 17:29 ` [PULL 12/55] tests/qtest: add a timeout for subprocess_run_one_test Michael S. Tsirkin
2022-10-10 17:29 ` [PULL 13/55] tests/qtest: use qos_printf instead of g_test_message Michael S. Tsirkin
2022-10-10 17:29 ` [PULL 14/55] tests/qtest: catch unhandled vhost-user messages Michael S. Tsirkin
2022-10-10 17:29 ` [PULL 15/55] tests/qtest: plain g_assert for VHOST_USER_F_PROTOCOL_FEATURES Michael S. Tsirkin
2022-10-10 17:29 ` [PULL 16/55] tests/qtest: add assert to catch bad features Michael S. Tsirkin
2022-10-10 17:29 ` [PULL 17/55] tests/qtest: implement stub for VHOST_USER_GET_CONFIG Michael S. Tsirkin
2022-10-10 17:29 ` [PULL 18/55] tests/qtest: add a get_features op to vhost-user-test Michael S. Tsirkin
2022-10-10 17:30 ` [PULL 19/55] tests/qtest: enable tests for virtio-gpio Michael S. Tsirkin
2022-10-10 17:30 ` [PULL 20/55] virtio: introduce VirtIOConfigSizeParams & virtio_get_config_size Michael S. Tsirkin
2022-10-10 17:30 ` [PULL 21/55] virtio-blk: move config size params to virtio-blk-common Michael S. Tsirkin
2022-10-10 17:30 ` [PULL 22/55] vhost-user-blk: make it possible to disable write-zeroes/discard Michael S. Tsirkin
2022-10-10 17:30 ` [PULL 23/55] vhost-user-blk: make 'config_wce' part of 'host_features' Michael S. Tsirkin
2022-10-10 17:30 ` [PULL 24/55] vhost-user-blk: dynamically resize config space based on features Michael S. Tsirkin
2022-10-10 17:30 ` [PULL 25/55] tests/acpi: virt: allow acpi GTDT changes Michael S. Tsirkin
2022-10-10 17:30 ` [PULL 26/55] acpi: arm/virt: build_gtdt: fix invalid 64-bit physical addresses Michael S. Tsirkin
2022-10-10 17:30 ` [PULL 27/55] tests/acpi: virt: update ACPI GTDT binaries Michael S. Tsirkin
2022-10-10 17:30 ` [PULL 28/55] mem/cxl-type3: Add sn option to provide serial number for PCI ecap Michael S. Tsirkin
2022-10-10 17:30 ` [PULL 29/55] Revert "intel_iommu: Fix irqchip / X2APIC configuration checks" Michael S. Tsirkin
2022-10-10 17:39 ` David Woodhouse
2022-10-10 19:08 ` Peter Xu
2022-10-10 23:16 ` David Woodhouse
2022-10-11 0:04 ` Peter Xu
2022-10-10 17:30 ` [PULL 30/55] qmp: add QMP command x-query-virtio Michael S. Tsirkin
2022-10-10 17:30 ` [PULL 31/55] qmp: add QMP command x-query-virtio-status Michael S. Tsirkin
2022-10-10 17:31 ` [PULL 32/55] qmp: decode feature & status bits in virtio-status Michael S. Tsirkin
2022-10-10 17:31 ` [PULL 33/55] qmp: add QMP commands for virtio/vhost queue-status Michael S. Tsirkin
2022-10-10 17:31 ` [PULL 34/55] qmp: add QMP command x-query-virtio-queue-element Michael S. Tsirkin
2022-10-10 17:31 ` Michael S. Tsirkin [this message]
2022-10-10 17:31 ` [PULL 36/55] pci: Remove unused pci_get_*_by_mask() functions Michael S. Tsirkin
2022-10-10 17:31 ` [PULL 37/55] pci: Sanity check mask argument to pci_set_*_by_mask() Michael S. Tsirkin
2022-10-10 17:31 ` [PULL 38/55] hw/smbios: support for type 8 (port connector) Michael S. Tsirkin
2022-10-10 17:31 ` [PULL 39/55] tests: acpi: whitelist pc/q35 DSDT due to HPET AML move Michael S. Tsirkin
2022-10-10 17:31 ` [PULL 40/55] acpi: x86: deduplicate HPET AML building Michael S. Tsirkin
2022-10-10 17:31 ` [PULL 41/55] tests: acpi: update expected blobs after HPET move Michael S. Tsirkin
2022-10-10 17:31 ` [PULL 42/55] tests: acpi: whitelist pc/q35 DSDT due to HPET AML move Michael S. Tsirkin
2022-10-10 17:31 ` [PULL 43/55] acpi: x86: refactor PDSM method to reduce nesting Michael S. Tsirkin
2022-10-10 17:31 ` [PULL 44/55] x86: acpi: _DSM: use Package to pass parameters Michael S. Tsirkin
2022-10-10 17:32 ` [PULL 45/55] tests: acpi: update expected blobs Michael S. Tsirkin
2022-10-10 17:32 ` [PULL 46/55] tests: acpi: whitelist pc/q35 DSDT before switching _DSM to use ASUN Michael S. Tsirkin
2022-10-10 17:32 ` [PULL 47/55] x86: acpi: cleanup PCI device _DSM duplication Michael S. Tsirkin
2022-10-10 17:32 ` [PULL 48/55] tests: acpi: update expected blobs Michael S. Tsirkin
2022-10-10 17:32 ` [PULL 49/55] tests: acpi: whitelist pc/q35 DSDT before moving _ADR field Michael S. Tsirkin
2022-10-10 17:32 ` [PULL 50/55] x86: pci: acpi: reorder Device's _ADR and _SUN fields Michael S. Tsirkin
2022-10-10 17:32 ` [PULL 51/55] tests: acpi: update expected blobs Michael S. Tsirkin
2022-10-10 17:32 ` [PULL 52/55] tests: acpi: whitelist pc/q35 DSDT before moving _ADR field Michael S. Tsirkin
2022-10-10 17:32 ` [PULL 53/55] x86: pci: acpi: reorder Device's _DSM method Michael S. Tsirkin
2022-10-10 17:32 ` [PULL 54/55] tests: acpi: update expected blobs Michael S. Tsirkin
2022-10-10 17:32 ` [PULL 55/55] x86: pci: acpi: consolidate PCI slots creation Michael S. Tsirkin
2022-10-12 20:04 ` [PULL 00/55] pc,virtio: features, tests, fixes, cleanups Stefan Hajnoczi
2022-10-12 20:59 ` Michael S. Tsirkin
2022-10-12 21:01 ` Stefan Hajnoczi
2022-10-12 21:25 ` Stefan Hajnoczi
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20221010172813.204597-36-mst@redhat.com \
--to=mst@redhat.com \
--cc=dgilbert@redhat.com \
--cc=jonah.palmer@oracle.com \
--cc=lvivier@redhat.com \
--cc=peter.maydell@linaro.org \
--cc=qemu-devel@nongnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).