Message ID | 20221022042728.43015-1-stachecki.tyler@gmail.com (mailing list archive) |
---|---|
State | Awaiting Upstream |
Delegated to: | Netdev Maintainers |
Headers | show |
Series | ath11k: Fix QCN9074 firmware boot on x86 | expand |
Context | Check | Description |
---|---|---|
netdev/tree_selection | success | Not a local patch |
"Tyler J. Stachecki" <stachecki.tyler@gmail.com> writes: > The 2.7.0 series of QCN9074's firmware requests 5 segments > of memory instead of 3 (as in the 2.5.0 series). > > The first segment (11M) is too large to be kalloc'd in one > go on x86 and requires piecemeal 1MB allocations, as was > the case with the prior public firmware (2.5.0, 15M). > > Since f6f92968e1e5, ath11k will break the memory requests, > but only if there were fewer than 3 segments requested by > the firmware. It seems that 5 segments works fine and > allows QCN9074 to boot on x86 with firmware 2.7.0, so > change things accordingly. > > Signed-off-by: Tyler J. Stachecki <stachecki.tyler@gmail.com> Ouch, that's pretty bad. Thanks for fixing this! Does the 2.5.0.1 firmware branch still work with this patch? It's important that we don't break the old firmware.
On Tue, Nov 1, 2022 at 10:46 AM Kalle Valo <kvalo@kernel.org> wrote: > > "Tyler J. Stachecki" <stachecki.tyler@gmail.com> writes: > > > The 2.7.0 series of QCN9074's firmware requests 5 segments > > of memory instead of 3 (as in the 2.5.0 series). > > > > The first segment (11M) is too large to be kalloc'd in one > > go on x86 and requires piecemeal 1MB allocations, as was > > the case with the prior public firmware (2.5.0, 15M). > > > > Since f6f92968e1e5, ath11k will break the memory requests, > > but only if there were fewer than 3 segments requested by > > the firmware. It seems that 5 segments works fine and > > allows QCN9074 to boot on x86 with firmware 2.7.0, so > > change things accordingly. > > > > Signed-off-by: Tyler J. Stachecki <stachecki.tyler@gmail.com> > > Ouch, that's pretty bad. Thanks for fixing this! > > Does the 2.5.0.1 firmware branch still work with this patch? It's > important that we don't break the old firmware. > > -- > https://patchwork.kernel.org/project/linux-wireless/list/ > > https://wireless.wiki.kernel.org/en/developers/documentation/submittingpatches Yep, tested the patch with all 3 combinations, below: QCN9074: WLAN.HK.2.7.0.1-01744-QCAHKSWPL_SILICONZ-1 WLAN.HK.2.5.0.1-01208-QCAHKSWPL_SILICONZ-1 WCN6855: WLAN.HSP.1.1-03125-QCAHSPSWPL_V1_V2_SILICONZ_LITE-3.6510.16
Tyler Stachecki <stachecki.tyler@gmail.com> writes: > On Tue, Nov 1, 2022 at 10:46 AM Kalle Valo <kvalo@kernel.org> wrote: >> >> "Tyler J. Stachecki" <stachecki.tyler@gmail.com> writes: >> >> > The 2.7.0 series of QCN9074's firmware requests 5 segments >> > of memory instead of 3 (as in the 2.5.0 series). >> > >> > The first segment (11M) is too large to be kalloc'd in one >> > go on x86 and requires piecemeal 1MB allocations, as was >> > the case with the prior public firmware (2.5.0, 15M). >> > >> > Since f6f92968e1e5, ath11k will break the memory requests, >> > but only if there were fewer than 3 segments requested by >> > the firmware. It seems that 5 segments works fine and >> > allows QCN9074 to boot on x86 with firmware 2.7.0, so >> > change things accordingly. >> > >> > Signed-off-by: Tyler J. Stachecki <stachecki.tyler@gmail.com> >> >> Ouch, that's pretty bad. Thanks for fixing this! >> >> Does the 2.5.0.1 firmware branch still work with this patch? It's >> important that we don't break the old firmware. >> >> -- >> https://patchwork.kernel.org/project/linux-wireless/list/ >> >> https://wireless.wiki.kernel.org/en/developers/documentation/submittingpatches > > Yep, tested the patch with all 3 combinations, below: > > QCN9074: > WLAN.HK.2.7.0.1-01744-QCAHKSWPL_SILICONZ-1 > WLAN.HK.2.5.0.1-01208-QCAHKSWPL_SILICONZ-1 > > WCN6855: > WLAN.HSP.1.1-03125-QCAHSPSWPL_V1_V2_SILICONZ_LITE-3.6510.16 Excellent, I'll add Tested-on tags for these. Thank you again.
Kalle Valo <kvalo@kernel.org> writes: > Tyler Stachecki <stachecki.tyler@gmail.com> writes: > >> On Tue, Nov 1, 2022 at 10:46 AM Kalle Valo <kvalo@kernel.org> wrote: >>> >>> "Tyler J. Stachecki" <stachecki.tyler@gmail.com> writes: >>> >>> > The 2.7.0 series of QCN9074's firmware requests 5 segments >>> > of memory instead of 3 (as in the 2.5.0 series). >>> > >>> > The first segment (11M) is too large to be kalloc'd in one >>> > go on x86 and requires piecemeal 1MB allocations, as was >>> > the case with the prior public firmware (2.5.0, 15M). >>> > >>> > Since f6f92968e1e5, ath11k will break the memory requests, >>> > but only if there were fewer than 3 segments requested by >>> > the firmware. It seems that 5 segments works fine and >>> > allows QCN9074 to boot on x86 with firmware 2.7.0, so >>> > change things accordingly. >>> > >>> > Signed-off-by: Tyler J. Stachecki <stachecki.tyler@gmail.com> >>> >>> Ouch, that's pretty bad. Thanks for fixing this! >>> >>> Does the 2.5.0.1 firmware branch still work with this patch? It's >>> important that we don't break the old firmware. >>> >>> -- >>> https://patchwork.kernel.org/project/linux-wireless/list/ >>> >>> https://wireless.wiki.kernel.org/en/developers/documentation/submittingpatches >> >> Yep, tested the patch with all 3 combinations, below: >> >> QCN9074: >> WLAN.HK.2.7.0.1-01744-QCAHKSWPL_SILICONZ-1 >> WLAN.HK.2.5.0.1-01208-QCAHKSWPL_SILICONZ-1 >> >> WCN6855: >> WLAN.HSP.1.1-03125-QCAHSPSWPL_V1_V2_SILICONZ_LITE-3.6510.16 > > Excellent, I'll add Tested-on tags for these. Thank you again. I'll think I'll queue this to v6.1, it's an important fix to have.
"Tyler J. Stachecki" <stachecki.tyler@gmail.com> wrote: > The 2.7.0 series of QCN9074's firmware requests 5 segments > of memory instead of 3 (as in the 2.5.0 series). > > The first segment (11M) is too large to be kalloc'd in one > go on x86 and requires piecemeal 1MB allocations, as was > the case with the prior public firmware (2.5.0, 15M). > > Since f6f92968e1e5, ath11k will break the memory requests, > but only if there were fewer than 3 segments requested by > the firmware. It seems that 5 segments works fine and > allows QCN9074 to boot on x86 with firmware 2.7.0, so > change things accordingly. > > Tested-on: QCN9074 hw1.0 PCI WLAN.HK.2.7.0.1-01744-QCAHKSWPL_SILICONZ-1 > Tested-on: QCN9074 hw1.0 PCI WLAN.HK.2.5.0.1-01208-QCAHKSWPL_SILICONZ-1 > Tested-on: WCN6855 hw2.0 PCI WLAN.HSP.1.1-03125-QCAHSPSWPL_V1_V2_SILICONZ_LITE-3.6510.16 > > Signed-off-by: Tyler J. Stachecki <stachecki.tyler@gmail.com> > Signed-off-by: Kalle Valo <quic_kvalo@quicinc.com> Patch applied to ath-current branch of ath.git, thanks. 3a89b6dec992 wifi: ath11k: Fix QCN9074 firmware boot on x86
diff --git a/drivers/net/wireless/ath/ath11k/qmi.h b/drivers/net/wireless/ath/ath11k/qmi.h index 2ec56a34fa81..0909d53cefeb 100644 --- a/drivers/net/wireless/ath/ath11k/qmi.h +++ b/drivers/net/wireless/ath/ath11k/qmi.h @@ -27,7 +27,7 @@ #define ATH11K_QMI_WLANFW_MAX_NUM_MEM_SEG_V01 52 #define ATH11K_QMI_CALDB_SIZE 0x480000 #define ATH11K_QMI_BDF_EXT_STR_LENGTH 0x20 -#define ATH11K_QMI_FW_MEM_REQ_SEGMENT_CNT 3 +#define ATH11K_QMI_FW_MEM_REQ_SEGMENT_CNT 5 #define QMI_WLFW_REQUEST_MEM_IND_V01 0x0035 #define QMI_WLFW_FW_MEM_READY_IND_V01 0x0037
The 2.7.0 series of QCN9074's firmware requests 5 segments of memory instead of 3 (as in the 2.5.0 series). The first segment (11M) is too large to be kalloc'd in one go on x86 and requires piecemeal 1MB allocations, as was the case with the prior public firmware (2.5.0, 15M). Since f6f92968e1e5, ath11k will break the memory requests, but only if there were fewer than 3 segments requested by the firmware. It seems that 5 segments works fine and allows QCN9074 to boot on x86 with firmware 2.7.0, so change things accordingly. Signed-off-by: Tyler J. Stachecki <stachecki.tyler@gmail.com> --- drivers/net/wireless/ath/ath11k/qmi.h | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-)