wfx: use container_of() to get vif
authorJaehee Park <jhpark1013@gmail.com>
Fri, 6 May 2022 17:00:46 +0000 (13:00 -0400)
committerKalle Valo <kvalo@kernel.org>
Wed, 11 May 2022 05:32:57 +0000 (08:32 +0300)
Currently, upon virtual interface creation, wfx_add_interface() stores
a reference to the corresponding struct ieee80211_vif in private data,
for later usage. This is not needed when using the container_of
construct. This construct already has all the info it needs to retrieve
the reference to the corresponding struct from the offset that is
already available, inherent in container_of(), between its type and
member inputs (struct ieee80211_vif and drv_priv, respectively).
Remove vif (which was previously storing the reference to the struct
ieee80211_vif) from the struct wfx_vif, define a function
wvif_to_vif(wvif) for container_of(), and replace all wvif->vif with
the newly defined container_of construct.

Signed-off-by: Jaehee Park <jhpark1013@gmail.com>
Signed-off-by: Kalle Valo <kvalo@kernel.org>
Link: https://lore.kernel.org/r/20220506170046.GA1297231@jaehee-ThinkPad-X1-Extreme
drivers/net/wireless/silabs/wfx/data_rx.c
drivers/net/wireless/silabs/wfx/data_tx.c
drivers/net/wireless/silabs/wfx/key.c
drivers/net/wireless/silabs/wfx/queue.c
drivers/net/wireless/silabs/wfx/scan.c
drivers/net/wireless/silabs/wfx/sta.c
drivers/net/wireless/silabs/wfx/wfx.h

index a4b5ffe158e47ade89e1decad476f938232a4527..e099a9e65bae698d42db1139b660699741614993 100644 (file)
@@ -15,6 +15,7 @@
 
 static void wfx_rx_handle_ba(struct wfx_vif *wvif, struct ieee80211_mgmt *mgmt)
 {
+       struct ieee80211_vif *vif = wvif_to_vif(wvif);
        int params, tid;
 
        if (wfx_api_older_than(wvif->wdev, 3, 6))
@@ -24,12 +25,12 @@ static void wfx_rx_handle_ba(struct wfx_vif *wvif, struct ieee80211_mgmt *mgmt)
        case WLAN_ACTION_ADDBA_REQ:
                params = le16_to_cpu(mgmt->u.action.u.addba_req.capab);
                tid = (params & IEEE80211_ADDBA_PARAM_TID_MASK) >> 2;
-               ieee80211_start_rx_ba_session_offl(wvif->vif, mgmt->sa, tid);
+               ieee80211_start_rx_ba_session_offl(vif, mgmt->sa, tid);
                break;
        case WLAN_ACTION_DELBA:
                params = le16_to_cpu(mgmt->u.action.u.delba.params);
                tid = (params &  IEEE80211_DELBA_PARAM_TID_MASK) >> 12;
-               ieee80211_stop_rx_ba_session_offl(wvif->vif, mgmt->sa, tid);
+               ieee80211_stop_rx_ba_session_offl(vif, mgmt->sa, tid);
                break;
        }
 }
index e07381b2ff4d2416fbd066d1d53386533364f44d..6a5e52a96d183a138c543f03b6cea33732adb5a9 100644 (file)
@@ -212,11 +212,12 @@ static u8 wfx_tx_get_link_id(struct wfx_vif *wvif, struct ieee80211_sta *sta,
                             struct ieee80211_hdr *hdr)
 {
        struct wfx_sta_priv *sta_priv = sta ? (struct wfx_sta_priv *)&sta->drv_priv : NULL;
+       struct ieee80211_vif *vif = wvif_to_vif(wvif);
        const u8 *da = ieee80211_get_DA(hdr);
 
        if (sta_priv && sta_priv->link_id)
                return sta_priv->link_id;
-       if (wvif->vif->type != NL80211_IFTYPE_AP)
+       if (vif->type != NL80211_IFTYPE_AP)
                return 0;
        if (is_multicast_ether_addr(da))
                return 0;
index 8f23e8d42bd4870224c06beaeee40fef3ce76737..196d64ef68f3b9980060b02398d4d11c0b576adf 100644 (file)
@@ -156,6 +156,7 @@ static int wfx_add_key(struct wfx_vif *wvif, struct ieee80211_sta *sta,
        struct wfx_dev *wdev = wvif->wdev;
        int idx = wfx_alloc_key(wvif->wdev);
        bool pairwise = key->flags & IEEE80211_KEY_FLAG_PAIRWISE;
+       struct ieee80211_vif *vif = wvif_to_vif(wvif);
 
        WARN(key->flags & IEEE80211_KEY_FLAG_PAIRWISE && !sta, "inconsistent data");
        ieee80211_get_key_rx_seq(key, 0, &seq);
@@ -174,7 +175,7 @@ static int wfx_add_key(struct wfx_vif *wvif, struct ieee80211_sta *sta,
                        k.type = fill_tkip_pair(&k.key.tkip_pairwise_key, key, sta->addr);
                else
                        k.type = fill_tkip_group(&k.key.tkip_group_key, key, &seq,
-                                                wvif->vif->type);
+                                                vif->type);
        } else if (key->cipher == WLAN_CIPHER_SUITE_CCMP) {
                if (pairwise)
                        k.type = fill_ccmp_pair(&k.key.aes_pairwise_key, key, sta->addr);
@@ -224,4 +225,3 @@ int wfx_set_key(struct ieee80211_hw *hw, enum set_key_cmd cmd, struct ieee80211_
        mutex_unlock(&wvif->wdev->conf_mutex);
        return ret;
 }
-
index 729825230db269c2ef1b60199d8eda2961719457..37f492e5d3bea5dcf16f375e69a296fcf12d3734 100644 (file)
@@ -205,9 +205,10 @@ unsigned int wfx_pending_get_pkt_us_delay(struct wfx_dev *wdev, struct sk_buff *
 
 bool wfx_tx_queues_has_cab(struct wfx_vif *wvif)
 {
+       struct ieee80211_vif *vif = wvif_to_vif(wvif);
        int i;
 
-       if (wvif->vif->type != NL80211_IFTYPE_AP)
+       if (vif->type != NL80211_IFTYPE_AP)
                return false;
        for (i = 0; i < IEEE80211_NUM_ACS; ++i)
                /* Note: since only AP can have mcast frames in queue and only one vif can be AP,
index 7f34f0d322f909bb7f9541f4d6ed91033928c9c3..16f619ed22e00ae3d762506a0acfc38e9c6cccf7 100644 (file)
@@ -23,9 +23,11 @@ static void wfx_ieee80211_scan_completed_compat(struct ieee80211_hw *hw, bool ab
 
 static int update_probe_tmpl(struct wfx_vif *wvif, struct cfg80211_scan_request *req)
 {
+       struct ieee80211_vif *vif = wvif_to_vif(wvif);
        struct sk_buff *skb;
 
-       skb = ieee80211_probereq_get(wvif->wdev->hw, wvif->vif->addr, NULL, 0, req->ie_len);
+       skb = ieee80211_probereq_get(wvif->wdev->hw, vif->addr, NULL, 0,
+                                    req->ie_len);
        if (!skb)
                return -ENOMEM;
 
@@ -37,8 +39,9 @@ static int update_probe_tmpl(struct wfx_vif *wvif, struct cfg80211_scan_request
 
 static int send_scan_req(struct wfx_vif *wvif, struct cfg80211_scan_request *req, int start_idx)
 {
-       int i, ret;
+       struct ieee80211_vif *vif = wvif_to_vif(wvif);
        struct ieee80211_channel *ch_start, *ch_cur;
+       int i, ret;
 
        for (i = start_idx; i < req->n_channels; i++) {
                ch_start = req->channels[start_idx];
@@ -75,8 +78,8 @@ static int send_scan_req(struct wfx_vif *wvif, struct cfg80211_scan_request *req
        } else {
                ret = wvif->scan_nb_chan_done;
        }
-       if (req->channels[start_idx]->max_power != wvif->vif->bss_conf.txpower)
-               wfx_hif_set_output_power(wvif, wvif->vif->bss_conf.txpower);
+       if (req->channels[start_idx]->max_power != vif->bss_conf.txpower)
+               wfx_hif_set_output_power(wvif, vif->bss_conf.txpower);
        wfx_tx_unlock(wvif->wdev);
        return ret;
 }
index 3297d73c327a089d67d8b9d375a9807979797755..e551fa284a43797ea2fb2c7b98c745f42dcfc5f3 100644 (file)
@@ -98,9 +98,10 @@ static void wfx_filter_beacon(struct wfx_vif *wvif, bool filter_beacon)
 void wfx_configure_filter(struct ieee80211_hw *hw, unsigned int changed_flags,
                          unsigned int *total_flags, u64 unused)
 {
-       struct wfx_vif *wvif = NULL;
-       struct wfx_dev *wdev = hw->priv;
        bool filter_bssid, filter_prbreq, filter_beacon;
+       struct ieee80211_vif *vif = NULL;
+       struct wfx_dev *wdev = hw->priv;
+       struct wfx_vif *wvif = NULL;
 
        /* Notes:
         *   - Probe responses (FIF_BCN_PRBRESP_PROMISC) are never filtered
@@ -131,8 +132,9 @@ void wfx_configure_filter(struct ieee80211_hw *hw, unsigned int changed_flags,
                else
                        filter_bssid = true;
 
+               vif = wvif_to_vif(wvif);
                /* In AP mode, chip can reply to probe request itself */
-               if (*total_flags & FIF_PROBE_REQ && wvif->vif->type == NL80211_IFTYPE_AP) {
+               if (*total_flags & FIF_PROBE_REQ && vif->type == NL80211_IFTYPE_AP) {
                        dev_dbg(wdev->dev, "do not forward probe request in AP mode\n");
                        *total_flags &= ~FIF_PROBE_REQ;
                }
@@ -152,19 +154,28 @@ static int wfx_get_ps_timeout(struct wfx_vif *wvif, bool *enable_ps)
 {
        struct ieee80211_channel *chan0 = NULL, *chan1 = NULL;
        struct ieee80211_conf *conf = &wvif->wdev->hw->conf;
+       struct ieee80211_vif *vif = wvif_to_vif(wvif);
 
-       WARN(!wvif->vif->bss_conf.assoc && enable_ps,
+       WARN(!vif->bss_conf.assoc && enable_ps,
             "enable_ps is reliable only if associated");
-       if (wdev_to_wvif(wvif->wdev, 0))
-               chan0 = wdev_to_wvif(wvif->wdev, 0)->vif->bss_conf.chandef.chan;
-       if (wdev_to_wvif(wvif->wdev, 1))
-               chan1 = wdev_to_wvif(wvif->wdev, 1)->vif->bss_conf.chandef.chan;
-       if (chan0 && chan1 && wvif->vif->type != NL80211_IFTYPE_AP) {
+       if (wdev_to_wvif(wvif->wdev, 0)) {
+               struct wfx_vif *wvif_ch0 = wdev_to_wvif(wvif->wdev, 0);
+               struct ieee80211_vif *vif_ch0 = wvif_to_vif(wvif_ch0);
+
+               chan0 = vif_ch0->bss_conf.chandef.chan;
+       }
+       if (wdev_to_wvif(wvif->wdev, 1)) {
+               struct wfx_vif *wvif_ch1 = wdev_to_wvif(wvif->wdev, 1);
+               struct ieee80211_vif *vif_ch1 = wvif_to_vif(wvif_ch1);
+
+               chan1 = vif_ch1->bss_conf.chandef.chan;
+       }
+       if (chan0 && chan1 && vif->type != NL80211_IFTYPE_AP) {
                if (chan0->hw_value == chan1->hw_value) {
                        /* It is useless to enable PS if channels are the same. */
                        if (enable_ps)
                                *enable_ps = false;
-                       if (wvif->vif->bss_conf.assoc && wvif->vif->bss_conf.ps)
+                       if (vif->bss_conf.assoc && vif->bss_conf.ps)
                                dev_info(wvif->wdev->dev, "ignoring requested PS mode");
                        return -1;
                }
@@ -177,8 +188,8 @@ static int wfx_get_ps_timeout(struct wfx_vif *wvif, bool *enable_ps)
                        return 30;
        }
        if (enable_ps)
-               *enable_ps = wvif->vif->bss_conf.ps;
-       if (wvif->vif->bss_conf.assoc && wvif->vif->bss_conf.ps)
+               *enable_ps = vif->bss_conf.ps;
+       if (vif->bss_conf.assoc && vif->bss_conf.ps)
                return conf->dynamic_ps_timeout;
        else
                return -1;
@@ -186,10 +197,11 @@ static int wfx_get_ps_timeout(struct wfx_vif *wvif, bool *enable_ps)
 
 int wfx_update_pm(struct wfx_vif *wvif)
 {
+       struct ieee80211_vif *vif = wvif_to_vif(wvif);
        int ps_timeout;
        bool ps;
 
-       if (!wvif->vif->bss_conf.assoc)
+       if (!vif->bss_conf.assoc)
                return 0;
        ps_timeout = wfx_get_ps_timeout(wvif, &ps);
        if (!ps)
@@ -215,7 +227,8 @@ int wfx_conf_tx(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
        mutex_lock(&wdev->conf_mutex);
        assign_bit(queue, &wvif->uapsd_mask, params->uapsd);
        wfx_hif_set_edca_queue_params(wvif, queue, params);
-       if (wvif->vif->type == NL80211_IFTYPE_STATION && old_uapsd != wvif->uapsd_mask) {
+       if (vif->type == NL80211_IFTYPE_STATION &&
+           old_uapsd != wvif->uapsd_mask) {
                wfx_hif_set_uapsd_info(wvif, wvif->uapsd_mask);
                wfx_update_pm(wvif);
        }
@@ -238,24 +251,26 @@ void wfx_event_report_rssi(struct wfx_vif *wvif, u8 raw_rcpi_rssi)
        /* RSSI: signed Q8.0, RCPI: unsigned Q7.1
         * RSSI = RCPI / 2 - 110
         */
+       struct ieee80211_vif *vif = wvif_to_vif(wvif);
        int rcpi_rssi;
        int cqm_evt;
 
        rcpi_rssi = raw_rcpi_rssi / 2 - 110;
-       if (rcpi_rssi <= wvif->vif->bss_conf.cqm_rssi_thold)
+       if (rcpi_rssi <= vif->bss_conf.cqm_rssi_thold)
                cqm_evt = NL80211_CQM_RSSI_THRESHOLD_EVENT_LOW;
        else
                cqm_evt = NL80211_CQM_RSSI_THRESHOLD_EVENT_HIGH;
-       ieee80211_cqm_rssi_notify(wvif->vif, cqm_evt, rcpi_rssi, GFP_KERNEL);
+       ieee80211_cqm_rssi_notify(vif, cqm_evt, rcpi_rssi, GFP_KERNEL);
 }
 
 static void wfx_beacon_loss_work(struct work_struct *work)
 {
        struct wfx_vif *wvif = container_of(to_delayed_work(work), struct wfx_vif,
                                            beacon_loss_work);
-       struct ieee80211_bss_conf *bss_conf = &wvif->vif->bss_conf;
+       struct ieee80211_vif *vif = wvif_to_vif(wvif);
+       struct ieee80211_bss_conf *bss_conf = &vif->bss_conf;
 
-       ieee80211_beacon_loss(wvif->vif);
+       ieee80211_beacon_loss(vif);
        schedule_delayed_work(to_delayed_work(work), msecs_to_jiffies(bss_conf->beacon_int));
 }
 
@@ -321,15 +336,16 @@ int wfx_sta_remove(struct ieee80211_hw *hw, struct ieee80211_vif *vif, struct ie
 
 static int wfx_upload_ap_templates(struct wfx_vif *wvif)
 {
+       struct ieee80211_vif *vif = wvif_to_vif(wvif);
        struct sk_buff *skb;
 
-       skb = ieee80211_beacon_get(wvif->wdev->hw, wvif->vif);
+       skb = ieee80211_beacon_get(wvif->wdev->hw, vif);
        if (!skb)
                return -ENOMEM;
        wfx_hif_set_template_frame(wvif, skb, HIF_TMPLT_BCN, API_RATE_INDEX_B_1MBPS);
        dev_kfree_skb(skb);
 
-       skb = ieee80211_proberesp_get(wvif->wdev->hw, wvif->vif);
+       skb = ieee80211_proberesp_get(wvif->wdev->hw, vif);
        if (!skb)
                return -ENOMEM;
        wfx_hif_set_template_frame(wvif, skb, HIF_TMPLT_PRBRES, API_RATE_INDEX_B_1MBPS);
@@ -339,7 +355,8 @@ static int wfx_upload_ap_templates(struct wfx_vif *wvif)
 
 static void wfx_set_mfp_ap(struct wfx_vif *wvif)
 {
-       struct sk_buff *skb = ieee80211_beacon_get(wvif->wdev->hw, wvif->vif);
+       struct ieee80211_vif *vif = wvif_to_vif(wvif);
+       struct sk_buff *skb = ieee80211_beacon_get(wvif->wdev->hw, vif);
        const int ieoffset = offsetof(struct ieee80211_mgmt, u.beacon.variable);
        const u16 *ptr = (u16 *)cfg80211_find_ie(WLAN_EID_RSN, skb->data + ieoffset,
                                                 skb->len - ieoffset);
@@ -388,12 +405,13 @@ void wfx_stop_ap(struct ieee80211_hw *hw, struct ieee80211_vif *vif)
 
 static void wfx_join(struct wfx_vif *wvif)
 {
-       int ret;
-       struct ieee80211_bss_conf *conf = &wvif->vif->bss_conf;
+       struct ieee80211_vif *vif = wvif_to_vif(wvif);
+       struct ieee80211_bss_conf *conf = &vif->bss_conf;
        struct cfg80211_bss *bss = NULL;
        u8 ssid[IEEE80211_MAX_SSID_LEN];
        const u8 *ssidie = NULL;
        int ssidlen = 0;
+       int ret;
 
        wfx_tx_lock_flush(wvif->wdev);
 
@@ -420,7 +438,7 @@ static void wfx_join(struct wfx_vif *wvif)
        wvif->join_in_progress = true;
        ret = wfx_hif_join(wvif, conf, wvif->channel, ssid, ssidlen);
        if (ret) {
-               ieee80211_connection_loss(wvif->vif);
+               ieee80211_connection_loss(vif);
                wfx_reset(wvif);
        } else {
                /* Due to beacon filtering it is possible that the AP's beacon is not known for the
@@ -434,13 +452,14 @@ static void wfx_join(struct wfx_vif *wvif)
 
 static void wfx_join_finalize(struct wfx_vif *wvif, struct ieee80211_bss_conf *info)
 {
+       struct ieee80211_vif *vif = wvif_to_vif(wvif);
        struct ieee80211_sta *sta = NULL;
        int ampdu_density = 0;
        bool greenfield = false;
 
        rcu_read_lock(); /* protect sta */
        if (info->bssid && !info->ibss_joined)
-               sta = ieee80211_find_sta(wvif->vif, info->bssid);
+               sta = ieee80211_find_sta(vif, info->bssid);
        if (sta && sta->deflink.ht_cap.ht_supported)
                ampdu_density = sta->deflink.ht_cap.ampdu_density;
        if (sta && sta->deflink.ht_cap.ht_supported &&
@@ -561,11 +580,13 @@ void wfx_bss_info_changed(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
 
 static int wfx_update_tim(struct wfx_vif *wvif)
 {
+       struct ieee80211_vif *vif = wvif_to_vif(wvif);
        struct sk_buff *skb;
        u16 tim_offset, tim_length;
        u8 *tim_ptr;
 
-       skb = ieee80211_beacon_get_tim(wvif->wdev->hw, wvif->vif, &tim_offset, &tim_length);
+       skb = ieee80211_beacon_get_tim(wvif->wdev->hw, vif, &tim_offset,
+                                      &tim_length);
        if (!skb)
                return -ENOENT;
        tim_ptr = skb->data + tim_offset;
@@ -707,8 +728,6 @@ int wfx_add_interface(struct ieee80211_hw *hw, struct ieee80211_vif *vif)
                return -EOPNOTSUPP;
        }
 
-       /* FIXME: prefer use of container_of() to get vif */
-       wvif->vif = vif;
        wvif->wdev = wdev;
 
        wvif->link_id_map = 1; /* link-id 0 is reserved for multicast */
@@ -767,7 +786,6 @@ void wfx_remove_interface(struct ieee80211_hw *hw, struct ieee80211_vif *vif)
 
        cancel_delayed_work_sync(&wvif->beacon_loss_work);
        wdev->vif[wvif->id] = NULL;
-       wvif->vif = NULL;
 
        mutex_unlock(&wdev->conf_mutex);
 
index 6f5e95dae21f451acd598bd5ff215fe5f765c835..13ba84b3b2c33242da88f3959791848e9c0ce36b 100644 (file)
@@ -62,7 +62,6 @@ struct wfx_dev {
 
 struct wfx_vif {
        struct wfx_dev             *wdev;
-       struct ieee80211_vif       *vif;
        struct ieee80211_channel   *channel;
        int                        id;
 
@@ -92,6 +91,11 @@ struct wfx_vif {
        struct completion          set_pm_mode_complete;
 };
 
+static inline struct ieee80211_vif *wvif_to_vif(struct wfx_vif *wvif)
+{
+       return container_of((void *)wvif, struct ieee80211_vif, drv_priv);
+}
+
 static inline struct wfx_vif *wdev_to_wvif(struct wfx_dev *wdev, int vif_id)
 {
        if (vif_id >= ARRAY_SIZE(wdev->vif)) {