developer | 70180b0 | 2023-11-14 17:01:47 +0800 | [diff] [blame^] | 1 | From 14b505d62c856f210ce46e831886ae0fab253252 Mon Sep 17 00:00:00 2001 |
| 2 | From: StanleyYP Wang <StanleyYP.Wang@mediatek.com> |
| 3 | Date: Tue, 31 Oct 2023 16:29:13 +0800 |
| 4 | Subject: [PATCH] wifi: mt76: testmode: add cheetah support |
| 5 | |
| 6 | Signed-off-by: StanleyYP Wang <StanleyYP.Wang@mediatek.com> |
| 7 | --- |
| 8 | mt7915/eeprom.c | 3 +-- |
| 9 | mt7915/eeprom.h | 12 ++++++++++++ |
| 10 | mt7915/mcu.c | 21 +++++++++++++++++++-- |
| 11 | mt7915/testmode.c | 9 +++++---- |
| 12 | 4 files changed, 37 insertions(+), 8 deletions(-) |
| 13 | |
| 14 | diff --git a/mt7915/eeprom.c b/mt7915/eeprom.c |
| 15 | index f8166dd..50ed7ba 100644 |
| 16 | --- a/mt7915/eeprom.c |
| 17 | +++ b/mt7915/eeprom.c |
| 18 | @@ -39,8 +39,7 @@ static int mt7915_eeprom_load_precal(struct mt7915_dev *dev) |
| 19 | if (!dev->flash_mode || !val) |
| 20 | return 0; |
| 21 | |
| 22 | - size = mt7915_get_cal_group_size(dev) + |
| 23 | - (is_mt7915(&dev->mt76) ? MT_EE_CAL_DPD_SIZE_V1 : MT_EE_CAL_DPD_SIZE_V2); |
| 24 | + size = mt7915_get_cal_group_size(dev) + mt7915_get_cal_dpd_size(dev); |
| 25 | |
| 26 | dev->cal = devm_kzalloc(mdev->dev, size, GFP_KERNEL); |
| 27 | if (!dev->cal) |
| 28 | diff --git a/mt7915/eeprom.h b/mt7915/eeprom.h |
| 29 | index a1ab05a..99101f9 100644 |
| 30 | --- a/mt7915/eeprom.h |
| 31 | +++ b/mt7915/eeprom.h |
| 32 | @@ -52,6 +52,7 @@ enum mt7915_eeprom_field { |
| 33 | #define MT_EE_CAL_GROUP_SIZE_7916_6G (94 * MT_EE_CAL_UNIT + 16) |
| 34 | #define MT_EE_CAL_DPD_SIZE_V1 (54 * MT_EE_CAL_UNIT) |
| 35 | #define MT_EE_CAL_DPD_SIZE_V2 (300 * MT_EE_CAL_UNIT) |
| 36 | +#define MT_EE_CAL_DPD_SIZE_V2_7981 (102 * MT_EE_CAL_UNIT) /* no 6g dpd data */ |
| 37 | |
| 38 | #define MT_EE_WIFI_CONF0_TX_PATH GENMASK(2, 0) |
| 39 | #define MT_EE_WIFI_CONF0_BAND_SEL GENMASK(7, 6) |
| 40 | @@ -192,6 +193,17 @@ mt7915_get_cal_group_size(struct mt7915_dev *dev) |
| 41 | } |
| 42 | } |
| 43 | |
| 44 | +static inline u32 |
| 45 | +mt7915_get_cal_dpd_size(struct mt7915_dev *dev) |
| 46 | +{ |
| 47 | + if (is_mt7915(&dev->mt76)) |
| 48 | + return MT_EE_CAL_DPD_SIZE_V1; |
| 49 | + else if (is_mt7981(&dev->mt76)) |
| 50 | + return MT_EE_CAL_DPD_SIZE_V2_7981; |
| 51 | + else |
| 52 | + return MT_EE_CAL_DPD_SIZE_V2; |
| 53 | +} |
| 54 | + |
| 55 | extern const u8 mt7915_sku_group_len[MAX_SKU_RATE_GROUP_NUM]; |
| 56 | |
| 57 | #endif |
| 58 | diff --git a/mt7915/mcu.c b/mt7915/mcu.c |
| 59 | index cd4f472..492cfcd 100644 |
| 60 | --- a/mt7915/mcu.c |
| 61 | +++ b/mt7915/mcu.c |
| 62 | @@ -3035,13 +3035,30 @@ static int mt7915_dpd_freq_idx(struct mt7915_dev *dev, u16 freq, u8 bw) |
| 63 | /* 5G BW160 */ |
| 64 | 5250, 5570, 5815 |
| 65 | }; |
| 66 | + const u16 freq_list_v2_7981[] = { |
| 67 | + /* 5G BW20 */ |
| 68 | + 5180, 5200, 5220, 5240, |
| 69 | + 5260, 5280, 5300, 5320, |
| 70 | + 5500, 5520, 5540, 5560, |
| 71 | + 5580, 5600, 5620, 5640, |
| 72 | + 5660, 5680, 5700, 5720, |
| 73 | + 5745, 5765, 5785, 5805, |
| 74 | + 5825, 5845, 5865, 5885, |
| 75 | + /* 5G BW160 */ |
| 76 | + 5250, 5570, 5815 |
| 77 | + }; |
| 78 | const u16 *freq_list = freq_list_v1; |
| 79 | int n_freqs = ARRAY_SIZE(freq_list_v1); |
| 80 | int idx; |
| 81 | |
| 82 | if (!is_mt7915(&dev->mt76)) { |
| 83 | - freq_list = freq_list_v2; |
| 84 | - n_freqs = ARRAY_SIZE(freq_list_v2); |
| 85 | + if (is_mt7981(&dev->mt76)) { |
| 86 | + freq_list = freq_list_v2_7981; |
| 87 | + n_freqs = ARRAY_SIZE(freq_list_v2_7981); |
| 88 | + } else { |
| 89 | + freq_list = freq_list_v2; |
| 90 | + n_freqs = ARRAY_SIZE(freq_list_v2); |
| 91 | + } |
| 92 | } |
| 93 | |
| 94 | if (freq < 4000) { |
| 95 | diff --git a/mt7915/testmode.c b/mt7915/testmode.c |
| 96 | index 5e20cb9..4aa7eb6 100644 |
| 97 | --- a/mt7915/testmode.c |
| 98 | +++ b/mt7915/testmode.c |
| 99 | @@ -2149,7 +2149,7 @@ mt7915_tm_group_prek(struct mt7915_phy *phy, enum mt76_testmode_state state) |
| 100 | eeprom = mdev->eeprom.data; |
| 101 | dev->cur_prek_offset = 0; |
| 102 | group_size = mt7915_get_cal_group_size(dev); |
| 103 | - dpd_size = is_mt7915(&dev->mt76) ? MT_EE_CAL_DPD_SIZE_V1 : MT_EE_CAL_DPD_SIZE_V2; |
| 104 | + dpd_size = mt7915_get_cal_dpd_size(dev); |
| 105 | size = group_size + dpd_size; |
| 106 | offs = is_mt7915(&dev->mt76) ? MT_EE_DO_PRE_CAL : MT_EE_DO_PRE_CAL_V2; |
| 107 | |
| 108 | @@ -2231,11 +2231,11 @@ mt7915_tm_dpd_prek(struct mt7915_phy *phy, enum mt76_testmode_state state) |
| 109 | eeprom = mdev->eeprom.data; |
| 110 | dev->cur_prek_offset = 0; |
| 111 | group_size = mt7915_get_cal_group_size(dev); |
| 112 | + dpd_size = mt7915_get_cal_dpd_size(dev); |
| 113 | dev->dpd_chan_num_2g = hweight32(DPD_2G_CH_BW20_BITMAP_0); |
| 114 | if (is_mt7915(&dev->mt76)) { |
| 115 | dev->dpd_chan_num_5g = hweight32(DPD_5G_CH_BW20_BITMAP_7915_0); |
| 116 | dev->dpd_chan_num_6g = 0; |
| 117 | - dpd_size = MT_EE_CAL_DPD_SIZE_V1; |
| 118 | offs = MT_EE_DO_PRE_CAL; |
| 119 | } else { |
| 120 | dev->dpd_chan_num_5g = hweight32(DPD_5G_CH_BW20_BITMAP_0) + |
| 121 | @@ -2244,7 +2244,8 @@ mt7915_tm_dpd_prek(struct mt7915_phy *phy, enum mt76_testmode_state state) |
| 122 | dev->dpd_chan_num_6g = hweight32(DPD_6G_CH_BW20_BITMAP_0) + |
| 123 | hweight32(DPD_6G_CH_BW20_BITMAP_1) + |
| 124 | ARRAY_SIZE(bw160_6g_freq); |
| 125 | - dpd_size = MT_EE_CAL_DPD_SIZE_V2; |
| 126 | + if (is_mt7981(&dev->mt76)) |
| 127 | + dev->dpd_chan_num_6g = 0; |
| 128 | offs = MT_EE_DO_PRE_CAL_V2; |
| 129 | } |
| 130 | size = group_size + dpd_size; |
| 131 | @@ -2707,7 +2708,7 @@ mt7915_tm_dump_precal(struct mt76_phy *mphy, struct sk_buff *msg, int flag, int |
| 132 | } |
| 133 | |
| 134 | group_size = mt7915_get_cal_group_size(dev); |
| 135 | - dpd_size = is_mt7915(&dev->mt76) ? MT_EE_CAL_DPD_SIZE_V1 : MT_EE_CAL_DPD_SIZE_V2; |
| 136 | + dpd_size = mt7915_get_cal_dpd_size(dev); |
| 137 | dpd_per_chan_size = is_mt7915(&dev->mt76) ? 2 : 3; |
| 138 | total_size = group_size + dpd_size; |
| 139 | pre_cal = dev->cal; |
| 140 | -- |
| 141 | 2.18.0 |
| 142 | |