staging: comedi: drivers: fix possible bug in comedi_handle_events()
authorH Hartley Sweeten <hsweeten@visionengravers.com>
Wed, 30 Mar 2016 17:47:25 +0000 (10:47 -0700)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 31 Mar 2016 04:04:53 +0000 (21:04 -0700)
This function assumes that the async subdevice has a cancel() function.
It looks like all the current comedi drivers implement a cancel() for
the async subdevices except for the dt2814 analog input usbdevice.

Fix comedi_handle_events() so it does not try to call a non-existent
cancel() function.

Add a dev_warn() to __comedi_device_postconfig_async() so that any new
driver authors will be reminded to implement the cancel().

Signed-off-by: H Hartley Sweeten <hsweeten@visionengravers.com>
Reviewed-by: Ian Abbott <abbotti@mev.co.uk>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/staging/comedi/drivers.c

index e3bbc8f724ba5fa768e01c8421f8daf241c94692..44511d7294505f241b7dc2c368efe1965f159a19 100644 (file)
@@ -564,7 +564,7 @@ unsigned int comedi_handle_events(struct comedi_device *dev,
        if (events == 0)
                return events;
 
-       if (events & COMEDI_CB_CANCEL_MASK)
+       if ((events & COMEDI_CB_CANCEL_MASK) && s->cancel)
                s->cancel(dev, s);
 
        comedi_event(dev, s);
@@ -625,6 +625,9 @@ static int __comedi_device_postconfig_async(struct comedi_device *dev,
                         "async subdevices must have a do_cmdtest() function\n");
                return -EINVAL;
        }
+       if (!s->cancel)
+               dev_warn(dev->class_dev,
+                        "async subdevices should have a cancel() function\n");
 
        async = kzalloc(sizeof(*async), GFP_KERNEL);
        if (!async)