mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	iwlwifi: stop dbgc recording before stopping DMA
Today we stop the device and the DMA without stopping the dbgc recording before. This causes host crashes when the DMA rate is high. Stop dbgc recording when clearing the fw debug configuration to fix this. Signed-off-by: Golan Ben Ami <golan.ben.ami@intel.com> Signed-off-by: Luca Coelho <luciano.coelho@intel.com>
This commit is contained in:
		
							parent
							
								
									baf41bc35f
								
							
						
					
					
						commit
						1efc3843a4
					
				| @ -1086,7 +1086,7 @@ void iwl_fw_error_dump_wk(struct work_struct *work) | |||||||
| 
 | 
 | ||||||
| 	if (fwrt->trans->cfg->device_family == IWL_DEVICE_FAMILY_7000) { | 	if (fwrt->trans->cfg->device_family == IWL_DEVICE_FAMILY_7000) { | ||||||
| 		/* stop recording */ | 		/* stop recording */ | ||||||
| 		iwl_set_bits_prph(fwrt->trans, MON_BUFF_SAMPLE_CTL, 0x100); | 		iwl_fw_dbg_stop_recording(fwrt); | ||||||
| 
 | 
 | ||||||
| 		iwl_fw_error_dump(fwrt); | 		iwl_fw_error_dump(fwrt); | ||||||
| 
 | 
 | ||||||
| @ -1104,10 +1104,7 @@ void iwl_fw_error_dump_wk(struct work_struct *work) | |||||||
| 		u32 in_sample = iwl_read_prph(fwrt->trans, DBGC_IN_SAMPLE); | 		u32 in_sample = iwl_read_prph(fwrt->trans, DBGC_IN_SAMPLE); | ||||||
| 		u32 out_ctrl = iwl_read_prph(fwrt->trans, DBGC_OUT_CTRL); | 		u32 out_ctrl = iwl_read_prph(fwrt->trans, DBGC_OUT_CTRL); | ||||||
| 
 | 
 | ||||||
| 		/* stop recording */ | 		iwl_fw_dbg_stop_recording(fwrt); | ||||||
| 		iwl_write_prph(fwrt->trans, DBGC_IN_SAMPLE, 0); |  | ||||||
| 		udelay(100); |  | ||||||
| 		iwl_write_prph(fwrt->trans, DBGC_OUT_CTRL, 0); |  | ||||||
| 		/* wait before we collect the data till the DBGC stop */ | 		/* wait before we collect the data till the DBGC stop */ | ||||||
| 		udelay(500); | 		udelay(500); | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -68,6 +68,8 @@ | |||||||
| #include <linux/workqueue.h> | #include <linux/workqueue.h> | ||||||
| #include <net/cfg80211.h> | #include <net/cfg80211.h> | ||||||
| #include "runtime.h" | #include "runtime.h" | ||||||
|  | #include "iwl-prph.h" | ||||||
|  | #include "iwl-io.h" | ||||||
| #include "file.h" | #include "file.h" | ||||||
| #include "error-dump.h" | #include "error-dump.h" | ||||||
| 
 | 
 | ||||||
| @ -194,8 +196,21 @@ _iwl_fw_dbg_trigger_simple_stop(struct iwl_fw_runtime *fwrt, | |||||||
| 					iwl_fw_dbg_get_trigger((fwrt)->fw,\ | 					iwl_fw_dbg_get_trigger((fwrt)->fw,\ | ||||||
| 							       (trig))) | 							       (trig))) | ||||||
| 
 | 
 | ||||||
|  | static inline void iwl_fw_dbg_stop_recording(struct iwl_fw_runtime *fwrt) | ||||||
|  | { | ||||||
|  | 	if (fwrt->trans->cfg->device_family == IWL_DEVICE_FAMILY_7000) { | ||||||
|  | 		iwl_set_bits_prph(fwrt->trans, MON_BUFF_SAMPLE_CTL, 0x100); | ||||||
|  | 	} else { | ||||||
|  | 		iwl_write_prph(fwrt->trans, DBGC_IN_SAMPLE, 0); | ||||||
|  | 		udelay(100); | ||||||
|  | 		iwl_write_prph(fwrt->trans, DBGC_OUT_CTRL, 0); | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | 
 | ||||||
| static inline void iwl_fw_dump_conf_clear(struct iwl_fw_runtime *fwrt) | static inline void iwl_fw_dump_conf_clear(struct iwl_fw_runtime *fwrt) | ||||||
| { | { | ||||||
|  | 	iwl_fw_dbg_stop_recording(fwrt); | ||||||
|  | 
 | ||||||
| 	fwrt->dump.conf = FW_DBG_INVALID; | 	fwrt->dump.conf = FW_DBG_INVALID; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Golan Ben Ami
						Golan Ben Ami