diff options
author | Peter Maydell <peter.maydell@linaro.org> | 2020-12-09 20:08:54 +0000 |
---|---|---|
committer | Peter Maydell <peter.maydell@linaro.org> | 2020-12-09 20:08:54 +0000 |
commit | 5e7b204dbfae9a562fc73684986f936b97f63877 (patch) | |
tree | 6cbdd59e56f5b9342c8252deed085f21485ac0fb /contrib/libvhost-user/libvhost-user-glib.c | |
parent | 28db503fd7a750861aa4381653800d4eb28b5426 (diff) | |
parent | fdfa3b1d6f9edd97c807df496a0d8e9ea49240da (diff) |
Merge remote-tracking branch 'remotes/mst/tags/for_upstream' into staging
pc,pci,virtio: fixes, cleanups
Lots of fixes, cleanups.
CPU hot-unplug improvements.
A new AER property for virtio devices, adding a dummy AER capability.
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
# gpg: Signature made Wed 09 Dec 2020 18:04:28 GMT
# gpg: using RSA key 5D09FD0871C8F85B94CA8A0D281F0DB8D28D5469
# gpg: issuer "mst@redhat.com"
# gpg: Good signature from "Michael S. Tsirkin <mst@kernel.org>" [full]
# gpg: aka "Michael S. Tsirkin <mst@redhat.com>" [full]
# Primary key fingerprint: 0270 606B 6F3C DF3D 0B17 0970 C350 3912 AFBE 8E67
# Subkey fingerprint: 5D09 FD08 71C8 F85B 94CA 8A0D 281F 0DB8 D28D 5469
* remotes/mst/tags/for_upstream: (65 commits)
hw/virtio-pci Added AER capability.
hw/virtio-pci Added counter for pcie capabilities offsets.
pcie_aer: Fix help message of pcie_aer_inject_error command
x86: ich9: let firmware negotiate 'CPU hot-unplug with SMI' feature
x86: ich9: factor out "guest_cpu_hotplug_features"
tests/acpi: update expected files
x86: acpi: let the firmware handle pending "CPU remove" events in SMM
tests/acpi: allow expected files change
x86: acpi: introduce AcpiPmInfo::smi_on_cpu_unplug
acpi: cpuhp: introduce 'firmware performs eject' status/control bits
hw/i386/pc: add max combined fw size as machine configuration option
block/export: avoid g_return_val_if() input validation
contrib/vhost-user-input: avoid g_return_val_if() input validation
contrib/vhost-user-gpu: avoid g_return_val_if() input validation
contrib/vhost-user-blk: avoid g_return_val_if() input validation
.gitlab-ci: add build-libvhost-user
libvhost-user: add a simple link test without glib
libvhost-user: make it a meson subproject
libvhost-user: drop qemu/osdep.h dependency
libvhost-user: remove qemu/compiler.h usage
...
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
Diffstat (limited to 'contrib/libvhost-user/libvhost-user-glib.c')
-rw-r--r-- | contrib/libvhost-user/libvhost-user-glib.c | 170 |
1 files changed, 0 insertions, 170 deletions
diff --git a/contrib/libvhost-user/libvhost-user-glib.c b/contrib/libvhost-user/libvhost-user-glib.c deleted file mode 100644 index 0df2ec9271..0000000000 --- a/contrib/libvhost-user/libvhost-user-glib.c +++ /dev/null @@ -1,170 +0,0 @@ -/* - * Vhost User library - * - * Copyright (c) 2016 Nutanix Inc. All rights reserved. - * Copyright (c) 2017 Red Hat, Inc. - * - * Authors: - * Marc-André Lureau <mlureau@redhat.com> - * Felipe Franciosi <felipe@nutanix.com> - * - * 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 "qemu/osdep.h" - -#include "libvhost-user-glib.h" - -/* glib event loop integration for libvhost-user and misc callbacks */ - -G_STATIC_ASSERT((int)G_IO_IN == (int)VU_WATCH_IN); -G_STATIC_ASSERT((int)G_IO_OUT == (int)VU_WATCH_OUT); -G_STATIC_ASSERT((int)G_IO_PRI == (int)VU_WATCH_PRI); -G_STATIC_ASSERT((int)G_IO_ERR == (int)VU_WATCH_ERR); -G_STATIC_ASSERT((int)G_IO_HUP == (int)VU_WATCH_HUP); - -typedef struct VugSrc { - GSource parent; - VuDev *dev; - GPollFD gfd; -} VugSrc; - -static gboolean -vug_src_prepare(GSource *gsrc, gint *timeout) -{ - g_assert(timeout); - - *timeout = -1; - return FALSE; -} - -static gboolean -vug_src_check(GSource *gsrc) -{ - VugSrc *src = (VugSrc *)gsrc; - - g_assert(src); - - return src->gfd.revents & src->gfd.events; -} - -static gboolean -vug_src_dispatch(GSource *gsrc, GSourceFunc cb, gpointer data) -{ - VugSrc *src = (VugSrc *)gsrc; - - g_assert(src); - - ((vu_watch_cb)cb)(src->dev, src->gfd.revents, data); - - return G_SOURCE_CONTINUE; -} - -static GSourceFuncs vug_src_funcs = { - vug_src_prepare, - vug_src_check, - vug_src_dispatch, - NULL -}; - -GSource * -vug_source_new(VugDev *gdev, int fd, GIOCondition cond, - vu_watch_cb vu_cb, gpointer data) -{ - VuDev *dev = &gdev->parent; - GSource *gsrc; - VugSrc *src; - guint id; - - g_assert(gdev); - g_assert(fd >= 0); - g_assert(vu_cb); - - gsrc = g_source_new(&vug_src_funcs, sizeof(VugSrc)); - g_source_set_callback(gsrc, (GSourceFunc)vu_cb, data, NULL); - src = (VugSrc *)gsrc; - src->dev = dev; - src->gfd.fd = fd; - src->gfd.events = cond; - - g_source_add_poll(gsrc, &src->gfd); - id = g_source_attach(gsrc, g_main_context_get_thread_default()); - g_assert(id); - - return gsrc; -} - -static void -set_watch(VuDev *vu_dev, int fd, int vu_evt, vu_watch_cb cb, void *pvt) -{ - GSource *src; - VugDev *dev; - - g_assert(vu_dev); - g_assert(fd >= 0); - g_assert(cb); - - dev = container_of(vu_dev, VugDev, parent); - src = vug_source_new(dev, fd, vu_evt, cb, pvt); - g_hash_table_replace(dev->fdmap, GINT_TO_POINTER(fd), src); -} - -static void -remove_watch(VuDev *vu_dev, int fd) -{ - VugDev *dev; - - g_assert(vu_dev); - g_assert(fd >= 0); - - dev = container_of(vu_dev, VugDev, parent); - g_hash_table_remove(dev->fdmap, GINT_TO_POINTER(fd)); -} - - -static void vug_watch(VuDev *dev, int condition, void *data) -{ - if (!vu_dispatch(dev) != 0) { - dev->panic(dev, "Error processing vhost message"); - } -} - -void vug_source_destroy(GSource *src) -{ - if (!src) { - return; - } - - g_source_destroy(src); - g_source_unref(src); -} - -bool -vug_init(VugDev *dev, uint16_t max_queues, int socket, - vu_panic_cb panic, const VuDevIface *iface) -{ - g_assert(dev); - g_assert(iface); - - if (!vu_init(&dev->parent, max_queues, socket, panic, NULL, set_watch, - remove_watch, iface)) { - return false; - } - - dev->fdmap = g_hash_table_new_full(NULL, NULL, NULL, - (GDestroyNotify) vug_source_destroy); - - dev->src = vug_source_new(dev, socket, G_IO_IN, vug_watch, NULL); - - return true; -} - -void -vug_deinit(VugDev *dev) -{ - g_assert(dev); - - g_hash_table_unref(dev->fdmap); - vug_source_destroy(dev->src); -} |