On 31.08.2017 14:18, Halil Pasic wrote: > The function ioinst_handle_xsch is presenting cc 2 when it's supposed to > present cc 1 and the other way around, because css_do_xsch has the error > codes mixed up. Because cc 1 has precedence over cc 2 we also have to > swap the two checks. > > Let us fix this. > > Signed-off-by: Halil Pasic <pa...@linux.vnet.ibm.com> > Reported-by: Pierre Morel <pmo...@linux.vnet.ibm.com> > --- > > Was previously a part of a series (due to an accident the > series had no name). This version also fixes the priority > (aka precedence) problem. > > --- > hw/s390x/css.c | 10 +++++----- > 1 file changed, 5 insertions(+), 5 deletions(-) > > diff --git a/hw/s390x/css.c b/hw/s390x/css.c > index 1880b1a0ff..e04e0ea3a8 100644 > --- a/hw/s390x/css.c > +++ b/hw/s390x/css.c > @@ -1276,16 +1276,16 @@ int css_do_xsch(SubchDev *sch) > goto out; > } > > + if (s->ctrl & SCSW_CTRL_MASK_STCTL) { > + ret = -EINPROGRESS; > + goto out; > + } > + > if (!(s->ctrl & SCSW_CTRL_MASK_FCTL) || > ((s->ctrl & SCSW_CTRL_MASK_FCTL) != SCSW_FCTL_START_FUNC) || > (!(s->ctrl & > (SCSW_ACTL_RESUME_PEND | SCSW_ACTL_START_PEND | SCSW_ACTL_SUSP))) > || > (s->ctrl & SCSW_ACTL_SUBCH_ACTIVE)) { > - ret = -EINPROGRESS; > - goto out; > - } > - > - if (s->ctrl & SCSW_CTRL_MASK_STCTL) { > ret = -EBUSY; > goto out; > } >
Reviewed-by: Thomas Huth <th...@redhat.com>