[PATCH ath-next v1] wifi: ath11k: Fix failure to connect to a 6 GHz AP
Baochen Qiang
baochen.qiang at oss.qualcomm.com
Wed Jan 7 00:31:08 PST 2026
On 1/7/2026 4:23 PM, Baochen Qiang wrote:
>
>
> On 1/7/2026 2:02 PM, Qian Zhang wrote:
>> STA fails to connect to a 6 GHz AP with the following errors:
>> ath11k_pci 0000:01:00.0: failed to handle chan list with power type 1
>> wlp1s0: deauthenticating from c8:a3:e8:dd:41:e3 by local choice (Reason: 3=DEAUTH_LEAVING)
>>
>> ath11k_reg_handle_chan_list() treats the update as redundant and
>> returns -EINVAL. That causes the connection attempt to fail.
>>
>> Avoid unnecessary validation during association. Apply the regulatory
>> redundant check only when the power type is IEEE80211_REG_UNSET_AP,
>> which only occurs during core initialization.
>>
>> Tested-on: WCN6855 hw2.1 PCI WLAN.HSP.1.1-03125-QCAHSPSWPL_V1_V2_SILICONZ_LITE-3.6510.41
>>
>> Signed-off-by: Qian Zhang <qian.zhang at oss.qualcomm.com>
>> ---
>> drivers/net/wireless/ath/ath11k/reg.c | 9 ++++++---
>> 1 file changed, 6 insertions(+), 3 deletions(-)
>>
>> diff --git a/drivers/net/wireless/ath/ath11k/reg.c b/drivers/net/wireless/ath/ath11k/reg.c
>> index d62a2014315a..8786ca3870fc 100644
>> --- a/drivers/net/wireless/ath/ath11k/reg.c
>> +++ b/drivers/net/wireless/ath/ath11k/reg.c
>> @@ -1,7 +1,7 @@
>> // SPDX-License-Identifier: BSD-3-Clause-Clear
>> /*
>> * Copyright (c) 2018-2019 The Linux Foundation. All rights reserved.
>> - * Copyright (c) 2021-2025 Qualcomm Innovation Center, Inc. All rights reserved.
>> + * Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.
>> */
>> #include <linux/rtnetlink.h>
>>
>> @@ -926,8 +926,11 @@ int ath11k_reg_handle_chan_list(struct ath11k_base *ab,
>> */
>> if (ab->default_regd[pdev_idx] && !ab->new_regd[pdev_idx] &&
>> !memcmp((char *)ab->default_regd[pdev_idx]->alpha2,
>> - (char *)reg_info->alpha2, 2))
>> - goto retfail;
>> + (char *)reg_info->alpha2, 2)) {
>> + if (power_type == IEEE80211_REG_UNSET_AP)
>> + ath11k_reg_reset_info(reg_info);
>> + return 0;
>> + }
>>
>> /* Intersect new rules with default regd if a new country setting was
>> * requested, i.e a default regd was already set during initialization
>>
>> base-commit: e33fc1c6d54ee1569a57255e11c2978ba9a42ffc
>
> Reviewed-by: Baochen Qiang <baochen.qiang at oss.qualcomm.com>
Withdraw my above tag as the code has some issues.
We should only return in IEEE80211_REG_UNSET_AP cases. For other types we should go on to
build a new regdomain.
>
More information about the ath11k
mailing list