rsi: add support for rf-kill functionality
authorPavani Muthyala <pavani.muthyala@redpinesignals.com>
Thu, 3 Aug 2017 14:28:57 +0000 (19:58 +0530)
committerKalle Valo <kvalo@codeaurora.org>
Tue, 8 Aug 2017 11:46:00 +0000 (14:46 +0300)
This patch implements rfkill_poll handler. Also, necessary changes
are done in interface up and down handler to support rfkill
functionality.

Signed-off-by: Pavani Muthyala <pavani.muthyala@redpinesignals.com>
Signed-off-by: Amitkumar Karwar <amit.karwar@redpinesignals.com>
Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
drivers/net/wireless/rsi/rsi_91x_mac80211.c

index c91d6efa7c847612a8a512865497f8e373ea0705..193f9227fdb3359f02295e4a446887f51e349ab8 100644 (file)
@@ -279,11 +279,12 @@ static int rsi_mac80211_start(struct ieee80211_hw *hw)
        struct rsi_hw *adapter = hw->priv;
        struct rsi_common *common = adapter->priv;
 
+       rsi_dbg(ERR_ZONE, "===> Interface UP <===\n");
        mutex_lock(&common->mutex);
        common->iface_down = false;
-       mutex_unlock(&common->mutex);
-
+       wiphy_rfkill_start_polling(hw->wiphy);
        rsi_send_rx_filter_frame(common, 0);
+       mutex_unlock(&common->mutex);
 
        return 0;
 }
@@ -299,8 +300,10 @@ static void rsi_mac80211_stop(struct ieee80211_hw *hw)
        struct rsi_hw *adapter = hw->priv;
        struct rsi_common *common = adapter->priv;
 
+       rsi_dbg(ERR_ZONE, "===> Interface DOWN <===\n");
        mutex_lock(&common->mutex);
        common->iface_down = true;
+       wiphy_rfkill_stop_polling(hw->wiphy);
 
        /* Block all rx frames */
        rsi_send_rx_filter_frame(common, 0xffff);
@@ -1214,6 +1217,19 @@ static void rsi_reg_notify(struct wiphy *wiphy,
        mutex_unlock(&common->mutex);
 }
 
+static void rsi_mac80211_rfkill_poll(struct ieee80211_hw *hw)
+{
+       struct rsi_hw *adapter = hw->priv;
+       struct rsi_common *common = adapter->priv;
+
+       mutex_lock(&common->mutex);
+       if (common->fsm_state != FSM_MAC_INIT_DONE)
+               wiphy_rfkill_set_hw_state(hw->wiphy, true);
+       else
+               wiphy_rfkill_set_hw_state(hw->wiphy, false);
+       mutex_unlock(&common->mutex);
+}
+
 static struct ieee80211_ops mac80211_ops = {
        .tx = rsi_mac80211_tx,
        .start = rsi_mac80211_start,
@@ -1232,6 +1248,7 @@ static struct ieee80211_ops mac80211_ops = {
        .sta_remove = rsi_mac80211_sta_remove,
        .set_antenna = rsi_mac80211_set_antenna,
        .get_antenna = rsi_mac80211_get_antenna,
+       .rfkill_poll = rsi_mac80211_rfkill_poll,
 };
 
 /**