xen: privcmd: Add support for irqfd
authorViresh Kumar <viresh.kumar@linaro.org>
Tue, 22 Aug 2023 09:45:07 +0000 (15:15 +0530)
committerJuergen Gross <jgross@suse.com>
Tue, 22 Aug 2023 10:12:50 +0000 (12:12 +0200)
commitf8941e6c4c712948663ec5d7bbb546f1a0f4e3f6
tree5ceab4ee6c3ad064c3c17d863d5c6c60fe1b628f
parent442466e04f5f1b4616d3f023ff19166b82e19989
xen: privcmd: Add support for irqfd

Xen provides support for injecting interrupts to the guests via the
HYPERVISOR_dm_op() hypercall. The same is used by the Virtio based
device backend implementations, in an inefficient manner currently.

Generally, the Virtio backends are implemented to work with the Eventfd
based mechanism. In order to make such backends work with Xen, another
software layer needs to poll the Eventfds and raise an interrupt to the
guest using the Xen based mechanism. This results in an extra context
switch.

This is not a new problem in Linux though. It is present with other
hypervisors like KVM, etc. as well. The generic solution implemented in
the kernel for them is to provide an IOCTL call to pass the interrupt
details and eventfd, which lets the kernel take care of polling the
eventfd and raising of the interrupt, instead of handling this in user
space (which involves an extra context switch).

This patch adds support to inject a specific interrupt to guest using
the eventfd mechanism, by preventing the extra context switch.

Inspired by existing implementations for KVM, etc..

Signed-off-by: Viresh Kumar <viresh.kumar@linaro.org>
Reviewed-by: Juergen Gross <jgross@suse.com>
Link: https://lore.kernel.org/r/8e724ac1f50c2bc1eb8da9b3ff6166f1372570aa.1692697321.git.viresh.kumar@linaro.org
Signed-off-by: Juergen Gross <jgross@suse.com>
drivers/xen/Kconfig
drivers/xen/privcmd.c
include/uapi/xen/privcmd.h