mwifiex: Add locking to mwifiex_11n_delba
authorDouglas Anderson <dianders@chromium.org>
Fri, 12 May 2017 16:42:01 +0000 (09:42 -0700)
committerKalle Valo <kvalo@codeaurora.org>
Fri, 19 May 2017 06:01:56 +0000 (09:01 +0300)
The mwifiex_11n_delba() function walked the rx_reorder_tbl_ptr without
holding the lock, which was an obvious violation.

Grab the lock.

NOTE: we hold the lock while calling mwifiex_send_delba().  There's also
several callers in 11n_rxreorder.c that hold the lock and the comments
in the struct sound just like very other list/lock pair -- as if the
lock should definitely be help for all operations like this.

Signed-off-by: Douglas Anderson <dianders@chromium.org>
Signed-off-by: Brian Norris <briannorris@chromium.org>
Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
drivers/net/wireless/marvell/mwifiex/11n.c

index c75b6abf16a008d88e3bbac3ca7f825717a6b2eb..16c77c27f1b6022cc4e34d23704e421b1e64f77f 100644 (file)
@@ -653,11 +653,13 @@ int mwifiex_send_delba(struct mwifiex_private *priv, int tid, u8 *peer_mac,
 void mwifiex_11n_delba(struct mwifiex_private *priv, int tid)
 {
        struct mwifiex_rx_reorder_tbl *rx_reor_tbl_ptr;
+       unsigned long flags;
 
+       spin_lock_irqsave(&priv->rx_reorder_tbl_lock, flags);
        if (list_empty(&priv->rx_reorder_tbl_ptr)) {
                dev_dbg(priv->adapter->dev,
                        "mwifiex_11n_delba: rx_reorder_tbl_ptr empty\n");
-               return;
+               goto exit;
        }
 
        list_for_each_entry(rx_reor_tbl_ptr, &priv->rx_reorder_tbl_ptr, list) {
@@ -666,9 +668,11 @@ void mwifiex_11n_delba(struct mwifiex_private *priv, int tid)
                                "Send delba to tid=%d, %pM\n",
                                tid, rx_reor_tbl_ptr->ta);
                        mwifiex_send_delba(priv, tid, rx_reor_tbl_ptr->ta, 0);
-                       return;
+                       goto exit;
                }
        }
+exit:
+       spin_unlock_irqrestore(&priv->rx_reorder_tbl_lock, flags);
 }
 
 /*