Commit 9ed745ff authored by Christian Gromm's avatar Christian Gromm Committed by Greg Kroah-Hartman

staging: most: hdm-usb: provide MBO status when freeing buffers

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: default avatarAndrey Shvetsov <andrey.shvetsov@k2l.de>
Signed-off-by: default avatarChristian Gromm <christian.gromm@microchip.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent cce93019
...@@ -190,8 +190,10 @@ static inline int drci_wr_reg(struct usb_device *dev, u16 reg, u16 data) ...@@ -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 * free_anchored_buffers - free device's anchored items
* @mdev: the device * @mdev: the device
* @channel: channel ID * @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 mbo *mbo;
struct buf_anchor *anchor, *tmp; struct buf_anchor *anchor, *tmp;
...@@ -212,7 +214,7 @@ static void free_anchored_buffers(struct most_dev *mdev, unsigned int channel) ...@@ -212,7 +214,7 @@ static void free_anchored_buffers(struct most_dev *mdev, unsigned int channel)
wait_for_completion(&anchor->urb_compl); wait_for_completion(&anchor->urb_compl);
} }
if ((mbo) && (mbo->complete)) { if ((mbo) && (mbo->complete)) {
mbo->status = MBO_E_CLOSE; mbo->status = status;
mbo->processed_length = 0; mbo->processed_length = 0;
mbo->complete(mbo); mbo->complete(mbo);
} }
...@@ -288,7 +290,7 @@ static int hdm_poison_channel(struct most_interface *iface, int channel) ...@@ -288,7 +290,7 @@ static int hdm_poison_channel(struct most_interface *iface, int channel)
mdev->is_channel_healthy[channel] = false; mdev->is_channel_healthy[channel] = false;
mutex_lock(&mdev->io_mutex); mutex_lock(&mdev->io_mutex);
free_anchored_buffers(mdev, channel); free_anchored_buffers(mdev, channel, MBO_E_CLOSE);
if (mdev->padding_active[channel]) if (mdev->padding_active[channel])
mdev->padding_active[channel] = false; mdev->padding_active[channel] = false;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment