]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
wifi: iwlwifi: pcie: set state to no-FW before reset handshake
authorJohannes Berg <johannes.berg@intel.com>
Fri, 11 Apr 2025 08:40:54 +0000 (10:40 +0200)
committerJohannes Berg <johannes.berg@intel.com>
Fri, 11 Apr 2025 14:07:47 +0000 (16:07 +0200)
The reset handshake attempts to kill the firmware, and it'll go
into a pretty much dead state once we do that. However, if it
times out, then we'll attempt to dump the firmware to be able
to see why it didn't respond. During this dump, we cannot treat
it as if it was still running, since we just tried to kill it,
otherwise dumping will attempt to send a DBGC stop command. As
this command will time out, we'll go into a reset loop.

For now, fix this by setting the trans->state to say firmware
isn't running before doing the reset handshake. In the longer
term, we should clean up the way this state is handled.

It's not entirely clear but it seems likely that this issue was
introduced by my rework of the error handling, prior to that it
would've been synchronous at that point and (I think) not have
attempted to reset since it was already doing down.

Closes: https://bugzilla.kernel.org/show_bug.cgi?id=219967
Closes: https://bugzilla.kernel.org/show_bug.cgi?id=219968
Fixes: 7391b2a4f7db ("wifi: iwlwifi: rework firmware error handling")
Reviewed-by: Miriam Rachel Korenblit <miriam.rachel.korenblit@intel.com>
Link: https://patch.msgid.link/20250411104054.63aa4f56894d.Ife70cfe997db03f0d07fdef2b164695739a05a63@changeid
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
drivers/net/wireless/intel/iwlwifi/pcie/trans-gen2.c

index 3ece34e30d580642a3ac177bc04be614048a95b3..472f26f83ba833d3c5696b26bcc7c42afdfd31a5 100644 (file)
@@ -147,8 +147,14 @@ static void _iwl_trans_pcie_gen2_stop_device(struct iwl_trans *trans)
                return;
 
        if (trans->state >= IWL_TRANS_FW_STARTED &&
-           trans_pcie->fw_reset_handshake)
+           trans_pcie->fw_reset_handshake) {
+               /*
+                * Reset handshake can dump firmware on timeout, but that
+                * should assume that the firmware is already dead.
+                */
+               trans->state = IWL_TRANS_NO_FW;
                iwl_trans_pcie_fw_reset_handshake(trans);
+       }
 
        trans_pcie->is_down = true;