mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	drm/amd/display: Fix deadlock during gpu reset v3
[Why]
during idle optimizations we acquire the dc_lock, this lock is also
acquired during gpu_reset so we end up hanging the system due to a
deadlock
[How]
If we are in gpu reset:
 - disable idle optimizations and skip calls to the dc function
v2: skip idle optimizations calls
v3: add guard for DCN
Fixes: 71338cb4a7 ("drm/amd/display: enable idle optimizations for linux (MALL stutter)")
Signed-off-by: Bhawanpreet Lakha <Bhawanpreet.Lakha@amd.com>
Reviewed-by: Nicholas Kazlauskas <nicholas.kazlauskas@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
			
			
This commit is contained in:
		
							parent
							
								
									966737906c
								
							
						
					
					
						commit
						98ab5f3513
					
				| @ -1816,6 +1816,11 @@ static int dm_suspend(void *handle) | ||||
| 
 | ||||
| 	if (amdgpu_in_reset(adev)) { | ||||
| 		mutex_lock(&dm->dc_lock); | ||||
| 
 | ||||
| #if defined(CONFIG_DRM_AMD_DC_DCN) | ||||
| 		dc_allow_idle_optimizations(adev->dm.dc, false); | ||||
| #endif | ||||
| 
 | ||||
| 		dm->cached_dc_state = dc_copy_state(dm->dc->current_state); | ||||
| 
 | ||||
| 		dm_gpureset_toggle_interrupts(adev, dm->cached_dc_state, false); | ||||
| @ -5483,6 +5488,10 @@ static inline int dm_set_vblank(struct drm_crtc *crtc, bool enable) | ||||
| 	if (!dc_interrupt_set(adev->dm.dc, irq_source, enable)) | ||||
| 		return -EBUSY; | ||||
| 
 | ||||
| #if defined(CONFIG_DRM_AMD_DC_DCN) | ||||
| 	if (amdgpu_in_reset(adev)) | ||||
| 		return 0; | ||||
| 
 | ||||
| 	mutex_lock(&dm->dc_lock); | ||||
| 
 | ||||
| 	if (enable) | ||||
| @ -5499,6 +5508,7 @@ static inline int dm_set_vblank(struct drm_crtc *crtc, bool enable) | ||||
| 
 | ||||
| 	mutex_unlock(&dm->dc_lock); | ||||
| 
 | ||||
| #endif | ||||
| 	return 0; | ||||
| } | ||||
| 
 | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Bhawanpreet Lakha
						Bhawanpreet Lakha