]> www.infradead.org Git - users/jedix/linux-maple.git/commit
wifi: ath12k: add panic handler
authorBaochen Qiang <quic_bqiang@quicinc.com>
Thu, 30 May 2024 15:56:52 +0000 (18:56 +0300)
committerKalle Valo <quic_kvalo@quicinc.com>
Mon, 3 Jun 2024 13:11:38 +0000 (16:11 +0300)
commit809055628bce824b7fe18331abb65e44d02b0ecf
tree476f7a3ccc18721e8081e7e90ef1a80c1ccadce6
parent8233d2716570b66ab45b6d24e577ee6612002dc4
wifi: ath12k: add panic handler

Currently for ath12k PCI devices, firmware could be running in one of
several execution environments, e.g., PBL, SBL and mission mode etc. Among
which PBL is the only stage where PCIe link negotiation could happen. So
normally firmware runs in PBL in order to be enumerated during system reboot.

However it might not work in kernel crash scenario: ath12k target is not
found after warm reboot from kernel crash. This is because when kernel crashes,
ath12k host does nothing to firmware. And during warm reboot, WLAN power
is sustained. So firmware is likely to keep running in mission mode throughout
the bootup process. As a result PCIe link is not established and thus target
not enumerated.

So add a handler in panic notification list for ath12k. When kernel crashes,
this handler gets called and tries to reset target to PBL state. Then PCIe
link negotiation could happen and target gets enumerated.

This change applies to all PCI devices including WCN7850 and QCN9274.

Tested-on: WCN7850 hw2.0 PCI WLAN.HMT.1.0-03427-QCAHMTSWPL_V1.0_V2.0_SILICONZ-1.15378.4

Signed-off-by: Baochen Qiang <quic_bqiang@quicinc.com>
Acked-by: Jeff Johnson <quic_jjohnson@quicinc.com>
Signed-off-by: Kalle Valo <quic_kvalo@quicinc.com>
Link: https://msgid.link/20240529021533.10861-1-quic_bqiang@quicinc.com
drivers/net/wireless/ath/ath12k/core.c
drivers/net/wireless/ath/ath12k/core.h
drivers/net/wireless/ath/ath12k/hif.h
drivers/net/wireless/ath/ath12k/pci.c