From: Cornelia Huck <cohuck@redhat.com>
To: Eric Farman <farman@linux.ibm.com>
Cc: Halil Pasic <pasic@linux.ibm.com>,
Jason Herne <jjherne@linux.ibm.com>,
Jared Rossi <jrossi@linux.ibm.com>,
linux-s390@vger.kernel.org, kvm@vger.kernel.org
Subject: Re: [RFC PATCH v2 7/9] vfio-ccw: Wire up the CRW irq and CRW region
Date: Mon, 6 Apr 2020 15:52:55 +0200 [thread overview]
Message-ID: <20200406155255.3c8f06e5.cohuck@redhat.com> (raw)
In-Reply-To: <20200206213825.11444-8-farman@linux.ibm.com>
On Thu, 6 Feb 2020 22:38:23 +0100
Eric Farman <farman@linux.ibm.com> wrote:
> From: Farhan Ali <alifm@linux.ibm.com>
>
> Use an IRQ to notify userspace that there is a CRW
> pending in the region, related to path-availability
> changes on the passthrough subchannel.
>
> Signed-off-by: Farhan Ali <alifm@linux.ibm.com>
> Signed-off-by: Eric Farman <farman@linux.ibm.com>
> ---
>
> Notes:
> v1->v2:
> - Remove extraneous 0x0 in crw.rsid assignment [CH]
> - Refactor the building/queueing of a crw into its own routine [EF]
>
> v0->v1: [EF]
> - Place the non-refactoring changes from the previous patch here
> - Clean up checkpatch (whitespace) errors
> - s/chp_crw/crw/
> - Move acquire/release of io_mutex in vfio_ccw_crw_region_read()
> into patch that introduces that region
> - Remove duplicate include from vfio_ccw_drv.c
> - Reorder include in vfio_ccw_private.h
>
> drivers/s390/cio/vfio_ccw_chp.c | 5 ++
> drivers/s390/cio/vfio_ccw_drv.c | 73 +++++++++++++++++++++++++++++
> drivers/s390/cio/vfio_ccw_ops.c | 4 ++
> drivers/s390/cio/vfio_ccw_private.h | 9 ++++
> include/uapi/linux/vfio.h | 1 +
> 5 files changed, 92 insertions(+)
[I may have gotten all muddled up from staring at this, but please bear
with me...]
> diff --git a/drivers/s390/cio/vfio_ccw_chp.c b/drivers/s390/cio/vfio_ccw_chp.c
> index 8fde94552149..328b4e1d1972 100644
> --- a/drivers/s390/cio/vfio_ccw_chp.c
> +++ b/drivers/s390/cio/vfio_ccw_chp.c
> @@ -98,6 +98,11 @@ static ssize_t vfio_ccw_crw_region_read(struct vfio_ccw_private *private,
> ret = count;
>
> mutex_unlock(&private->io_mutex);
> +
> + /* Notify the guest if more CRWs are on our queue */
> + if (!list_empty(&private->crw) && private->crw_trigger)
> + eventfd_signal(private->crw_trigger, 1);
Here we possibly arm the eventfd again, but don't do anything regarding
queued crws and the region.
> +
> return ret;
> }
>
> diff --git a/drivers/s390/cio/vfio_ccw_drv.c b/drivers/s390/cio/vfio_ccw_drv.c
> index 1e1360af1b34..c48c260a129d 100644
> --- a/drivers/s390/cio/vfio_ccw_drv.c
> +++ b/drivers/s390/cio/vfio_ccw_drv.c
> @@ -108,6 +108,31 @@ static void vfio_ccw_sch_io_todo(struct work_struct *work)
> eventfd_signal(private->io_trigger, 1);
> }
>
> +static void vfio_ccw_crw_todo(struct work_struct *work)
> +{
> + struct vfio_ccw_private *private;
> + struct vfio_ccw_crw *crw;
> +
> + private = container_of(work, struct vfio_ccw_private, crw_work);
> +
> + /* FIXME Ugh, need better control of this list */
> + crw = list_first_entry_or_null(&private->crw,
> + struct vfio_ccw_crw, next);
> +
> + if (crw) {
> + list_del(&crw->next);
> +
> + mutex_lock(&private->io_mutex);
> + memcpy(&private->crw_region->crw0, crw->crw, sizeof(*crw->crw));
> + mutex_unlock(&private->io_mutex);
> +
> + kfree(crw);
> +
> + if (private->crw_trigger)
> + eventfd_signal(private->crw_trigger, 1);
> + }
> +}
This function copies one outstanding crw and arms the eventfd.
> +
> /*
> * Css driver callbacks
> */
(...)
> @@ -276,6 +309,44 @@ static int vfio_ccw_sch_event(struct subchannel *sch, int process)
> return rc;
> }
>
> +static void vfio_ccw_alloc_crw(struct vfio_ccw_private *private,
> + struct chp_link *link,
> + unsigned int erc)
> +{
> + struct vfio_ccw_crw *vc_crw;
> + struct crw *crw;
> +
> + /*
> + * If unable to allocate a CRW, just drop the event and
> + * carry on. The guest will either see a later one or
> + * learn when it issues its own store subchannel.
> + */
> + vc_crw = kzalloc(sizeof(*vc_crw), GFP_ATOMIC);
> + if (!vc_crw)
> + return;
> +
> + /*
> + * Build in the first CRW space, but don't chain anything
> + * into the second one even though the space exists.
> + */
> + crw = &vc_crw->crw[0];
> +
> + /*
> + * Presume every CRW we handle is reported by a channel-path.
> + * Maybe not future-proof, but good for what we're doing now.
> + *
> + * FIXME Sort of a lie, since we're converting a CRW
> + * reported by a channel-path into one issued to each
> + * subchannel, but still saying it's coming from the path.
> + */
> + crw->rsc = CRW_RSC_CPATH;
> + crw->rsid = (link->chpid.cssid << 8) | link->chpid.id;
> + crw->erc = erc;
> +
> + list_add_tail(&vc_crw->next, &private->crw);
> + queue_work(vfio_ccw_work_q, &private->crw_work);
This function allocates a new crw and queues it. After that, it
triggers the function doing the copy-to-region-and-notify stuff.
> +}
> +
> static int vfio_ccw_chp_event(struct subchannel *sch,
> struct chp_link *link, int event)
> {
> @@ -303,6 +374,7 @@ static int vfio_ccw_chp_event(struct subchannel *sch,
> case CHP_OFFLINE:
> /* Path is gone */
> cio_cancel_halt_clear(sch, &retry);
> + vfio_ccw_alloc_crw(private, link, CRW_ERC_PERRN);
> break;
> case CHP_VARY_ON:
> /* Path logically turned on */
> @@ -312,6 +384,7 @@ static int vfio_ccw_chp_event(struct subchannel *sch,
> case CHP_ONLINE:
> /* Path became available */
> sch->lpm |= mask & sch->opm;
> + vfio_ccw_alloc_crw(private, link, CRW_ERC_INIT);
> break;
> }
>
These two (path online/offline handling) are the only code paths
triggering an update to the queued crws.
Aren't we missing copying in a new queued crw after userspace had done
a read?
next prev parent reply other threads:[~2020-04-06 13:53 UTC|newest]
Thread overview: 31+ messages / expand[flat|nested] mbox.gz Atom feed top
2020-02-06 21:38 [RFC PATCH v2 0/9] s390x/vfio-ccw: Channel Path Handling Eric Farman
2020-02-06 21:38 ` [RFC PATCH v2 1/9] vfio-ccw: Introduce new helper functions to free/destroy regions Eric Farman
2020-02-06 21:38 ` [RFC PATCH v2 2/9] vfio-ccw: Register a chp_event callback for vfio-ccw Eric Farman
2020-02-14 12:11 ` Cornelia Huck
2020-02-14 16:35 ` Eric Farman
2020-03-24 15:58 ` Cornelia Huck
2020-03-26 2:09 ` Eric Farman
2020-03-26 6:47 ` Cornelia Huck
2020-03-26 11:54 ` Eric Farman
2020-02-06 21:38 ` [RFC PATCH v2 3/9] vfio-ccw: Refactor the unregister of the async regions Eric Farman
2020-02-06 21:38 ` [RFC PATCH v2 4/9] vfio-ccw: Introduce a new schib region Eric Farman
2020-02-14 12:32 ` Cornelia Huck
2020-02-14 14:29 ` Eric Farman
2020-02-06 21:38 ` [RFC PATCH v2 5/9] vfio-ccw: Introduce a new CRW region Eric Farman
2020-04-06 13:40 ` Cornelia Huck
2020-04-06 21:43 ` Eric Farman
2020-04-07 6:30 ` Cornelia Huck
2020-02-06 21:38 ` [RFC PATCH v2 6/9] vfio-ccw: Refactor IRQ handlers Eric Farman
2020-02-06 21:38 ` [RFC PATCH v2 7/9] vfio-ccw: Wire up the CRW irq and CRW region Eric Farman
2020-02-14 13:34 ` Cornelia Huck
2020-02-14 16:24 ` Eric Farman
2020-03-24 16:34 ` Cornelia Huck
2020-03-26 18:51 ` Eric Farman
2020-04-06 13:52 ` Cornelia Huck [this message]
2020-04-06 22:11 ` Eric Farman
2020-02-06 21:38 ` [RFC PATCH v2 8/9] vfio-ccw: Add trace for CRW event Eric Farman
2020-02-06 21:38 ` [RFC PATCH v2 9/9] vfio-ccw: Remove inline get_schid() routine Eric Farman
2020-02-14 13:27 ` Cornelia Huck
2020-02-14 14:27 ` Eric Farman
2020-02-07 9:12 ` [RFC PATCH v2 0/9] s390x/vfio-ccw: Channel Path Handling Cornelia Huck
2020-02-07 13:26 ` Eric Farman
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=20200406155255.3c8f06e5.cohuck@redhat.com \
--to=cohuck@redhat.com \
--cc=farman@linux.ibm.com \
--cc=jjherne@linux.ibm.com \
--cc=jrossi@linux.ibm.com \
--cc=kvm@vger.kernel.org \
--cc=linux-s390@vger.kernel.org \
--cc=pasic@linux.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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox