mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-12 07:53:07 +00:00
6bcd1c2501
Some local patches have been sent to upstream and they are slightly different from the upstream version. So it's better to replace them to avoid conflicts with the new mac80211 backport driver. The different parts have been merged into patch 996. This commit also includes some additional fixes: * Fix watchdog function. * Improve MT7620 register initialization. * Introduce DMA busy watchdog for rt2800. P.S. Sometimes rt2800 series chips may fall into a DMA busy state. The tx queues become very slow and the client cannot connect to the AP. Usually, We can see a lot of hostapd warnings at this point: 'hostapd: IEEE 802.11: did not acknowledge authentication response' The DMA busy watchdog can help the driver automatically recover from this abnormal state. By the way, setting higer 'cell_density' and disabling 'disassoc_low_ack' can significantly reduce the probability of the DMA busy. Signed-off-by: Shiji Yang <yangshiji66@qq.com>
147 lines
5.2 KiB
Diff
147 lines
5.2 KiB
Diff
From a28533c6be1711584bf3ec978309d5c590029821 Mon Sep 17 00:00:00 2001
|
|
From: Shiji Yang <yangshiji66@outlook.com>
|
|
Date: Thu, 19 Oct 2023 19:58:57 +0800
|
|
Subject: wifi: rt2x00: rework MT7620 channel config function
|
|
|
|
1. Move the channel configuration code from rt2800_vco_calibration()
|
|
to the rt2800_config_channel().
|
|
2. Use MT7620 SoC specific AGC initial LNA value instead of the
|
|
RT5592's value.
|
|
3. BBP{195,196} pairing write has been replaced with
|
|
rt2800_bbp_glrt_write() to reduce redundant code.
|
|
|
|
Signed-off-by: Shiji Yang <yangshiji66@outlook.com>
|
|
Acked-by: Stanislaw Gruszka <stf_xl@wp.pl>
|
|
Signed-off-by: Kalle Valo <kvalo@kernel.org>
|
|
Link: https://lore.kernel.org/r/TYAP286MB0315622A4340BFFA530B1B86BCD4A@TYAP286MB0315.JPNP286.PROD.OUTLOOK.COM
|
|
---
|
|
drivers/net/wireless/ralink/rt2x00/rt2800lib.c | 91 ++++++++++----------------
|
|
1 file changed, 35 insertions(+), 56 deletions(-)
|
|
|
|
--- a/drivers/net/wireless/ralink/rt2x00/rt2800lib.c
|
|
+++ b/drivers/net/wireless/ralink/rt2x00/rt2800lib.c
|
|
@@ -3861,14 +3861,6 @@ static void rt2800_config_channel_rf7620
|
|
rfcsr |= tx_agc_fc;
|
|
rt2800_rfcsr_write_bank(rt2x00dev, 7, 59, rfcsr);
|
|
}
|
|
-
|
|
- if (conf_is_ht40(conf)) {
|
|
- rt2800_bbp_glrt_write(rt2x00dev, 141, 0x10);
|
|
- rt2800_bbp_glrt_write(rt2x00dev, 157, 0x2f);
|
|
- } else {
|
|
- rt2800_bbp_glrt_write(rt2x00dev, 141, 0x1a);
|
|
- rt2800_bbp_glrt_write(rt2x00dev, 157, 0x40);
|
|
- }
|
|
}
|
|
|
|
static void rt2800_config_alc_rt6352(struct rt2x00_dev *rt2x00dev,
|
|
@@ -4437,32 +4429,46 @@ static void rt2800_config_channel(struct
|
|
usleep_range(1000, 1500);
|
|
}
|
|
|
|
- if (rt2x00_rt(rt2x00dev, RT5592) || rt2x00_rt(rt2x00dev, RT6352)) {
|
|
- reg = 0x10;
|
|
- if (!conf_is_ht40(conf)) {
|
|
- if (rt2x00_rt(rt2x00dev, RT6352) &&
|
|
- rt2x00_has_cap_external_lna_bg(rt2x00dev)) {
|
|
- reg |= 0x5;
|
|
- } else {
|
|
- reg |= 0xa;
|
|
- }
|
|
- }
|
|
- rt2800_bbp_write(rt2x00dev, 195, 141);
|
|
- rt2800_bbp_write(rt2x00dev, 196, reg);
|
|
+ if (rt2x00_rt(rt2x00dev, RT5592)) {
|
|
+ bbp = conf_is_ht40(conf) ? 0x10 : 0x1a;
|
|
+ rt2800_bbp_glrt_write(rt2x00dev, 141, bbp);
|
|
|
|
- /* AGC init.
|
|
- * Despite the vendor driver using different values here for
|
|
- * RT6352 chip, we use 0x1c for now. This may have to be changed
|
|
- * once TSSI got implemented.
|
|
- */
|
|
- reg = (rf->channel <= 14 ? 0x1c : 0x24) + 2*rt2x00dev->lna_gain;
|
|
- rt2800_bbp_write_with_rx_chain(rt2x00dev, 66, reg);
|
|
+ bbp = (rf->channel <= 14 ? 0x1c : 0x24) + 2 * rt2x00dev->lna_gain;
|
|
+ rt2800_bbp_write_with_rx_chain(rt2x00dev, 66, bbp);
|
|
|
|
- if (rt2x00_rt(rt2x00dev, RT5592))
|
|
- rt2800_iq_calibrate(rt2x00dev, rf->channel);
|
|
+ rt2800_iq_calibrate(rt2x00dev, rf->channel);
|
|
}
|
|
|
|
if (rt2x00_rt(rt2x00dev, RT6352)) {
|
|
+ /* BBP for GLRT BW */
|
|
+ bbp = conf_is_ht40(conf) ?
|
|
+ 0x10 : rt2x00_has_cap_external_lna_bg(rt2x00dev) ?
|
|
+ 0x15 : 0x1a;
|
|
+ rt2800_bbp_glrt_write(rt2x00dev, 141, bbp);
|
|
+
|
|
+ bbp = conf_is_ht40(conf) ? 0x2f : 0x40;
|
|
+ rt2800_bbp_glrt_write(rt2x00dev, 157, bbp);
|
|
+
|
|
+ if (rt2x00dev->default_ant.rx_chain_num == 1) {
|
|
+ rt2800_bbp_write(rt2x00dev, 91, 0x07);
|
|
+ rt2800_bbp_write(rt2x00dev, 95, 0x1a);
|
|
+ rt2800_bbp_glrt_write(rt2x00dev, 128, 0xa0);
|
|
+ rt2800_bbp_glrt_write(rt2x00dev, 170, 0x12);
|
|
+ rt2800_bbp_glrt_write(rt2x00dev, 171, 0x10);
|
|
+ } else {
|
|
+ rt2800_bbp_write(rt2x00dev, 91, 0x06);
|
|
+ rt2800_bbp_write(rt2x00dev, 95, 0x9a);
|
|
+ rt2800_bbp_glrt_write(rt2x00dev, 128, 0xe0);
|
|
+ rt2800_bbp_glrt_write(rt2x00dev, 170, 0x30);
|
|
+ rt2800_bbp_glrt_write(rt2x00dev, 171, 0x30);
|
|
+ }
|
|
+
|
|
+ /* AGC init */
|
|
+ bbp = rf->channel <= 14 ? 0x04 + 2 * rt2x00dev->lna_gain : 0;
|
|
+ rt2800_bbp_write_with_rx_chain(rt2x00dev, 66, bbp);
|
|
+
|
|
+ usleep_range(1000, 1500);
|
|
+
|
|
if (test_bit(CAPABILITY_EXTERNAL_PA_TX0,
|
|
&rt2x00dev->cap_flags)) {
|
|
reg = rt2800_register_read(rt2x00dev, RF_CONTROL3);
|
|
@@ -5608,26 +5614,6 @@ void rt2800_vco_calibration(struct rt2x0
|
|
rt2800_register_write(rt2x00dev, TX_PIN_CFG, tx_pin);
|
|
|
|
if (rt2x00_rt(rt2x00dev, RT6352)) {
|
|
- if (rt2x00dev->default_ant.rx_chain_num == 1) {
|
|
- rt2800_bbp_write(rt2x00dev, 91, 0x07);
|
|
- rt2800_bbp_write(rt2x00dev, 95, 0x1A);
|
|
- rt2800_bbp_write(rt2x00dev, 195, 128);
|
|
- rt2800_bbp_write(rt2x00dev, 196, 0xA0);
|
|
- rt2800_bbp_write(rt2x00dev, 195, 170);
|
|
- rt2800_bbp_write(rt2x00dev, 196, 0x12);
|
|
- rt2800_bbp_write(rt2x00dev, 195, 171);
|
|
- rt2800_bbp_write(rt2x00dev, 196, 0x10);
|
|
- } else {
|
|
- rt2800_bbp_write(rt2x00dev, 91, 0x06);
|
|
- rt2800_bbp_write(rt2x00dev, 95, 0x9A);
|
|
- rt2800_bbp_write(rt2x00dev, 195, 128);
|
|
- rt2800_bbp_write(rt2x00dev, 196, 0xE0);
|
|
- rt2800_bbp_write(rt2x00dev, 195, 170);
|
|
- rt2800_bbp_write(rt2x00dev, 196, 0x30);
|
|
- rt2800_bbp_write(rt2x00dev, 195, 171);
|
|
- rt2800_bbp_write(rt2x00dev, 196, 0x30);
|
|
- }
|
|
-
|
|
if (rt2x00_has_cap_external_lna_bg(rt2x00dev)) {
|
|
rt2800_bbp_write(rt2x00dev, 75, 0x68);
|
|
rt2800_bbp_write(rt2x00dev, 76, 0x4C);
|
|
@@ -5635,13 +5621,6 @@ void rt2800_vco_calibration(struct rt2x0
|
|
rt2800_bbp_write(rt2x00dev, 80, 0x0C);
|
|
rt2800_bbp_write(rt2x00dev, 82, 0xB6);
|
|
}
|
|
-
|
|
- /* On 11A, We should delay and wait RF/BBP to be stable
|
|
- * and the appropriate time should be 1000 micro seconds
|
|
- * 2005/06/05 - On 11G, we also need this delay time.
|
|
- * Otherwise it's difficult to pass the WHQL.
|
|
- */
|
|
- usleep_range(1000, 1500);
|
|
}
|
|
}
|
|
EXPORT_SYMBOL_GPL(rt2800_vco_calibration);
|