qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
From: Paolo Bonzini <pbonzini@redhat.com>
To: Vincenzo Maffione <v.maffione@gmail.com>
Cc: peter.maydell@linaro.org, aliguori@us.ibm.com,
	ehabkost@redhat.com, gleb@redhat.com, qemu-devel@nongnu.org,
	Alex Williamson <alex.williamson@redhat.com>,
	Giuseppe Lettieri <g.lettieri@iet.unipi.it>,
	Luigi Rizzo <rizzo@iet.unipi.it>,
	afaerber@suse.de
Subject: Re: [Qemu-devel] [PATCH] kvm: add KVM_IRQFD_FLAG_RESAMPLE support
Date: Mon, 22 Jul 2013 16:56:56 +0200	[thread overview]
Message-ID: <51ED4838.4010506@redhat.com> (raw)
In-Reply-To: <CA+_eA9i5_JFvNNe9vd8AB=TUx7xpMNjJpdmx-FMhJV+WhJekaQ@mail.gmail.com>

Il 22/07/2013 16:18, Vincenzo Maffione ha scritto:
> Actually our research group (at University of Pisa) is working on some
> paravirtualization extensions of the e1000 NIC emulation that needs
> KVM_IRQFD_FLAG_RESAMPLE support. This is one of the reasons why I'm
> proposing this patch.
> 
> Do you suggest modifying vfio_enable_intx_kvm() to take advantage of
> the patch? I haven't addressed vfio only because I wasn't sure I am
> "permitted" to do that.

If you have a patch to do that, I guess it's welcome. :)

Otherwise, this patch makes sense from the point of view of supporting
the KVM API in a more complete manner.

Paolo

> 
> 
> Thanks,
>   Vincenzo
> 
> 2013/7/22 Alex Williamson <alex.williamson@redhat.com>:
>>
>> On Mon, 2013-07-22 at 12:43 +0200, Vincenzo Maffione wrote:
>>> From e59e35380380c2986cd0164f11dcd8a07a8e4e59 Mon Sep 17 00:00:00 2001
>>> From: Vincenzo Maffione <v.maffione@gmail.com>
>>> Date: Mon, 22 Jul 2013 11:51:33 +0200
>>> Subject: [PATCH] kvm: add KVM_IRQFD_FLAG_RESAMPLE support
>>>
>>> Added an EventNotifier* parameter to
>>> kvm-all.c:kvm_irqchip_add_irqfd_notifier(), in order to give KVM
>>> another eventfd to be used as "resamplefd". See the documentation
>>> in the linux kernel sources in Documentation/virtual/kvm/api.txt
>>> (section 4.75) for more details.
>>> When the added parameter is passed NULL, the behaviour of the
>>> function is unchanged with respect to the previous versions.
>>>
>>> Signed-off-by: Vincenzo Maffione <v.maffione@gmail.com>
>>> ---
>>>  hw/misc/vfio.c         |  4 ++--
>>>  hw/virtio/virtio-pci.c |  2 +-
>>>  include/sysemu/kvm.h   |  3 ++-
>>>  kvm-all.c              | 17 +++++++++++++----
>>>  4 files changed, 18 insertions(+), 8 deletions(-)
>>>
>>> diff --git a/hw/misc/vfio.c b/hw/misc/vfio.c
>>> index ad8ce77..54af34a 100644
>>> --- a/hw/misc/vfio.c
>>> +++ b/hw/misc/vfio.c
>>> @@ -646,7 +646,7 @@ static int vfio_msix_vector_do_use(PCIDevice
>>> *pdev, unsigned int nr,
>>>      vector->virq = msg ? kvm_irqchip_add_msi_route(kvm_state, *msg) : -1;
>>>      if (vector->virq < 0 ||
>>>          kvm_irqchip_add_irqfd_notifier(kvm_state, &vector->interrupt,
>>> -                                       vector->virq) < 0) {
>>> +                                       NULL, vector->virq) < 0) {
>>>          if (vector->virq >= 0) {
>>>              kvm_irqchip_release_virq(kvm_state, vector->virq);
>>>              vector->virq = -1;
>>> @@ -814,7 +814,7 @@ retry:
>>>          vector->virq = kvm_irqchip_add_msi_route(kvm_state, msg);
>>>          if (vector->virq < 0 ||
>>>              kvm_irqchip_add_irqfd_notifier(kvm_state, &vector->interrupt,
>>> -                                           vector->virq) < 0) {
>>> +                                           NULL, vector->virq) < 0) {
>>>              qemu_set_fd_handler(event_notifier_get_fd(&vector->interrupt),
>>>                                  vfio_msi_interrupt, NULL, vector);
>>>          }
>>
>>
>> Why doesn't this address the only current user of
>> KVM_IRQFD_FLAG_RESAMPLE, vfio_enable_intx_kvm()?  Thanks,
>>
>> Alex
>>
>>
>>> diff --git a/hw/virtio/virtio-pci.c b/hw/virtio/virtio-pci.c
>>> index c38cfd1..c4db407 100644
>>> --- a/hw/virtio/virtio-pci.c
>>> +++ b/hw/virtio/virtio-pci.c
>>> @@ -508,7 +508,7 @@ static int kvm_virtio_pci_irqfd_use(VirtIOPCIProxy *proxy,
>>>      VirtQueue *vq = virtio_get_queue(proxy->vdev, queue_no);
>>>      EventNotifier *n = virtio_queue_get_guest_notifier(vq);
>>>      int ret;
>>> -    ret = kvm_irqchip_add_irqfd_notifier(kvm_state, n, irqfd->virq);
>>> +    ret = kvm_irqchip_add_irqfd_notifier(kvm_state, n, NULL, irqfd->virq);
>>>      return ret;
>>>  }
>>>
>>> diff --git a/include/sysemu/kvm.h b/include/sysemu/kvm.h
>>> index 1e08a85..9e5d78e 100644
>>> --- a/include/sysemu/kvm.h
>>> +++ b/include/sysemu/kvm.h
>>> @@ -309,7 +309,8 @@ int kvm_irqchip_add_msi_route(KVMState *s, MSIMessage msg);
>>>  int kvm_irqchip_update_msi_route(KVMState *s, int virq, MSIMessage msg);
>>>  void kvm_irqchip_release_virq(KVMState *s, int virq);
>>>
>>> -int kvm_irqchip_add_irqfd_notifier(KVMState *s, EventNotifier *n, int virq);
>>> +int kvm_irqchip_add_irqfd_notifier(KVMState *s, EventNotifier *n,
>>> +                                   EventNotifier *rn, int virq);
>>>  int kvm_irqchip_remove_irqfd_notifier(KVMState *s, EventNotifier *n, int virq);
>>>  void kvm_pc_gsi_handler(void *opaque, int n, int level);
>>>  void kvm_pc_setup_irq_routing(bool pci_enabled);
>>> diff --git a/kvm-all.c b/kvm-all.c
>>> index 232c39a..3f69b41 100644
>>> --- a/kvm-all.c
>>> +++ b/kvm-all.c
>>> @@ -1230,7 +1230,8 @@ int kvm_irqchip_update_msi_route(KVMState *s,
>>> int virq, MSIMessage msg)
>>>      return kvm_update_routing_entry(s, &kroute);
>>>  }
>>>
>>> -static int kvm_irqchip_assign_irqfd(KVMState *s, int fd, int virq, bool assign)
>>> +static int kvm_irqchip_assign_irqfd(KVMState *s, int fd, int rfd, int virq,
>>> +                                    bool assign)
>>>  {
>>>      struct kvm_irqfd irqfd = {
>>>          .fd = fd,
>>> @@ -1238,6 +1239,11 @@ static int kvm_irqchip_assign_irqfd(KVMState
>>> *s, int fd, int virq, bool assign)
>>>          .flags = assign ? 0 : KVM_IRQFD_FLAG_DEASSIGN,
>>>      };
>>>
>>> +    if (rfd != -1) {
>>> +        irqfd.flags |= KVM_IRQFD_FLAG_RESAMPLE;
>>> +        irqfd.resamplefd = rfd;
>>> +    }
>>> +
>>>      if (!kvm_irqfds_enabled()) {
>>>          return -ENOSYS;
>>>      }
>>> @@ -1276,14 +1282,17 @@ int kvm_irqchip_update_msi_route(KVMState *s,
>>> int virq, MSIMessage msg)
>>>  }
>>>  #endif /* !KVM_CAP_IRQ_ROUTING */
>>>
>>> -int kvm_irqchip_add_irqfd_notifier(KVMState *s, EventNotifier *n, int virq)
>>> +int kvm_irqchip_add_irqfd_notifier(KVMState *s, EventNotifier *n,
>>> +                                   EventNotifier *rn, int virq)
>>>  {
>>> -    return kvm_irqchip_assign_irqfd(s, event_notifier_get_fd(n), virq, true);
>>> +    return kvm_irqchip_assign_irqfd(s, event_notifier_get_fd(n),
>>> +           rn ? event_notifier_get_fd(rn) : -1, virq, true);
>>>  }
>>>
>>>  int kvm_irqchip_remove_irqfd_notifier(KVMState *s, EventNotifier *n, int virq)
>>>  {
>>> -    return kvm_irqchip_assign_irqfd(s, event_notifier_get_fd(n), virq, false);
>>> +    return kvm_irqchip_assign_irqfd(s, event_notifier_get_fd(n), -1, virq,
>>> +           false);
>>>  }
>>>
>>>  static int kvm_irqchip_create(KVMState *s)
>>> --
>>> 1.8.3.3
>>
>>
>>
>>
> 
> 
> 

  reply	other threads:[~2013-07-22 14:57 UTC|newest]

Thread overview: 5+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2013-07-22 10:43 [Qemu-devel] [PATCH] kvm: add KVM_IRQFD_FLAG_RESAMPLE support Vincenzo Maffione
2013-07-22 14:01 ` Alex Williamson
2013-07-22 14:18   ` Vincenzo Maffione
2013-07-22 14:56     ` Paolo Bonzini [this message]
2013-07-22 15:06       ` Vincenzo Maffione

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=51ED4838.4010506@redhat.com \
    --to=pbonzini@redhat.com \
    --cc=afaerber@suse.de \
    --cc=alex.williamson@redhat.com \
    --cc=aliguori@us.ibm.com \
    --cc=ehabkost@redhat.com \
    --cc=g.lettieri@iet.unipi.it \
    --cc=gleb@redhat.com \
    --cc=peter.maydell@linaro.org \
    --cc=qemu-devel@nongnu.org \
    --cc=rizzo@iet.unipi.it \
    --cc=v.maffione@gmail.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).