]> Git Repo - qemu.git/commitdiff
s390x/css: start with cleared cstat/dstat
authorCornelia Huck <[email protected]>
Fri, 24 Jul 2015 10:08:37 +0000 (12:08 +0200)
committerCornelia Huck <[email protected]>
Mon, 7 Sep 2015 14:10:43 +0000 (16:10 +0200)
When executing the start function, we should start with a clear state
regarding subchannel and device status; it is easy to forget updating one
of them after the ccw has been processed.

Note that we don't need to care about resetting the various control
fields: They are cleared by tsch(), and if they were still pending,
we wouldn't be able to execute the start function in the first
place.

Also note that we don't want to clear cstat/dstat if a suspended
subchannel is resumed.

This fixes a bug where we would continue to present channel-program
check in cstat even though later ccw requests for the subchannel
finished without error (i.e. cstat should be 0).

Cc: [email protected]
Signed-off-by: Cornelia Huck <[email protected]>
Reviewed-by: David Hildenbrand <[email protected]>
hw/s390x/css.c

index 95962808de606a6424a782959fa9ecc3113cfb35..c033612889ca3a20534ae354333c225cb5db7fed 100644 (file)
@@ -399,6 +399,8 @@ static void sch_handle_start_func(SubchDev *sch, ORB *orb)
     path = 0x80;
 
     if (!(s->ctrl & SCSW_ACTL_SUSP)) {
+        s->cstat = 0;
+        s->dstat = 0;
         /* Look at the orb and try to execute the channel program. */
         assert(orb != NULL); /* resume does not pass an orb */
         p->intparm = orb->intparm;
This page took 0.024378 seconds and 4 git commands to generate.