 c06fb25d1f
			
		
	
	c06fb25d1f
	
	
		
			
	
		
	
	
		
			Some checks failed
		
		
	
	Build Kernel / Build all affected Kernels (push) Has been cancelled
				
			Build all core packages / Build all core packages for selected target (push) Has been cancelled
				
			Build and Push prebuilt tools container / Build and Push all prebuilt containers (push) Has been cancelled
				
			Build Toolchains / Build Toolchains for each target (push) Has been cancelled
				
			Build host tools / Build host tools for linux and macos based systems (push) Has been cancelled
				
			Coverity scan build / Coverity x86/64 build (push) Has been cancelled
				
			
		
			
				
	
	
		
			59 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			59 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| From c12bd0136e9772e955b5637185415d413d8d5b5c Mon Sep 17 00:00:00 2001
 | |
| From: Dave Stevenson <dave.stevenson@raspberrypi.com>
 | |
| Date: Fri, 1 Apr 2022 11:31:38 +0100
 | |
| Subject: [PATCH 0024/1085] drm/vc4: Force trigger of dlist update on margins
 | |
|  change
 | |
| 
 | |
| When the margins are changed, the dlist needs to be regenerated
 | |
| with the changed updated dest regions for each of the planes.
 | |
| 
 | |
| Setting the zpos_changed flag is sufficient to trigger that
 | |
| without doing a full modeset, therefore set it should the
 | |
| margins be changed.
 | |
| 
 | |
| Signed-off-by: Dave Stevenson <dave.stevenson@raspberrypi.com>
 | |
| ---
 | |
|  drivers/gpu/drm/vc4/vc4_crtc.c | 14 ++++++++++----
 | |
|  drivers/gpu/drm/vc4/vc4_drv.h  |  7 +------
 | |
|  2 files changed, 11 insertions(+), 10 deletions(-)
 | |
| 
 | |
| --- a/drivers/gpu/drm/vc4/vc4_crtc.c
 | |
| +++ b/drivers/gpu/drm/vc4/vc4_crtc.c
 | |
| @@ -752,10 +752,16 @@ int vc4_crtc_atomic_check(struct drm_crt
 | |
|  		if (conn_state->crtc != crtc)
 | |
|  			continue;
 | |
|  
 | |
| -		vc4_state->margins.left = conn_state->tv.margins.left;
 | |
| -		vc4_state->margins.right = conn_state->tv.margins.right;
 | |
| -		vc4_state->margins.top = conn_state->tv.margins.top;
 | |
| -		vc4_state->margins.bottom = conn_state->tv.margins.bottom;
 | |
| +		if (memcmp(&vc4_state->margins, &conn_state->tv.margins,
 | |
| +			   sizeof(vc4_state->margins))) {
 | |
| +			memcpy(&vc4_state->margins, &conn_state->tv.margins,
 | |
| +			       sizeof(vc4_state->margins));
 | |
| +
 | |
| +			/* Need to force the dlist entries for all planes to be
 | |
| +			 * updated so that the dest rectangles are changed.
 | |
| +			 */
 | |
| +			crtc_state->zpos_changed = true;
 | |
| +		}
 | |
|  		break;
 | |
|  	}
 | |
|  
 | |
| --- a/drivers/gpu/drm/vc4/vc4_drv.h
 | |
| +++ b/drivers/gpu/drm/vc4/vc4_drv.h
 | |
| @@ -627,12 +627,7 @@ struct vc4_crtc_state {
 | |
|  	bool txp_armed;
 | |
|  	unsigned int assigned_channel;
 | |
|  
 | |
| -	struct {
 | |
| -		unsigned int left;
 | |
| -		unsigned int right;
 | |
| -		unsigned int top;
 | |
| -		unsigned int bottom;
 | |
| -	} margins;
 | |
| +	struct drm_connector_tv_margins margins;
 | |
|  
 | |
|  	unsigned long hvs_load;
 | |
|  
 |