developer | bd9fa1e | 2023-10-16 11:04:00 +0800 | [diff] [blame] | 1 | From e6830d67bbbc38036cd077badd5a605b8f257752 Mon Sep 17 00:00:00 2001 |
| 2 | From: Benjamin Lin <benjamin-jw.lin@mediatek.com> |
| 3 | Date: Thu, 27 Jul 2023 14:00:30 +0800 |
| 4 | Subject: [PATCH 21/98] wifi: mt76: mt7996: remove periodic MPDU TXS request |
| 5 | |
| 6 | --- |
| 7 | mt7996/mac.c | 39 ++++++++++++++++++++++----------------- |
| 8 | mt7996/main.c | 1 - |
| 9 | mt7996/mt7996.h | 1 - |
| 10 | 3 files changed, 22 insertions(+), 19 deletions(-) |
| 11 | |
| 12 | diff --git a/mt7996/mac.c b/mt7996/mac.c |
| 13 | index 06c9a14..32c52fc 100644 |
| 14 | --- a/mt7996/mac.c |
| 15 | +++ b/mt7996/mac.c |
| 16 | @@ -926,15 +926,6 @@ int mt7996_tx_prepare_skb(struct mt76_dev *mdev, void *txwi_ptr, |
| 17 | if (!wcid) |
| 18 | wcid = &dev->mt76.global_wcid; |
| 19 | |
| 20 | - if (sta) { |
| 21 | - struct mt7996_sta *msta = (struct mt7996_sta *)sta->drv_priv; |
| 22 | - |
| 23 | - if (time_after(jiffies, msta->jiffies + HZ / 4)) { |
| 24 | - info->flags |= IEEE80211_TX_CTL_REQ_TX_STATUS; |
| 25 | - msta->jiffies = jiffies; |
| 26 | - } |
| 27 | - } |
| 28 | - |
| 29 | t = (struct mt76_txwi_cache *)(txwi + mdev->drv->txwi_size); |
| 30 | t->skb = tx_info->skb; |
| 31 | |
| 32 | @@ -1010,22 +1001,36 @@ u32 mt7996_wed_init_buf(void *ptr, dma_addr_t phys, int token_id) |
| 33 | } |
| 34 | |
| 35 | static void |
| 36 | -mt7996_tx_check_aggr(struct ieee80211_sta *sta, __le32 *txwi) |
| 37 | +mt7996_tx_check_aggr(struct ieee80211_sta *sta, struct sk_buff *skb) |
| 38 | { |
| 39 | struct mt7996_sta *msta; |
| 40 | + struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb); |
| 41 | + bool is_8023 = info->flags & IEEE80211_TX_CTL_HW_80211_ENCAP; |
| 42 | u16 fc, tid; |
| 43 | - u32 val; |
| 44 | |
| 45 | if (!sta || !(sta->deflink.ht_cap.ht_supported || sta->deflink.he_cap.has_he)) |
| 46 | return; |
| 47 | |
| 48 | - tid = le32_get_bits(txwi[1], MT_TXD1_TID); |
| 49 | + tid = skb->priority & IEEE80211_QOS_CTL_TID_MASK; |
| 50 | if (tid >= 6) /* skip VO queue */ |
| 51 | return; |
| 52 | |
| 53 | - val = le32_to_cpu(txwi[2]); |
| 54 | - fc = FIELD_GET(MT_TXD2_FRAME_TYPE, val) << 2 | |
| 55 | - FIELD_GET(MT_TXD2_SUB_TYPE, val) << 4; |
| 56 | + if (is_8023) |
| 57 | + fc = IEEE80211_FTYPE_DATA | |
| 58 | + (sta->wme ? IEEE80211_STYPE_QOS_DATA |
| 59 | + : IEEE80211_STYPE_DATA); |
| 60 | + else { |
| 61 | + /* No need to get precise TID for Action/Management Frame, |
| 62 | + * since it will not meet the following Frame Control |
| 63 | + * condition anyway. |
| 64 | + */ |
| 65 | + |
| 66 | + struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data; |
| 67 | + |
| 68 | + fc = le16_to_cpu(hdr->frame_control) & |
| 69 | + (IEEE80211_FCTL_FTYPE | IEEE80211_FCTL_STYPE); |
| 70 | + } |
| 71 | + |
| 72 | if (unlikely(fc != (IEEE80211_FTYPE_DATA | IEEE80211_STYPE_QOS_DATA))) |
| 73 | return; |
| 74 | |
| 75 | @@ -1053,7 +1058,7 @@ mt7996_txwi_free(struct mt7996_dev *dev, struct mt76_txwi_cache *t, |
| 76 | wcid_idx = wcid->idx; |
| 77 | |
| 78 | if (likely(t->skb->protocol != cpu_to_be16(ETH_P_PAE))) |
| 79 | - mt7996_tx_check_aggr(sta, txwi); |
| 80 | + mt7996_tx_check_aggr(sta, t->skb); |
| 81 | } else { |
| 82 | wcid_idx = le32_get_bits(txwi[9], MT_TXD9_WLAN_IDX); |
| 83 | } |
| 84 | @@ -1330,7 +1335,7 @@ static void mt7996_mac_add_txs(struct mt7996_dev *dev, void *data) |
| 85 | wcidx = le32_get_bits(txs_data[2], MT_TXS2_MLD_ID); |
| 86 | pid = le32_get_bits(txs_data[3], MT_TXS3_PID); |
| 87 | |
| 88 | - if (pid < MT_PACKET_ID_WED) |
| 89 | + if (pid < MT_PACKET_ID_NO_SKB) |
| 90 | return; |
| 91 | |
| 92 | if (wcidx >= mt7996_wtbl_size(dev)) |
| 93 | diff --git a/mt7996/main.c b/mt7996/main.c |
| 94 | index 0b3f8c8..832b861 100644 |
| 95 | --- a/mt7996/main.c |
| 96 | +++ b/mt7996/main.c |
| 97 | @@ -666,7 +666,6 @@ int mt7996_mac_sta_add(struct mt76_dev *mdev, struct ieee80211_vif *vif, |
| 98 | msta->wcid.idx = idx; |
| 99 | msta->wcid.phy_idx = band_idx; |
| 100 | msta->wcid.tx_info |= MT_WCID_TX_INFO_SET; |
| 101 | - msta->jiffies = jiffies; |
| 102 | |
| 103 | ewma_avg_signal_init(&msta->avg_ack_signal); |
| 104 | |
| 105 | diff --git a/mt7996/mt7996.h b/mt7996/mt7996.h |
| 106 | index 420d113..f268773 100644 |
| 107 | --- a/mt7996/mt7996.h |
| 108 | +++ b/mt7996/mt7996.h |
| 109 | @@ -147,7 +147,6 @@ struct mt7996_sta { |
| 110 | struct ewma_avg_signal avg_ack_signal; |
| 111 | |
| 112 | unsigned long changed; |
| 113 | - unsigned long jiffies; |
| 114 | |
| 115 | struct mt76_connac_sta_key_conf bip; |
| 116 | |
| 117 | -- |
| 118 | 2.18.0 |
| 119 | |