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: Include surface of unaffected streams
The commit stream function does not include surfaces of unaffected streams, which may lead to some blank screens during mode change in some edge cases. This commit adds surfaces of unaffected streams followed by kernel-doc for documenting some of the fields that participate in this change. v2: squash in kerneldoc warning fix (Alex) Reviewed-by: Harry Wentland <harry.wentland@amd.com> Signed-off-by: Rodrigo Siqueira <Rodrigo.Siqueira@amd.com> Co-developed-by: Aurabindo Pillai <aurabindo.pillai@amd.com> Signed-off-by: Aurabindo Pillai <aurabindo.pillai@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
		
							parent
							
								
									0e986cea03
								
							
						
					
					
						commit
						f6ae69f49f
					
				| @ -1907,9 +1907,10 @@ enum dc_status dc_commit_streams(struct dc *dc, | |||||||
| 				 struct dc_stream_state *streams[], | 				 struct dc_stream_state *streams[], | ||||||
| 				 uint8_t stream_count) | 				 uint8_t stream_count) | ||||||
| { | { | ||||||
| 	int i; | 	int i, j; | ||||||
| 	struct dc_state *context; | 	struct dc_state *context; | ||||||
| 	enum dc_status res = DC_OK; | 	enum dc_status res = DC_OK; | ||||||
|  | 	struct dc_validation_set set[MAX_STREAMS] = {0}; | ||||||
| 
 | 
 | ||||||
| 	if (!streams_changed(dc, streams, stream_count)) | 	if (!streams_changed(dc, streams, stream_count)) | ||||||
| 		return res; | 		return res; | ||||||
| @ -1918,8 +1919,17 @@ enum dc_status dc_commit_streams(struct dc *dc, | |||||||
| 
 | 
 | ||||||
| 	for (i = 0; i < stream_count; i++) { | 	for (i = 0; i < stream_count; i++) { | ||||||
| 		struct dc_stream_state *stream = streams[i]; | 		struct dc_stream_state *stream = streams[i]; | ||||||
|  | 		struct dc_stream_status *status = dc_stream_get_status(stream); | ||||||
| 
 | 
 | ||||||
| 		dc_stream_log(dc, stream); | 		dc_stream_log(dc, stream); | ||||||
|  | 
 | ||||||
|  | 		set[i].stream = stream; | ||||||
|  | 
 | ||||||
|  | 		if (status) { | ||||||
|  | 			set[i].plane_count = status->plane_count; | ||||||
|  | 			for (j = 0; j < status->plane_count; j++) | ||||||
|  | 				set[i].plane_states[j] = status->plane_states[j]; | ||||||
|  | 		} | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	context = dc_create_state(dc); | 	context = dc_create_state(dc); | ||||||
|  | |||||||
| @ -1269,12 +1269,23 @@ void dc_post_update_surfaces_to_stream( | |||||||
| 
 | 
 | ||||||
| #include "dc_stream.h" | #include "dc_stream.h" | ||||||
| 
 | 
 | ||||||
| /*
 | /**
 | ||||||
|  * Structure to store surface/stream associations for validation |  * struct dc_validation_set - Struct to store surface/stream associations for validation | ||||||
|  */ |  */ | ||||||
| struct dc_validation_set { | struct dc_validation_set { | ||||||
|  | 	/**
 | ||||||
|  | 	 * @stream: Stream state properties | ||||||
|  | 	 */ | ||||||
| 	struct dc_stream_state *stream; | 	struct dc_stream_state *stream; | ||||||
|  | 
 | ||||||
|  | 	/**
 | ||||||
|  | 	 * @plane_state: Surface state | ||||||
|  | 	 */ | ||||||
| 	struct dc_plane_state *plane_states[MAX_SURFACES]; | 	struct dc_plane_state *plane_states[MAX_SURFACES]; | ||||||
|  | 
 | ||||||
|  | 	/**
 | ||||||
|  | 	 * @plane_count: Total of active planes | ||||||
|  | 	 */ | ||||||
| 	uint8_t plane_count; | 	uint8_t plane_count; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -41,6 +41,10 @@ struct timing_sync_info { | |||||||
| struct dc_stream_status { | struct dc_stream_status { | ||||||
| 	int primary_otg_inst; | 	int primary_otg_inst; | ||||||
| 	int stream_enc_inst; | 	int stream_enc_inst; | ||||||
|  | 
 | ||||||
|  | 	/**
 | ||||||
|  | 	 * @plane_count: Total of planes attached to a single stream | ||||||
|  | 	 */ | ||||||
| 	int plane_count; | 	int plane_count; | ||||||
| 	int audio_inst; | 	int audio_inst; | ||||||
| 	struct timing_sync_info timing_sync_info; | 	struct timing_sync_info timing_sync_info; | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Rodrigo Siqueira
						Rodrigo Siqueira