From: Claudio Fontana <claudio.fontana@huawei.com>
To: marcandre.lureau@redhat.com, qemu-devel@nongnu.org
Cc: drjones@redhat.com, cam@cs.ualberta.ca,
"Andreas Färber" <afaerber@suse.de>,
stefanha@redhat.com
Subject: Re: [Qemu-devel] [PATCH v3 40/46] tests: add ivshmem qtest
Date: Tue, 22 Sep 2015 16:44:52 +0200 [thread overview]
Message-ID: <56016964.6070900@huawei.com> (raw)
In-Reply-To: <1442333283-13119-41-git-send-email-marcandre.lureau@redhat.com>
On 15.09.2015 18:07, marcandre.lureau@redhat.com wrote:
> From: Marc-André Lureau <marcandre.lureau@redhat.com>
>
> Adds 4 ivshmemtests:
> - single qemu instance and basic IO
> - pair of instances, check memory sharing
> - pair of instances with server, and MSIX
> - hot plug/unplug
>
> A temporary shm is created as well as a directory to place server
> socket, both should be clear on exit and abort.
>
> Cc: Cam Macdonell <cam@cs.ualberta.ca>
> CC: Andreas Färber <afaerber@suse.de>
> Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
> ---
> tests/Makefile | 3 +
> tests/ivshmem-test.c | 474 +++++++++++++++++++++++++++++++++++++++++++++++++++
> 2 files changed, 477 insertions(+)
> create mode 100644 tests/ivshmem-test.c
>
> diff --git a/tests/Makefile b/tests/Makefile
> index 34c6136..e7a50e7 100644
> --- a/tests/Makefile
> +++ b/tests/Makefile
> @@ -142,6 +142,8 @@ gcov-files-pci-y += hw/display/virtio-gpu-pci.c
> gcov-files-pci-$(CONFIG_VIRTIO_VGA) += hw/display/virtio-vga.c
> check-qtest-pci-y += tests/intel-hda-test$(EXESUF)
> gcov-files-pci-y += hw/audio/intel-hda.c hw/audio/hda-codec.c
> +check-qtest-pci-$(CONFIG_LINUX) += tests/ivshmem-test$(EXESUF)
> +gcov-files-pci-y += hw/misc/ivshmem.c
>
> check-qtest-i386-y = tests/endianness-test$(EXESUF)
> check-qtest-i386-y += tests/fdc-test$(EXESUF)
> @@ -416,6 +418,7 @@ tests/vhost-user-test$(EXESUF): tests/vhost-user-test.o qemu-char.o qemu-timer.o
> tests/qemu-iotests/socket_scm_helper$(EXESUF): tests/qemu-iotests/socket_scm_helper.o
> tests/test-qemu-opts$(EXESUF): tests/test-qemu-opts.o libqemuutil.a libqemustub.a
> tests/test-write-threshold$(EXESUF): tests/test-write-threshold.o $(block-obj-y) libqemuutil.a libqemustub.a
> +tests/ivshmem-test$(EXESUF): tests/ivshmem-test.o contrib/ivshmem-server/ivshmem-server.o $(libqos-pc-obj-y)
>
> ifeq ($(CONFIG_POSIX),y)
> LIBS += -lutil
> diff --git a/tests/ivshmem-test.c b/tests/ivshmem-test.c
> new file mode 100644
> index 0000000..03f44c1
> --- /dev/null
> +++ b/tests/ivshmem-test.c
> @@ -0,0 +1,474 @@
> +/*
> + * QTest testcase for ivshmem
> + *
> + * Copyright (c) 2015 Red Hat, Inc.
> + *
> + * This work is licensed under the terms of the GNU GPL, version 2 or later.
> + * See the COPYING file in the top-level directory.
> + */
> +
> +#include <errno.h>
> +#include <fcntl.h>
> +#include <glib.h>
> +#include <glib/gstdio.h>
> +#include <string.h>
> +#include <sys/mman.h>
> +#include <unistd.h>
> +#include "contrib/ivshmem-server/ivshmem-server.h"
> +#include "libqos/pci-pc.h"
> +#include "libqtest.h"
> +#include "qemu/osdep.h"
> +#include <stdlib.h>
> +
> +#if GLIB_CHECK_VERSION(2, 32, 0)
> +#define HAVE_THREAD_NEW
> +#endif
> +
> +#define TMPSHMSIZE (1 << 20)
> +static char *tmpshm;
> +static void *tmpshmem;
> +static char *tmpdir;
> +static char *tmpserver;
> +
> +static void save_fn(QPCIDevice *dev, int devfn, void *data)
> +{
> + QPCIDevice **pdev = (QPCIDevice **) data;
> +
> + *pdev = dev;
> +}
> +
> +static QPCIDevice *get_device(void)
> +{
> + QPCIDevice *dev;
> + QPCIBus *pcibus;
> +
> + pcibus = qpci_init_pc();
> + qpci_device_foreach(pcibus, 0x1af4, 0x1110, save_fn, &dev);
> + g_assert(dev != NULL);
> +
> + return dev;
> +}
> +
> +typedef struct _IVState {
> + QTestState *qtest;
> + void *reg_base, *mem_base;
> + QPCIDevice *dev;
> +} IVState;
> +
> +#define REG(name, len, val) \
> + static inline unsigned in_##name(IVState *s) \
> + { \
> + QTestState *qtest = global_qtest; \
> + unsigned res; \
> + global_qtest = s->qtest; \
> + res = qpci_io_read##len(s->dev, s->reg_base+(val)); \
> + g_test_message("*%s -> %x\n", #name, res); \
> + global_qtest = qtest; \
> + return res; \
> + } \
> + static inline void out_##name(IVState *s, unsigned v) \
> + { \
> + QTestState *qtest = global_qtest; \
> + global_qtest = s->qtest; \
> + g_test_message("%x -> *%s\n", v, #name); \
> + qpci_io_write##len(s->dev, s->reg_base+(val), v); \
> + global_qtest = qtest; \
> + }
> +
> +REG(IntrMask, l, 0)
> +REG(IntrStatus, l, 4)
> +REG(IVPosition, l, 8)
> +REG(DoorBell, l, 12)
I find this kind of macro use an aberration, but it is common use in QEMU (unfortunately), and becoming worse.
If somebody else wants to step in and add his own tag on this I would feel like less of an accomplice in this crime.
Ciao,
Claudio
> +
> +#if 0
> +static void info_qtree(void)
> +{
> + QDict *response;
> +
> + response = qmp("{'execute': 'human-monitor-command',"
> + " 'arguments': {"
> + " 'command-line': 'info qtree'"
> + "}}");
> + g_assert(response);
> + g_debug(qdict_get_try_str(response, "return"));
> + QDECREF(response);
> +}
> +#endif
> +
> +static void setup_vm_cmd(IVState *s, const char *cmd, bool msix)
> +{
> + uint64_t barsize;
> +
> + s->qtest = qtest_start(cmd);
> +
> + s->dev = get_device();
> +
> + /* FIXME: other bar order fails, mappings changes */
> + s->mem_base = qpci_iomap(s->dev, 2, &barsize);
> + g_assert_nonnull(s->mem_base);
> + g_assert_cmpuint(barsize, ==, TMPSHMSIZE);
> +
> + if (msix) {
> + qpci_msix_enable(s->dev);
> + }
> +
> + s->reg_base = qpci_iomap(s->dev, 0, &barsize);
> + g_assert_nonnull(s->reg_base);
> + g_assert_cmpuint(barsize, ==, 256);
> +
> + qpci_device_enable(s->dev);
> +}
> +
> +static void setup_vm(IVState *s)
> +{
> + char *cmd = g_strdup_printf("-device ivshmem,shm=%s,size=1M", tmpshm);
> +
> + setup_vm_cmd(s, cmd, false);
> +
> + g_free(cmd);
> +}
> +
> +static void test_ivshmem_single(void)
> +{
> + IVState state, *s;
> + uint32_t data[1024];
> + int i;
> +
> + setup_vm(&state);
> + s = &state;
> +
> + /* valid io */
> + out_IntrMask(s, 0);
> + in_IntrStatus(s);
> + in_IVPosition(s);
> +
> + out_IntrMask(s, 0xffffffff);
> + g_assert_cmpuint(in_IntrMask(s), ==, 0xffffffff);
> + out_IntrStatus(s, 1);
> + /* XXX: intercept IRQ, not seen in resp */
> + g_assert_cmpuint(in_IntrStatus(s), ==, 1);
> +
> + /* invalid io */
> + out_IVPosition(s, 1);
> + out_DoorBell(s, 8 << 16);
> +
> + for (i = 0; i < G_N_ELEMENTS(data); i++) {
> + data[i] = i;
> + }
> + qtest_memwrite(s->qtest, (uintptr_t)s->mem_base, data, sizeof(data));
> +
> + for (i = 0; i < G_N_ELEMENTS(data); i++) {
> + g_assert_cmpuint(((uint32_t *)tmpshmem)[i], ==, i);
> + }
> +
> + memset(data, 0, sizeof(data));
> +
> + qtest_memread(s->qtest, (uintptr_t)s->mem_base, data, sizeof(data));
> + for (i = 0; i < G_N_ELEMENTS(data); i++) {
> + g_assert_cmpuint(data[i], ==, i);
> + }
> +
> + qtest_quit(s->qtest);
> +}
> +
> +static void test_ivshmem_pair(void)
> +{
> + IVState state1, state2, *s1, *s2;
> + char *data;
> + int i;
> +
> + setup_vm(&state1);
> + s1 = &state1;
> + setup_vm(&state2);
> + s2 = &state2;
> +
> + data = g_malloc0(TMPSHMSIZE);
> +
> + /* host write, guest 1 & 2 read */
> + memset(tmpshmem, 0x42, TMPSHMSIZE);
> + qtest_memread(s1->qtest, (uintptr_t)s1->mem_base, data, TMPSHMSIZE);
> + for (i = 0; i < TMPSHMSIZE; i++) {
> + g_assert_cmpuint(data[i], ==, 0x42);
> + }
> + qtest_memread(s2->qtest, (uintptr_t)s2->mem_base, data, TMPSHMSIZE);
> + for (i = 0; i < TMPSHMSIZE; i++) {
> + g_assert_cmpuint(data[i], ==, 0x42);
> + }
> +
> + /* guest 1 write, guest 2 read */
> + memset(data, 0x43, TMPSHMSIZE);
> + qtest_memwrite(s1->qtest, (uintptr_t)s1->mem_base, data, TMPSHMSIZE);
> + memset(data, 0, TMPSHMSIZE);
> + qtest_memread(s2->qtest, (uintptr_t)s2->mem_base, data, TMPSHMSIZE);
> + for (i = 0; i < TMPSHMSIZE; i++) {
> + g_assert_cmpuint(data[i], ==, 0x43);
> + }
> +
> + /* guest 2 write, guest 1 read */
> + memset(data, 0x44, TMPSHMSIZE);
> + qtest_memwrite(s2->qtest, (uintptr_t)s2->mem_base, data, TMPSHMSIZE);
> + memset(data, 0, TMPSHMSIZE);
> + qtest_memread(s1->qtest, (uintptr_t)s2->mem_base, data, TMPSHMSIZE);
> + for (i = 0; i < TMPSHMSIZE; i++) {
> + g_assert_cmpuint(data[i], ==, 0x44);
> + }
> +
> + qtest_quit(s1->qtest);
> + qtest_quit(s2->qtest);
> + g_free(data);
> +}
> +
> +typedef struct ServerThread {
> + GThread *thread;
> + IvshmemServer *server;
> + int pipe[2]; /* to handle quit */
> +} ServerThread;
> +
> +static void *server_thread(void *data)
> +{
> + ServerThread *t = data;
> + IvshmemServer *server = t->server;
> +
> + while (true) {
> + fd_set fds;
> + int maxfd, ret;
> +
> + FD_ZERO(&fds);
> + FD_SET(t->pipe[0], &fds);
> + maxfd = t->pipe[0] + 1;
> +
> + ivshmem_server_get_fds(server, &fds, &maxfd);
> +
> + ret = select(maxfd, &fds, NULL, NULL, NULL);
> +
> + if (ret < 0) {
> + if (errno == EINTR) {
> + continue;
> + }
> +
> + g_critical("select error: %s\n", strerror(errno));
> + break;
> + }
> + if (ret == 0) {
> + continue;
> + }
> +
> + if (FD_ISSET(t->pipe[0], &fds)) {
> + break;
> + }
> +
> + if (ivshmem_server_handle_fds(server, &fds, maxfd) < 0) {
> + g_critical("ivshmem_server_handle_fds() failed\n");
> + break;
> + }
> + }
> +
> + return NULL;
> +}
> +
> +static void setup_vm_with_server(IVState *s, int nvectors)
> +{
> + char *cmd = g_strdup_printf("-chardev socket,id=chr0,path=%s,nowait "
> + "-device ivshmem,size=1M,chardev=chr0,vectors=%d",
> + tmpserver, nvectors);
> +
> + setup_vm_cmd(s, cmd, true);
> +
> + g_free(cmd);
> +}
> +
> +static GThread *thread_new(const gchar *name, GThreadFunc func, gpointer data)
> +{
> + GThread *thread = NULL;
> + GError *error = NULL;
> +#ifdef HAVE_THREAD_NEW
> + thread = g_thread_try_new(name, func, data, &error);
> +#else
> + thread = g_thread_create(func, data, TRUE, &error);
> +#endif
> + g_assert_no_error(error);
> + return thread;
> +}
> +
> +static void test_ivshmem_server(void)
> +{
> + IVState state1, state2, *s1, *s2;
> + ServerThread thread;
> + IvshmemServer server;
> + int ret, vm1, vm2;
> + int nvectors = 2;
> +
> + memset(tmpshmem, 0x42, TMPSHMSIZE);
> + ret = ivshmem_server_init(&server, tmpserver, tmpshm,
> + TMPSHMSIZE, nvectors,
> + getenv("QTEST_LOG") != NULL);
> + g_assert_cmpint(ret, ==, 0);
> +
> + ret = ivshmem_server_start(&server);
> + g_assert_cmpint(ret, ==, 0);
> +
> + setup_vm_with_server(&state1, nvectors);
> + s1 = &state1;
> + setup_vm_with_server(&state2, nvectors);
> + s2 = &state2;
> +
> + g_assert_cmpuint(in_IVPosition(s1), ==, 0xffffffff);
> + g_assert_cmpuint(in_IVPosition(s2), ==, 0xffffffff);
> +
> + g_assert_cmpuint(qtest_readb(s1->qtest, (uintptr_t)s1->mem_base), ==, 0x00);
> +
> + thread.server = &server;
> + ret = pipe(thread.pipe);
> + g_assert_cmpint(ret, ==, 0);
> + thread.thread = thread_new("ivshmem-server", server_thread, &thread);
> +
> + /* waiting until mapping is done */
> + while (true) {
> + g_usleep(1000);
> +
> + if (qtest_readb(s1->qtest, (uintptr_t)s1->mem_base) == 0x42 &&
> + qtest_readb(s2->qtest, (uintptr_t)s2->mem_base) == 0x42) {
> + break;
> + }
> + }
> +
> + /* check got different VM ids */
> + vm1 = in_IVPosition(s1);
> + vm2 = in_IVPosition(s2);
> + g_assert_cmpuint(vm1, !=, vm2);
> +
> + global_qtest = s1->qtest;
> + ret = qpci_msix_table_size(s1->dev);
> + g_assert_cmpuint(ret, ==, nvectors);
> +
> + /* ping vm2 -> vm1 */
> + ret = qpci_msix_pending(s1->dev, 0);
> + g_assert_cmpuint(ret, ==, 0);
> + out_DoorBell(s2, vm1 << 16);
> + g_usleep(10000);
> + ret = qpci_msix_pending(s1->dev, 0);
> + g_assert_cmpuint(ret, !=, 0);
> +
> + /* ping vm1 -> vm2 */
> + global_qtest = s2->qtest;
> + ret = qpci_msix_pending(s2->dev, 0);
> + g_assert_cmpuint(ret, ==, 0);
> + out_DoorBell(s1, vm2 << 16);
> + g_usleep(10000);
> + ret = qpci_msix_pending(s2->dev, 0);
> + g_assert_cmpuint(ret, !=, 0);
> +
> + /* remove vm2 */
> + qtest_quit(s2->qtest);
> + /* XXX wait enough time for vm1 to be notified */
> + g_usleep(1000);
> +
> + qtest_quit(s1->qtest);
> +
> + write(thread.pipe[1], "q", 1);
> + g_thread_join(thread.thread);
> +
> + ivshmem_server_close(&server);
> + close(thread.pipe[1]);
> + close(thread.pipe[0]);
> +}
> +
> +#define PCI_SLOT_HP 0x06
> +
> +static void test_ivshmem_hotplug(void)
> +{
> + gchar *opts;
> +
> + qtest_start("");
> +
> + opts = g_strdup_printf("'shm': '%s', 'size': '1M'", tmpshm);
> +
> + qpci_plug_device_test("ivshmem", "iv1", PCI_SLOT_HP, opts);
> + qpci_unplug_acpi_device_test("iv1", PCI_SLOT_HP);
> +
> + qtest_end();
> + g_free(opts);
> +}
> +
> +static void cleanup(void)
> +{
> + if (tmpshmem) {
> + munmap(tmpshmem, TMPSHMSIZE);
> + tmpshmem = NULL;
> + }
> +
> + if (tmpshm) {
> + shm_unlink(tmpshm);
> + g_free(tmpshm);
> + tmpshm = NULL;
> + }
> +
> + if (tmpserver) {
> + g_unlink(tmpserver);
> + g_free(tmpserver);
> + tmpserver = NULL;
> + }
> +
> + if (tmpdir) {
> + g_rmdir(tmpdir);
> + tmpdir = NULL;
> + }
> +}
> +
> +static void abrt_handler(void *data)
> +{
> + cleanup();
> +}
> +
> +static gchar *mktempshm(int size, int *fd)
> +{
> + while (true) {
> + gchar *name;
> +
> + name = g_strdup_printf("/qtest-%u-%u", getpid(), g_random_int());
> + *fd = shm_open(name, O_CREAT|O_RDWR|O_EXCL,
> + S_IRWXU|S_IRWXG|S_IRWXO);
> + if (*fd > 0) {
> + g_assert(ftruncate(*fd, size) == 0);
> + return name;
> + }
> +
> + g_free(name);
> + }
> +}
> +
> +int main(int argc, char **argv)
> +{
> + int ret, fd;
> + static gchar dir[] = "/tmp/ivshmem-test.XXXXXX";
> +
> +#if !GLIB_CHECK_VERSION(2, 31, 0)
> + if (!g_thread_supported()) {
> + g_thread_init(NULL);
> + }
> +#endif
> +
> + g_test_init(&argc, &argv, NULL);
> +
> + qtest_add_abrt_handler(abrt_handler, NULL);
> + /* shm */
> + tmpshm = mktempshm(TMPSHMSIZE, &fd);
> + tmpshmem = mmap(0, TMPSHMSIZE, PROT_READ|PROT_WRITE, MAP_SHARED, fd, 0);
> + g_assert(tmpshmem != MAP_FAILED);
> + /* server */
> + if (g_mkdtemp_full(dir, 0700) == NULL) {
> + g_error("g_mkdtemp_full: %s", g_strerror(errno));
> + }
> + tmpdir = dir;
> + tmpserver = g_strconcat(tmpdir, "/server", NULL);
> +
> + qtest_add_func("/ivshmem/single", test_ivshmem_single);
> + qtest_add_func("/ivshmem/pair", test_ivshmem_pair);
> + qtest_add_func("/ivshmem/server", test_ivshmem_server);
> + qtest_add_func("/ivshmem/hotplug", test_ivshmem_hotplug);
> +
> + ret = g_test_run();
> +
> + cleanup();
> + return ret;
> +}
>
next prev parent reply other threads:[~2015-09-22 14:45 UTC|newest]
Thread overview: 109+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-09-15 16:07 [Qemu-devel] [PATCH v3 00/46] ivshmem improvements (please review) marcandre.lureau
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 01/46] char: add qemu_chr_free() marcandre.lureau
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 02/46] msix: add VMSTATE_MSIX_TEST marcandre.lureau
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 03/46] ivhsmem: read do not accept more than sizeof(long) marcandre.lureau
2015-09-16 9:27 ` Claudio Fontana
2015-09-16 9:33 ` Marc-André Lureau
2015-09-16 11:27 ` Claudio Fontana
2015-09-16 12:03 ` Marc-André Lureau
2015-09-16 12:51 ` Paolo Bonzini
2015-09-16 13:05 ` Claudio Fontana
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 04/46] ivshmem: fix number of bytes to push to fifo marcandre.lureau
2015-09-16 9:28 ` Claudio Fontana
2015-09-23 10:17 ` Marc-André Lureau
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 05/46] ivshmem: factor out the incoming fifo handling marcandre.lureau
2015-09-22 14:01 ` Claudio Fontana
2015-09-23 10:18 ` Marc-André Lureau
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 06/46] ivshmem: remove unnecessary dup() marcandre.lureau
2015-09-22 14:06 ` Claudio Fontana
2015-09-22 15:29 ` Marc-André Lureau
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 07/46] ivshmem: remove superflous ivshmem_attr field marcandre.lureau
2015-09-16 9:25 ` Claudio Fontana
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 08/46] ivshmem: remove useless doorbell field marcandre.lureau
2015-09-22 13:50 ` Claudio Fontana
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 09/46] ivshmem: more qdev conversion marcandre.lureau
2015-09-22 14:00 ` Claudio Fontana
2015-09-23 10:22 ` Marc-André Lureau
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 10/46] ivshmem: remove last exit(1) marcandre.lureau
2015-09-22 13:55 ` Claudio Fontana
2015-09-22 13:58 ` Claudio Fontana
2015-09-22 14:00 ` Marc-André Lureau
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 11/46] ivshmem: limit maximum number of peers to G_MAXUINT16 marcandre.lureau
2015-09-22 14:09 ` Claudio Fontana
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 12/46] ivshmem: simplify around increase_dynamic_storage() marcandre.lureau
2015-09-22 14:10 ` Claudio Fontana
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 13/46] ivshmem: allocate eventfds in resize_peers() marcandre.lureau
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 14/46] ivshmem: remove useless ivshmem_update_irq() val argument marcandre.lureau
2015-09-22 14:13 ` Claudio Fontana
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 15/46] ivshmem: initialize max_peer to -1 marcandre.lureau
2015-09-22 14:13 ` Claudio Fontana
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 16/46] ivshmem: remove max_peer field marcandre.lureau
2015-09-16 9:39 ` Claudio Fontana
2015-09-16 9:40 ` Marc-André Lureau
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 17/46] ivshmem: improve debug messages marcandre.lureau
2015-09-22 14:23 ` Claudio Fontana
2015-09-23 10:29 ` Marc-André Lureau
2015-09-23 12:10 ` Claudio Fontana
2015-09-23 15:45 ` Marc-André Lureau
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 18/46] ivshmem: improve error marcandre.lureau
2015-09-22 14:26 ` Claudio Fontana
2015-09-23 10:30 ` Marc-André Lureau
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 19/46] ivshmem: print error on invalid peer id marcandre.lureau
2015-09-22 14:27 ` Claudio Fontana
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 20/46] ivshmem: simplify a bit the code marcandre.lureau
2015-09-22 14:32 ` Claudio Fontana
2015-09-22 14:56 ` Marc-André Lureau
2015-09-23 12:18 ` Claudio Fontana
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 21/46] ivshmem: use common return marcandre.lureau
2015-09-16 11:30 ` Claudio Fontana
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 22/46] ivshmem: use common is_power_of_2() marcandre.lureau
2015-09-16 11:31 ` Claudio Fontana
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 23/46] ivshmem: migrate with VMStateDescription marcandre.lureau
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 24/46] ivshmem: shmfd can be 0 marcandre.lureau
2015-09-16 11:33 ` Claudio Fontana
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 25/46] ivshmem: check shm isn't already initialized marcandre.lureau
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 26/46] ivshmem: add device description marcandre.lureau
2015-09-16 11:38 ` Claudio Fontana
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 27/46] ivshmem: fix pci_ivshmem_exit() marcandre.lureau
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 28/46] ivshmem: replace 'guest' for 'peer' appropriately marcandre.lureau
2015-09-16 11:44 ` Claudio Fontana
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 29/46] ivshmem: error on too many eventfd received marcandre.lureau
2015-09-16 12:14 ` Claudio Fontana
2015-09-23 10:47 ` Marc-André Lureau
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 30/46] ivshmem: reset mask on device reset marcandre.lureau
2015-09-16 12:15 ` Claudio Fontana
2015-09-23 10:48 ` Marc-André Lureau
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 31/46] contrib: add ivshmem client and server marcandre.lureau
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 32/46] ivshmem-client: check the number of vectors marcandre.lureau
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 33/46] ivshmem-server: use a uint16 for client ID marcandre.lureau
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 34/46] ivshmem-server: fix hugetlbfs support marcandre.lureau
2015-09-16 16:07 ` Vladimir Sementsov-Ogievskiy
2015-09-16 16:14 ` Marc-André Lureau
2015-09-17 8:52 ` Vladimir Sementsov-Ogievskiy
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 35/46] docs: update ivshmem device spec marcandre.lureau
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 36/46] ivshmem: add check on protocol version in QEMU marcandre.lureau
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 37/46] contrib: remove unnecessary strdup() marcandre.lureau
2015-09-17 9:01 ` Vladimir Sementsov-Ogievskiy
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 38/46] msix: implement pba write (but read-only) marcandre.lureau
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 39/46] qtest: add qtest_add_abrt_handler() marcandre.lureau
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 40/46] tests: add ivshmem qtest marcandre.lureau
2015-09-22 14:44 ` Claudio Fontana [this message]
2015-09-23 11:24 ` Marc-André Lureau
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 41/46] ivshmem: do not keep shm_fd open marcandre.lureau
2015-09-22 14:36 ` Claudio Fontana
2015-09-22 14:59 ` Marc-André Lureau
2015-09-23 12:20 ` Claudio Fontana
2015-09-15 16:07 ` [Qemu-devel] [PATCH v3 42/46] ivshmem: make ivshmem_get_size() more generic marcandre.lureau
2015-09-16 15:23 ` Vladimir Sementsov-Ogievskiy
2015-09-16 15:24 ` Vladimir Sementsov-Ogievskiy
2015-09-16 15:26 ` Marc-André Lureau
2015-09-15 16:08 ` [Qemu-devel] [PATCH v3 43/46] ivshmem: add hostmem backend marcandre.lureau
2015-09-22 14:49 ` Claudio Fontana
2015-09-15 16:08 ` [Qemu-devel] [PATCH v3 44/46] ivshmem: remove EventfdEntry.vector marcandre.lureau
2015-09-22 14:59 ` Claudio Fontana
2015-09-22 15:18 ` Marc-André Lureau
2015-09-15 16:08 ` [Qemu-devel] [PATCH v3 45/46] ivshmem: rename MSI eventfd_table marcandre.lureau
2015-09-15 16:08 ` [Qemu-devel] [PATCH v3 46/46] ivshmem: use kvm irqfd for msi notifications marcandre.lureau
2015-09-16 12:47 ` [Qemu-devel] [PATCH v3 00/46] ivshmem improvements (please review) Claudio Fontana
2015-09-16 16:52 ` Vladimir Sementsov-Ogievskiy
2015-09-16 20:34 ` Marc-André Lureau
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=56016964.6070900@huawei.com \
--to=claudio.fontana@huawei.com \
--cc=afaerber@suse.de \
--cc=cam@cs.ualberta.ca \
--cc=drjones@redhat.com \
--cc=marcandre.lureau@redhat.com \
--cc=qemu-devel@nongnu.org \
--cc=stefanha@redhat.com \
/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).