vfio/ccw: remove WARN_ON during shutdown
authorEric Farman <farman@linux.ibm.com>
Fri, 10 Feb 2023 17:42:27 +0000 (18:42 +0100)
committerHeiko Carstens <hca@linux.ibm.com>
Tue, 14 Feb 2023 10:45:40 +0000 (11:45 +0100)
The logic in vfio_ccw_sch_shutdown() always assumed that the input
subchannel would point to a vfio_ccw_private struct, without checking
that one exists. The blamed commit put in a check for this scenario,
to prevent the possibility of a missing private.

The trouble is that check was put alongside a WARN_ON(), presuming
that such a scenario would be a cause for concern. But this can be
triggered by binding a subchannel to vfio-ccw, and rebooting the
system before starting the mdev (via "mdevctl start" or similar)
or after stopping it. In those cases, shutdown doesn't need to
worry because either the private was never allocated, or it was
cleaned up by vfio_ccw_mdev_remove().

Remove the WARN_ON() piece of this check, since there are plausible
scenarios where private would be NULL in this path.

Fixes: 9e6f07cd1eaa ("vfio/ccw: create a parent struct")
Signed-off-by: Eric Farman <farman@linux.ibm.com>
Reviewed-by: Matthew Rosato <mjrosato@linux.ibm.com>
Link: https://lore.kernel.org/r/20230210174227.2256424-1-farman@linux.ibm.com
Signed-off-by: Heiko Carstens <hca@linux.ibm.com>
drivers/s390/cio/vfio_ccw_drv.c

index 54aba7cceb33f98bc80c3f09bb7bceb95f2b8cdf..ff538a086fc77e62f96b97b9811ec7bd71322565 100644 (file)
@@ -225,7 +225,7 @@ static void vfio_ccw_sch_shutdown(struct subchannel *sch)
        struct vfio_ccw_parent *parent = dev_get_drvdata(&sch->dev);
        struct vfio_ccw_private *private = dev_get_drvdata(&parent->dev);
 
-       if (WARN_ON(!private))
+       if (!private)
                return;
 
        vfio_ccw_fsm_event(private, VFIO_CCW_EVENT_CLOSE);