staging: wfx: wfx_flush() did not ensure that frames are processed
authorJérôme Pouiller <jerome.pouiller@silabs.com>
Wed, 1 Apr 2020 11:04:02 +0000 (13:04 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 13 Apr 2020 06:55:37 +0000 (08:55 +0200)
wfx_flush() exited once all frames are retrieved from the device.
However, it did not ensure they were processed by driver before to
return. Therefore, some frame may be processed after the interface has
disappear.

Change the place we signal that the queue is empty to fix that.

Reviewed-by: Dan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: Jérôme Pouiller <jerome.pouiller@silabs.com>
Link: https://lore.kernel.org/r/20200401110405.80282-30-Jerome.Pouiller@silabs.com
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/staging/wfx/bh.c

index 9fcab00a373356a6b973988328fbcc20e885744d..ba7fa0a7cd9a4f174d4ae0a1f026e09334d9a771 100644 (file)
@@ -108,8 +108,6 @@ static int rx_helper(struct wfx_dev *wdev, size_t read_len, int *is_cnf)
                        release_count = 1;
                WARN(wdev->hif.tx_buffers_used < release_count, "corrupted buffer counter");
                wdev->hif.tx_buffers_used -= release_count;
-               if (!wdev->hif.tx_buffers_used)
-                       wake_up(&wdev->hif.tx_buffers_empty);
        }
        _trace_hif_recv(hif, wdev->hif.tx_buffers_used);
 
@@ -123,6 +121,8 @@ static int rx_helper(struct wfx_dev *wdev, size_t read_len, int *is_cnf)
        skb_put(skb, hif->len);
        // wfx_handle_rx takes care on SKB livetime
        wfx_handle_rx(wdev, skb);
+       if (!wdev->hif.tx_buffers_used)
+               wake_up(&wdev->hif.tx_buffers_empty);
 
        return piggyback;