[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [Qemu-devel] [PATCH 12/15] s390-bios: Refactor virtio to run channel
From: |
Cornelia Huck |
Subject: |
Re: [Qemu-devel] [PATCH 12/15] s390-bios: Refactor virtio to run channel programs via cio |
Date: |
Mon, 4 Feb 2019 12:44:16 +0100 |
On Tue, 29 Jan 2019 08:29:19 -0500
"Jason J. Herne" <address@hidden> wrote:
> Now that we have a Channel I/O library let's modify virtio boot code to
> make use of it for running channel programs.
>
> Signed-off-by: Jason J. Herne <address@hidden>
> ---
> pc-bios/s390-ccw/virtio.c | 48
> +++++++++++++++++++----------------------------
> 1 file changed, 19 insertions(+), 29 deletions(-)
>
> diff --git a/pc-bios/s390-ccw/virtio.c b/pc-bios/s390-ccw/virtio.c
> index aa9da72..f8d71ed 100644
> --- a/pc-bios/s390-ccw/virtio.c
> +++ b/pc-bios/s390-ccw/virtio.c
> @@ -89,33 +89,20 @@ int drain_irqs(SubChannelId schid)
> }
> }
>
> -static int run_ccw(VDev *vdev, int cmd, void *ptr, int len)
> +static int run_ccw(VDev *vdev, int cmd, void *ptr, int len, bool sli)
> {
> Ccw1 ccw = {};
> - CmdOrb orb = {};
> - int r;
> -
> - enable_subchannel(vdev->schid);
> -
> - /* start subchannel command */
> - orb.fmt = 1;
> - orb.cpa = (u32)(long)&ccw;
> - orb.lpm = 0x80;
>
> ccw.cmd_code = cmd;
> ccw.cda = (long)ptr;
> ccw.count = len;
>
> - r = ssch(vdev->schid, &orb);
> - /*
> - * XXX Wait until device is done processing the CCW. For now we can
> - * assume that a simple tsch will have finished the CCW processing,
> - * but the architecture allows for asynchronous operation
> - */
> - if (!r) {
> - r = drain_irqs(vdev->schid);
> + if (sli) {
> + ccw.flags |= CCW_FLAG_SLI;
> }
> - return r;
> +
> + enable_subchannel(vdev->schid);
> + return do_cio(vdev->schid, ptr2u32(&ccw), CCW_FMT1);
That still has the very odd pattern that you enable the subchannel
every time you run a channel program...
> }
>
> static void vring_init(VRing *vr, VqInfo *info)
- Re: [Qemu-devel] [PATCH 12/15] s390-bios: Refactor virtio to run channel programs via cio,
Cornelia Huck <=