linux-wireless.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH 1/2] wifi: rtw88: 8822c: Fix reported RX band width
@ 2024-07-21 22:53 Bitterblue Smith
  2024-07-21 22:55 ` [PATCH 2/2] wifi: rtw88: 8703b: " Bitterblue Smith
  0 siblings, 1 reply; 5+ messages in thread
From: Bitterblue Smith @ 2024-07-21 22:53 UTC (permalink / raw)
  To: linux-wireless@vger.kernel.org; +Cc: Ping-Ke Shih

"iw dev wlp2s0 station dump" shows incorrect rx bitrate:

tx bitrate:     866.7 MBit/s VHT-MCS 9 80MHz short GI VHT-NSS 2
rx bitrate:     86.7 MBit/s VHT-MCS 9 VHT-NSS 1

This is because the RX band width is calculated incorrectly. Fix the
calculation according to the phydm_rxsc_2_bw() function from the
official drivers.

After:

tx bitrate:     866.7 MBit/s VHT-MCS 9 80MHz short GI VHT-NSS 2
rx bitrate:     390.0 MBit/s VHT-MCS 9 80MHz VHT-NSS 1

It also works correctly with the AP configured for 20 MHz and 40 MHz.

Tested with RTL8822CE.

Cc: stable@vger.kernel.org
Signed-off-by: Bitterblue Smith <rtl8821cerfe2@gmail.com>
---
 drivers/net/wireless/realtek/rtw88/rtw8822c.c | 10 ++++++----
 1 file changed, 6 insertions(+), 4 deletions(-)

diff --git a/drivers/net/wireless/realtek/rtw88/rtw8822c.c b/drivers/net/wireless/realtek/rtw88/rtw8822c.c
index bc807b13e9ce..e265a35184ab 100644
--- a/drivers/net/wireless/realtek/rtw88/rtw8822c.c
+++ b/drivers/net/wireless/realtek/rtw88/rtw8822c.c
@@ -2612,12 +2612,14 @@ static void query_phy_status_page1(struct rtw_dev *rtwdev, u8 *phy_status,
 	else
 		rxsc = GET_PHY_STAT_P1_HT_RXSC(phy_status);
 
-	if (rxsc >= 9 && rxsc <= 12)
+	if (rxsc == 0)
+		bw = rtwdev->hal.current_band_width;
+	else if (rxsc >= 1 && rxsc <= 8)
+		bw = RTW_CHANNEL_WIDTH_20;
+	else if (rxsc >= 9 && rxsc <= 12)
 		bw = RTW_CHANNEL_WIDTH_40;
-	else if (rxsc >= 13)
-		bw = RTW_CHANNEL_WIDTH_80;
 	else
-		bw = RTW_CHANNEL_WIDTH_20;
+		bw = RTW_CHANNEL_WIDTH_80;
 
 	channel = GET_PHY_STAT_P1_CHANNEL(phy_status);
 	rtw_set_rx_freq_band(pkt_stat, channel);
-- 
2.45.2


^ permalink raw reply related	[flat|nested] 5+ messages in thread

* [PATCH 2/2] wifi: rtw88: 8703b: Fix reported RX band width
  2024-07-21 22:53 [PATCH 1/2] wifi: rtw88: 8822c: Fix reported RX band width Bitterblue Smith
@ 2024-07-21 22:55 ` Bitterblue Smith
  2024-07-22  3:39   ` Ping-Ke Shih
  0 siblings, 1 reply; 5+ messages in thread
From: Bitterblue Smith @ 2024-07-21 22:55 UTC (permalink / raw)
  To: linux-wireless@vger.kernel.org; +Cc: Ping-Ke Shih, Fiona Klute

The definition of GET_RX_DESC_BW is incorrect. Fix it according to the
GET_RX_STATUS_DESC_BW_8703B macro from the official driver.

Tested only with RTL8812AU, which uses the same bits.

Cc: stable@vger.kernel.org
Signed-off-by: Bitterblue Smith <rtl8821cerfe2@gmail.com>
---
 drivers/net/wireless/realtek/rtw88/rx.h | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/drivers/net/wireless/realtek/rtw88/rx.h b/drivers/net/wireless/realtek/rtw88/rx.h
index d3668c4efc24..8a072dd3d73c 100644
--- a/drivers/net/wireless/realtek/rtw88/rx.h
+++ b/drivers/net/wireless/realtek/rtw88/rx.h
@@ -41,7 +41,7 @@ enum rtw_rx_desc_enc {
 #define GET_RX_DESC_TSFL(rxdesc)                                               \
 	le32_get_bits(*((__le32 *)(rxdesc) + 0x05), GENMASK(31, 0))
 #define GET_RX_DESC_BW(rxdesc)                                                 \
-	(le32_get_bits(*((__le32 *)(rxdesc) + 0x04), GENMASK(31, 24)))
+	(le32_get_bits(*((__le32 *)(rxdesc) + 0x04), GENMASK(5, 4)))
 
 void rtw_rx_stats(struct rtw_dev *rtwdev, struct ieee80211_vif *vif,
 		  struct sk_buff *skb);
-- 
2.45.2



^ permalink raw reply related	[flat|nested] 5+ messages in thread

* RE: [PATCH 2/2] wifi: rtw88: 8703b: Fix reported RX band width
  2024-07-21 22:55 ` [PATCH 2/2] wifi: rtw88: 8703b: " Bitterblue Smith
@ 2024-07-22  3:39   ` Ping-Ke Shih
  2024-07-22 11:07     ` Bitterblue Smith
  0 siblings, 1 reply; 5+ messages in thread
From: Ping-Ke Shih @ 2024-07-22  3:39 UTC (permalink / raw)
  To: Bitterblue Smith, linux-wireless@vger.kernel.org; +Cc: Fiona Klute

Bitterblue Smith <rtl8821cerfe2@gmail.com> wrote:
> The definition of GET_RX_DESC_BW is incorrect. Fix it according to the
> GET_RX_STATUS_DESC_BW_8703B macro from the official driver.
> 
> Tested only with RTL8812AU, which uses the same bits.
> 
> Cc: stable@vger.kernel.org

Add a Fixes tag? as well as patch 1/2. 
Otherwise looks good to me. 

> Signed-off-by: Bitterblue Smith <rtl8821cerfe2@gmail.com>



^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: [PATCH 2/2] wifi: rtw88: 8703b: Fix reported RX band width
  2024-07-22  3:39   ` Ping-Ke Shih
@ 2024-07-22 11:07     ` Bitterblue Smith
  2024-07-23  1:27       ` Ping-Ke Shih
  0 siblings, 1 reply; 5+ messages in thread
From: Bitterblue Smith @ 2024-07-22 11:07 UTC (permalink / raw)
  To: Ping-Ke Shih, linux-wireless@vger.kernel.org; +Cc: Fiona Klute

On 22/07/2024 06:39, Ping-Ke Shih wrote:
> Bitterblue Smith <rtl8821cerfe2@gmail.com> wrote:
>> The definition of GET_RX_DESC_BW is incorrect. Fix it according to the
>> GET_RX_STATUS_DESC_BW_8703B macro from the official driver.
>>
>> Tested only with RTL8812AU, which uses the same bits.
>>
>> Cc: stable@vger.kernel.org
> 
> Add a Fixes tag? as well as patch 1/2. 
> Otherwise looks good to me. 
> 
>> Signed-off-by: Bitterblue Smith <rtl8821cerfe2@gmail.com>
> 
> 

Done.

By the way, there is another problem with the RX rate: rtw88
doesn't report if short guard interval was used. The older
chips like RTL8703B have the sgi_en bit in the PHY status
struct, but I couldn't find out how the newer chips do it.

^ permalink raw reply	[flat|nested] 5+ messages in thread

* RE: [PATCH 2/2] wifi: rtw88: 8703b: Fix reported RX band width
  2024-07-22 11:07     ` Bitterblue Smith
@ 2024-07-23  1:27       ` Ping-Ke Shih
  0 siblings, 0 replies; 5+ messages in thread
From: Ping-Ke Shih @ 2024-07-23  1:27 UTC (permalink / raw)
  To: Bitterblue Smith, linux-wireless@vger.kernel.org; +Cc: Fiona Klute

Bitterblue Smith <rtl8821cerfe2@gmail.com> wrote:
> By the way, there is another problem with the RX rate: rtw88
> doesn't report if short guard interval was used. The older
> chips like RTL8703B have the sgi_en bit in the PHY status
> struct, but I couldn't find out how the newer chips do it.

The newer chips don't have that bit for RX.



^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2024-07-23  1:27 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-07-21 22:53 [PATCH 1/2] wifi: rtw88: 8822c: Fix reported RX band width Bitterblue Smith
2024-07-21 22:55 ` [PATCH 2/2] wifi: rtw88: 8703b: " Bitterblue Smith
2024-07-22  3:39   ` Ping-Ke Shih
2024-07-22 11:07     ` Bitterblue Smith
2024-07-23  1:27       ` Ping-Ke Shih

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).