staging: most: hdm-usb: provide MBO status when freeing buffers
authorChristian Gromm <christian.gromm@microchip.com>
Fri, 19 Aug 2016 09:12:46 +0000 (11:12 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Sun, 21 Aug 2016 14:53:56 +0000 (16:53 +0200)
This patch adds the additional status parameter to function
free_anchored_buffers. This allows to dispatch further processing based
on this flag.

Signed-off-by: Andrey Shvetsov <andrey.shvetsov@k2l.de>
Signed-off-by: Christian Gromm <christian.gromm@microchip.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/staging/most/hdm-usb/hdm_usb.c

index 79277ddf4e43eb81b555ad57a9aa90a11a829d82..bc2d174c5fdf0fac99b836717c6f7167590967c6 100644 (file)
@@ -190,8 +190,10 @@ static inline int drci_wr_reg(struct usb_device *dev, u16 reg, u16 data)
  * free_anchored_buffers - free device's anchored items
  * @mdev: the device
  * @channel: channel ID
+ * @status: status of MBO termination
  */
-static void free_anchored_buffers(struct most_dev *mdev, unsigned int channel)
+static void free_anchored_buffers(struct most_dev *mdev, unsigned int channel,
+                                 enum mbo_status_flags status)
 {
        struct mbo *mbo;
        struct buf_anchor *anchor, *tmp;
@@ -212,7 +214,7 @@ static void free_anchored_buffers(struct most_dev *mdev, unsigned int channel)
                                wait_for_completion(&anchor->urb_compl);
                        }
                        if ((mbo) && (mbo->complete)) {
-                               mbo->status = MBO_E_CLOSE;
+                               mbo->status = status;
                                mbo->processed_length = 0;
                                mbo->complete(mbo);
                        }
@@ -288,7 +290,7 @@ static int hdm_poison_channel(struct most_interface *iface, int channel)
        mdev->is_channel_healthy[channel] = false;
 
        mutex_lock(&mdev->io_mutex);
-       free_anchored_buffers(mdev, channel);
+       free_anchored_buffers(mdev, channel, MBO_E_CLOSE);
        if (mdev->padding_active[channel])
                mdev->padding_active[channel] = false;