mwifiex: delete TDLS link upon Teardown event
authorAvinash Patil <patila@marvell.com>
Thu, 22 May 2014 05:02:29 +0000 (22:02 -0700)
committerJohn W. Linville <linville@tuxdriver.com>
Thu, 22 May 2014 18:04:37 +0000 (14:04 -0400)
If userspace application does not take care of TDLS teardown
event, TDLS link would be present in driver database and thus
driver would send such packets on direct link while peer has
already severed link causing data traffic failure. Disable TDLS
link upon teardown event so as to ensure this does not happen.

Signed-off-by: Avinash Patil <patila@marvell.com>
Signed-off-by: Bing Zhao <bzhao@marvell.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
drivers/net/wireless/mwifiex/sta_event.c

index 5aea719219a3194cd8c39d3f46879437b7ab0af0..f6395ef11a721b8fc6d8ee797fb34a72b7c2f43d 100644 (file)
@@ -137,6 +137,7 @@ mwifiex_reset_connect_state(struct mwifiex_private *priv, u16 reason_code)
 static int mwifiex_parse_tdls_event(struct mwifiex_private *priv,
                                    struct sk_buff *event_skb)
 {
+       int ret = 0;
        struct mwifiex_adapter *adapter = priv->adapter;
        struct mwifiex_sta_node *sta_ptr;
        struct mwifiex_tdls_generic_event *tdls_evt =
@@ -162,12 +163,15 @@ static int mwifiex_parse_tdls_event(struct mwifiex_private *priv,
                                           NL80211_TDLS_TEARDOWN,
                                           le16_to_cpu(tdls_evt->u.reason_code),
                                           GFP_KERNEL);
+               ret = mwifiex_tdls_oper(priv, tdls_evt->peer_mac,
+                                       MWIFIEX_TDLS_DISABLE_LINK);
+               queue_work(adapter->workqueue, &adapter->main_work);
                break;
        default:
                break;
        }
 
-       return 0;
+       return ret;
 }
 
 /*