staging: wfx: relocate wfx_skb_dtor() prior its callers
authorJérôme Pouiller <jerome.pouiller@silabs.com>
Wed, 1 Apr 2020 11:04:00 +0000 (13:04 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 13 Apr 2020 06:55:37 +0000 (08:55 +0200)
In a next commit, we would like to mark wfx_skb_dtor as static and stop
to declare it in data_tx.h.

Relocate wfx_skb_dtor() prior its callers to avoid compile error.

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-28-Jerome.Pouiller@silabs.com
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/staging/wfx/data_tx.c

index 17209f645e4b8e8471815c73b40fd9e1446c954a..ec95518c91675ad5ba266d74925880bc36ad9e82 100644 (file)
@@ -503,6 +503,43 @@ drop:
        ieee80211_tx_status_irqsafe(wdev->hw, skb);
 }
 
+static void wfx_notify_buffered_tx(struct wfx_vif *wvif, struct sk_buff *skb)
+{
+       struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data;
+       struct ieee80211_sta *sta;
+       struct wfx_sta_priv *sta_priv;
+       int tid = ieee80211_get_tid(hdr);
+
+       rcu_read_lock(); // protect sta
+       sta = ieee80211_find_sta(wvif->vif, hdr->addr1);
+       if (sta) {
+               sta_priv = (struct wfx_sta_priv *)&sta->drv_priv;
+               spin_lock_bh(&sta_priv->lock);
+               WARN(!sta_priv->buffered[tid], "inconsistent notification");
+               sta_priv->buffered[tid]--;
+               if (!sta_priv->buffered[tid])
+                       ieee80211_sta_set_buffered(sta, tid, false);
+               spin_unlock_bh(&sta_priv->lock);
+       }
+       rcu_read_unlock();
+}
+
+void wfx_skb_dtor(struct wfx_dev *wdev, struct sk_buff *skb)
+{
+       struct hif_msg *hif = (struct hif_msg *)skb->data;
+       struct hif_req_tx *req = (struct hif_req_tx *)hif->body;
+       struct wfx_vif *wvif = wdev_to_wvif(wdev, hif->interface);
+       unsigned int offset = sizeof(struct hif_req_tx) +
+                               sizeof(struct hif_msg) +
+                               req->data_flags.fc_offset;
+
+       WARN_ON(!wvif);
+       skb_pull(skb, offset);
+       wfx_notify_buffered_tx(wvif, skb);
+       wfx_tx_policy_put(wvif, req->tx_flags.retry_policy_index);
+       ieee80211_tx_status_irqsafe(wdev->hw, skb);
+}
+
 void wfx_tx_confirm_cb(struct wfx_vif *wvif, const struct hif_cnf_tx *arg)
 {
        int i;
@@ -589,39 +626,4 @@ void wfx_tx_confirm_cb(struct wfx_vif *wvif, const struct hif_cnf_tx *arg)
        wfx_skb_dtor(wvif->wdev, skb);
 }
 
-static void wfx_notify_buffered_tx(struct wfx_vif *wvif, struct sk_buff *skb)
-{
-       struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data;
-       struct ieee80211_sta *sta;
-       struct wfx_sta_priv *sta_priv;
-       int tid = ieee80211_get_tid(hdr);
-
-       rcu_read_lock(); // protect sta
-       sta = ieee80211_find_sta(wvif->vif, hdr->addr1);
-       if (sta) {
-               sta_priv = (struct wfx_sta_priv *)&sta->drv_priv;
-               spin_lock_bh(&sta_priv->lock);
-               WARN(!sta_priv->buffered[tid], "inconsistent notification");
-               sta_priv->buffered[tid]--;
-               if (!sta_priv->buffered[tid])
-                       ieee80211_sta_set_buffered(sta, tid, false);
-               spin_unlock_bh(&sta_priv->lock);
-       }
-       rcu_read_unlock();
-}
-
-void wfx_skb_dtor(struct wfx_dev *wdev, struct sk_buff *skb)
-{
-       struct hif_msg *hif = (struct hif_msg *)skb->data;
-       struct hif_req_tx *req = (struct hif_req_tx *)hif->body;
-       struct wfx_vif *wvif = wdev_to_wvif(wdev, hif->interface);
-       unsigned int offset = sizeof(struct hif_req_tx) +
-                               sizeof(struct hif_msg) +
-                               req->data_flags.fc_offset;
 
-       WARN_ON(!wvif);
-       skb_pull(skb, offset);
-       wfx_notify_buffered_tx(wvif, skb);
-       wfx_tx_policy_put(wvif, req->tx_flags.retry_policy_index);
-       ieee80211_tx_status_irqsafe(wdev->hw, skb);
-}