From: Dong Jia Shi <bjsdjshi@linux.vnet.ibm.com>
To: Alex Williamson <alex.williamson@redhat.com>
Cc: Dong Jia Shi <bjsdjshi@linux.vnet.ibm.com>,
kvm@vger.kernel.org, linux-s390@vger.kernel.org,
qemu-devel@nongnu.org, renxiaof@linux.vnet.ibm.com,
cornelia.huck@de.ibm.com, borntraeger@de.ibm.com, agraf@suse.com,
pmorel@linux.vnet.ibm.com, pasic@linux.vnet.ibm.com,
wkywang@linux.vnet.ibm.com
Subject: Re: [Qemu-devel] [PATCH RFC v3 11/15] vfio: ccw: realize VFIO_DEVICE_G(S)ET_IRQ_INFO ioctls
Date: Mon, 27 Feb 2017 09:44:57 +0800 [thread overview]
Message-ID: <20170227014457.GW562@bjsdjshi@linux.vnet.ibm.com> (raw)
In-Reply-To: <20170224162724.6dd2eb0e@t450s.home>
* Alex Williamson <alex.williamson@redhat.com> [2017-02-24 16:27:24 -0700]:
> On Fri, 17 Feb 2017 09:29:35 +0100
> Dong Jia Shi <bjsdjshi@linux.vnet.ibm.com> wrote:
>
> > Realize VFIO_DEVICE_GET_IRQ_INFO ioctl to retrieve
> > VFIO_CCW_IO_IRQ information.
> >
> > Realize VFIO_DEVICE_SET_IRQS ioctl to set an eventfd fd for
> > VFIO_CCW_IO_IRQ. Once a write operation to the ccw_io_region
> > was performed, trigger a signal on this fd.
> >
> > Signed-off-by: Dong Jia Shi <bjsdjshi@linux.vnet.ibm.com>
> > Reviewed-by: Pierre Morel <pmorel@linux.vnet.ibm.com>
> > ---
> > drivers/s390/cio/vfio_ccw_ops.c | 123 +++++++++++++++++++++++++++++++++++-
> > drivers/s390/cio/vfio_ccw_private.h | 4 ++
> > include/uapi/linux/vfio.h | 10 ++-
> > 3 files changed, 134 insertions(+), 3 deletions(-)
> >
> > diff --git a/drivers/s390/cio/vfio_ccw_ops.c b/drivers/s390/cio/vfio_ccw_ops.c
> > index 125818c..ebc38fb 100644
> > --- a/drivers/s390/cio/vfio_ccw_ops.c
> > +++ b/drivers/s390/cio/vfio_ccw_ops.c
> > @@ -202,6 +202,9 @@ static ssize_t vfio_ccw_mdev_write(struct mdev_device *mdev,
> > if (region->ret_code != 0)
> > return region->ret_code;
> >
> > + if (private->io_trigger)
> > + eventfd_signal(private->io_trigger, 1);
> > +
> > return count;
> > }
> >
> > @@ -209,7 +212,7 @@ static int vfio_ccw_mdev_get_device_info(struct vfio_device_info *info)
> > {
> > info->flags = VFIO_DEVICE_FLAGS_CCW | VFIO_DEVICE_FLAGS_RESET;
> > info->num_regions = VFIO_CCW_NUM_REGIONS;
> > - info->num_irqs = 0;
> > + info->num_irqs = VFIO_CCW_NUM_IRQS;
> >
> > return 0;
> > }
> > @@ -230,6 +233,83 @@ static int vfio_ccw_mdev_get_region_info(struct vfio_region_info *info,
> > }
> > }
> >
> > +int vfio_ccw_mdev_get_irq_info(struct vfio_irq_info *info)
> > +{
> > + if (info->index != VFIO_CCW_IO_IRQ_INDEX)
> > + return -EINVAL;
> > +
> > + info->count = 1;
> > + info->flags = VFIO_IRQ_INFO_EVENTFD | VFIO_IRQ_INFO_NORESIZE;
>
> I tend to think that NORESIZE isn't relevant when count is one. We
> don't expose this flag on vfio-pci for INTx where there's only a single
> interrupt. I don't really see how it applies, it's really trying to
> indicate if there are multiple sub-indexes within an index, if some are
> enabled, we cannot enable others without first disabling them all.
> Thus we can't resize the number of enabled sub-indexes. There really
> are no sub-indexes when count is one. Thanks,
Hi Alex,
I read the description of NORESIZE again, and I think you are right.
Since we do not have a subset of indexes here, I will remove this flag.
Thanks!
>
> Alex
>
> > +
> > + return 0;
> > +}
> > +
[...]
--
Dong Jia
next prev parent reply other threads:[~2017-02-27 1:45 UTC|newest]
Thread overview: 61+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-02-17 8:29 [PATCH RFC v3 00/15] basic vfio-ccw infrastructure Dong Jia Shi
2017-02-17 8:29 ` [Qemu-devel] " Dong Jia Shi
2017-02-17 8:29 ` [PATCH RFC v3 01/15] s390: cio: introduce cio_cancel_halt_clear Dong Jia Shi
2017-02-17 8:29 ` [Qemu-devel] " Dong Jia Shi
2017-02-17 8:29 ` [PATCH RFC v3 02/15] s390: cio: export more interfaces Dong Jia Shi
2017-02-17 8:29 ` [Qemu-devel] " Dong Jia Shi
2017-02-17 8:29 ` [PATCH RFC v3 03/15] vfio: ccw: define device_api strings Dong Jia Shi
2017-02-17 8:29 ` [Qemu-devel] " Dong Jia Shi
2017-02-17 8:29 ` [PATCH RFC v3 04/15] vfio: ccw: basic implementation for vfio_ccw driver Dong Jia Shi
2017-02-17 8:29 ` [Qemu-devel] " Dong Jia Shi
2017-02-20 18:31 ` Cornelia Huck
2017-02-20 18:31 ` [Qemu-devel] " Cornelia Huck
2017-02-21 7:36 ` Dong Jia Shi
2017-02-21 7:36 ` [Qemu-devel] " Dong Jia Shi
2017-02-21 7:43 ` Dong Jia Shi
2017-02-21 7:43 ` [Qemu-devel] " Dong Jia Shi
2017-02-21 15:43 ` Cornelia Huck
2017-02-21 15:43 ` [Qemu-devel] " Cornelia Huck
2017-02-22 3:05 ` Dong Jia Shi
2017-02-22 3:05 ` Dong Jia Shi
2017-02-17 8:29 ` [PATCH RFC v3 05/15] vfio: ccw: introduce channel program interfaces Dong Jia Shi
2017-02-17 8:29 ` [Qemu-devel] " Dong Jia Shi
2017-02-17 8:29 ` [PATCH RFC v3 06/15] vfio: ccw: register vfio_ccw to the mediated device framework Dong Jia Shi
2017-02-17 8:29 ` [Qemu-devel] " Dong Jia Shi
2017-02-17 8:29 ` [PATCH RFC v3 07/15] vfio: ccw: introduce ccw_io_region Dong Jia Shi
2017-02-17 8:29 ` [Qemu-devel] " Dong Jia Shi
2017-02-24 23:13 ` Alex Williamson
2017-02-24 23:13 ` [Qemu-devel] " Alex Williamson
2017-02-17 8:29 ` [PATCH RFC v3 08/15] vfio: ccw: handle ccw command request Dong Jia Shi
2017-02-17 8:29 ` [Qemu-devel] " Dong Jia Shi
2017-02-17 8:29 ` [PATCH RFC v3 09/15] vfio: ccw: realize VFIO_DEVICE_GET_REGION_INFO ioctl Dong Jia Shi
2017-02-17 8:29 ` [Qemu-devel] " Dong Jia Shi
2017-02-17 8:29 ` [PATCH RFC v3 10/15] vfio: ccw: realize VFIO_DEVICE_RESET ioctl Dong Jia Shi
2017-02-17 8:29 ` [Qemu-devel] " Dong Jia Shi
2017-02-17 8:29 ` [PATCH RFC v3 11/15] vfio: ccw: realize VFIO_DEVICE_G(S)ET_IRQ_INFO ioctls Dong Jia Shi
2017-02-17 8:29 ` [Qemu-devel] " Dong Jia Shi
2017-02-24 23:27 ` Alex Williamson
2017-02-24 23:27 ` [Qemu-devel] " Alex Williamson
2017-02-27 1:44 ` Dong Jia Shi
2017-02-27 1:44 ` Dong Jia Shi [this message]
2017-02-17 8:29 ` [PATCH RFC v3 12/15] vfio: ccw: return I/O results asynchronously Dong Jia Shi
2017-02-17 8:29 ` [Qemu-devel] " Dong Jia Shi
2017-02-17 8:29 ` [PATCH RFC v3 13/15] vfio: ccw: introduce a finite state machine Dong Jia Shi
2017-02-17 8:29 ` [Qemu-devel] " Dong Jia Shi
2017-02-17 8:29 ` [PATCH RFC v3 14/15] docs: add documentation for vfio-ccw Dong Jia Shi
2017-02-17 8:29 ` [Qemu-devel] " Dong Jia Shi
2017-02-17 8:29 ` [PATCH RFC v3 15/15] vfio: ccw: introduce support for ccw0 Dong Jia Shi
2017-02-17 8:29 ` [Qemu-devel] " Dong Jia Shi
2017-02-20 18:59 ` Cornelia Huck
2017-02-20 18:59 ` [Qemu-devel] " Cornelia Huck
2017-02-21 8:58 ` Dong Jia Shi
2017-02-21 8:58 ` [Qemu-devel] " Dong Jia Shi
2017-02-21 15:47 ` Cornelia Huck
2017-02-21 15:47 ` [Qemu-devel] " Cornelia Huck
2017-03-09 9:25 ` [Qemu-devel] [PATCH RFC v3 00/15] basic vfio-ccw infrastructure Dong Jia Shi
2017-03-10 10:46 ` Cornelia Huck
2017-03-10 10:46 ` [Qemu-devel] " Cornelia Huck
2017-03-13 7:16 ` Dong Jia Shi
2017-03-16 9:25 ` Cornelia Huck
2017-03-16 9:25 ` [Qemu-devel] " Cornelia Huck
2017-03-16 9:28 ` Dong Jia Shi
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=20170227014457.GW562@bjsdjshi@linux.vnet.ibm.com \
--to=bjsdjshi@linux.vnet.ibm.com \
--cc=agraf@suse.com \
--cc=alex.williamson@redhat.com \
--cc=borntraeger@de.ibm.com \
--cc=cornelia.huck@de.ibm.com \
--cc=kvm@vger.kernel.org \
--cc=linux-s390@vger.kernel.org \
--cc=pasic@linux.vnet.ibm.com \
--cc=pmorel@linux.vnet.ibm.com \
--cc=qemu-devel@nongnu.org \
--cc=renxiaof@linux.vnet.ibm.com \
--cc=wkywang@linux.vnet.ibm.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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.