Skip to content

Commit 045a5b6

Browse files
committed
wifi: iwlwifi: fw: don't always use FW dump trig
Since the dump_data (struct iwl_fwrt_dump_data) is a union, it's not safe to unconditionally access and use the 'trig' member, it might be 'desc' instead. Access it only if it's known to be 'trig' rather than 'desc', i.e. if ini-debug is present. Cc: stable@vger.kernel.org Fixes: 0eb50c6 ("iwlwifi: yoyo: send hcmd to fw after dump collection completes.") Signed-off-by: Johannes Berg <johannes.berg@intel.com> Signed-off-by: Miri Korenblit <miriam.rachel.korenblit@intel.com> Link: https://msgid.link/20240319100755.e2976bc58b29.I72fbd6135b3623227de53d8a2bb82776066cb72b@changeid Signed-off-by: Johannes Berg <johannes.berg@intel.com>
1 parent 06a0938 commit 045a5b6

1 file changed

Lines changed: 8 additions & 7 deletions

File tree

  • drivers/net/wireless/intel/iwlwifi/fw

drivers/net/wireless/intel/iwlwifi/fw/dbg.c

Lines changed: 8 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -3081,8 +3081,6 @@ static void iwl_fw_dbg_collect_sync(struct iwl_fw_runtime *fwrt, u8 wk_idx)
30813081
struct iwl_fw_dbg_params params = {0};
30823082
struct iwl_fwrt_dump_data *dump_data =
30833083
&fwrt->dump.wks[wk_idx].dump_data;
3084-
u32 policy;
3085-
u32 time_point;
30863084
if (!test_bit(wk_idx, &fwrt->dump.active_wks))
30873085
return;
30883086

@@ -3113,13 +3111,16 @@ static void iwl_fw_dbg_collect_sync(struct iwl_fw_runtime *fwrt, u8 wk_idx)
31133111

31143112
iwl_fw_dbg_stop_restart_recording(fwrt, &params, false);
31153113

3116-
policy = le32_to_cpu(dump_data->trig->apply_policy);
3117-
time_point = le32_to_cpu(dump_data->trig->time_point);
3114+
if (iwl_trans_dbg_ini_valid(fwrt->trans)) {
3115+
u32 policy = le32_to_cpu(dump_data->trig->apply_policy);
3116+
u32 time_point = le32_to_cpu(dump_data->trig->time_point);
31183117

3119-
if (policy & IWL_FW_INI_APPLY_POLICY_DUMP_COMPLETE_CMD) {
3120-
IWL_DEBUG_FW_INFO(fwrt, "WRT: sending dump complete\n");
3121-
iwl_send_dbg_dump_complete_cmd(fwrt, time_point, 0);
3118+
if (policy & IWL_FW_INI_APPLY_POLICY_DUMP_COMPLETE_CMD) {
3119+
IWL_DEBUG_FW_INFO(fwrt, "WRT: sending dump complete\n");
3120+
iwl_send_dbg_dump_complete_cmd(fwrt, time_point, 0);
3121+
}
31223122
}
3123+
31233124
if (fwrt->trans->dbg.last_tp_resetfw == IWL_FW_INI_RESET_FW_MODE_STOP_FW_ONLY)
31243125
iwl_force_nmi(fwrt->trans);
31253126

0 commit comments

Comments
 (0)