Search Linux Wireless

Re: [PATCH 5/7] wifi: rtw88: Extend rtw_fw_send_ra_info() for RTL8814AU

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 29/01/2025 04:43, Ping-Ke Shih wrote:
> Bitterblue Smith <rtl8821cerfe2@xxxxxxxxx> wrote:
>> On 28/01/2025 07:52, Ping-Ke Shih wrote:
>>> Bitterblue Smith <rtl8821cerfe2@xxxxxxxxx> wrote:
>>>> On 27/01/2025 08:36, Ping-Ke Shih wrote:
>>>>> Bitterblue Smith <rtl8821cerfe2@xxxxxxxxx> wrote:
>>>>>> The existing code is suitable for chips with up to 2 spatial streams.
>>>>>> Inform the firmware about the rates it's allowed to use when
>>>>>> transmitting 3 spatial streams.
>>>>>>
>>>>>> Signed-off-by: Bitterblue Smith <rtl8821cerfe2@xxxxxxxxx>
>>>>>> ---
>>>>>>  drivers/net/wireless/realtek/rtw88/fw.c | 14 ++++++++++++++
>>>>>>  drivers/net/wireless/realtek/rtw88/fw.h |  1 +
>>>>>>  2 files changed, 15 insertions(+)
>>>>>>
>>>>>> diff --git a/drivers/net/wireless/realtek/rtw88/fw.c b/drivers/net/wireless/realtek/rtw88/fw.c
>>>>>> index 02389b7c6876..0ca1b139110d 100644
>>>>>> --- a/drivers/net/wireless/realtek/rtw88/fw.c
>>>>>> +++ b/drivers/net/wireless/realtek/rtw88/fw.c
>>>>>> @@ -735,6 +735,7 @@ void rtw_fw_send_ra_info(struct rtw_dev *rtwdev, struct rtw_sta_info *si,
>>>>>>  {
>>>>>>         u8 h2c_pkt[H2C_PKT_SIZE] = {0};
>>>>>>         bool disable_pt = true;
>>>>>> +       u32 mask_hi;
>>>>>>
>>>>>>         SET_H2C_CMD_ID_CLASS(h2c_pkt, H2C_CMD_RA_INFO);
>>>>>>
>>>>>> @@ -755,6 +756,19 @@ void rtw_fw_send_ra_info(struct rtw_dev *rtwdev, struct rtw_sta_info *si,
>>>>>>         si->init_ra_lv = 0;
>>>>>>
>>>>>>         rtw_fw_send_h2c_command(rtwdev, h2c_pkt);
>>>>>> +
>>>>>> +       if (rtwdev->chip->rf_tbl[RF_PATH_C]) {
>>>>>
>>>>> Using `efuse->hw_cap.nss >= 3` would be consistent with latter patch.
>>>>>
>>>>
>>>> I would like that, but nss is 2 when RTL8814AU is in USB 2 mode.
>>>> I assume this is to keep the current draw under the 500 mA limit
>>>> of USB 2.
>>>>
>>>> What about rtwdev->hal.rf_path_num >= 3 ? I don't remember why
>>>> I didn't do that.
>>>
>>> I think `rtwdev->hal.rf_path_num >= 3` is suitable to initialize/configure
>>> hardware registers, because no matter USB 2 or 3 mode should be the same.
>>>
>>> For this case (RA info), this is related to protocol, so I feel
>>> `efuse->hw_cap.nss >= 3` is suitable, but I have not seen a patch to declare
>>> supported NSS in register_hw(), or I missed it? Or, without RA_INFO_HI,
>>> it gets abnormal rate to RTL8814AU in your test?
>>>
>>
>> You didn't miss it, that will be in part 3. You can see the code here:
>>
>> https://github.com/lwfinger/rtw88/blob/21a3fa7ec11a0cbb3be14145f45cdca35c3d3217/rtw8814a.c#L82
>>
> 
> I feel we should clearly define the meaning. What I thought for 8814AU are:
>  - hal->rf_type: hardware capability. Should be RF_3T3R no matter USB 2 or 3.
>  - hal->antenna_tx: the antenna for current TX. Can be 2 antenna.
>  - hal->antenna_rx: the antenna for current RX. Can be 2 antenna.
>  - efuse->hw_cap.nss: read from efuse. So this will be 3SS for USB 2/3.
> If you have better defnitiion, please share your ideas. 
> 

If efuse->hw_cap.nss is always 3, how to limit the spatial streams
to 2 in USB 2 mode?

> Also, I would want to point the mcs_map implemented in rtw_init_vht_cap().
> 
> 	if (efuse->hw_cap.nss > 1) {
> 		highest = cpu_to_le16(780);
> 		mcs_map |= IEEE80211_VHT_MCS_SUPPORT_0_9 << 2;
> 	}
> 
> This can only support up to 2SS, and I'm not sure if 'efuse->hw_cap.nss' is
> still sutiable for 8814AU.
> 

rtw_init_vht_cap() will be fixed in the next patch set:

https://github.com/lwfinger/rtw88/blob/21a3fa7ec11a0cbb3be14145f45cdca35c3d3217/main.c#L1718

>>
>> With RA_INFO_HI the first C2H_RA_RPT comes at the normal time,
>> before the first CTRL-EVENT-SIGNAL-CHANGE:
> 
> So, how about sending RA_INFO_HI unconditionally for 8814AU
> (just check chip ID as condition)?
> 

I guess that's fine.




[Index of Archives]     [Linux Host AP]     [ATH6KL]     [Linux Wireless Personal Area Network]     [Linux Bluetooth]     [Wireless Regulations]     [Linux Netdev]     [Kernel Newbies]     [Linux Kernel]     [IDE]     [Git]     [Netfilter]     [Bugtraq]     [Yosemite Hiking]     [MIPS Linux]     [ARM Linux]     [Linux RAID]

  Powered by Linux