diff options
| author | Michel Dänzer <michel.daenzer@amd.com> | 2019-07-24 17:56:28 +0200 | 
|---|---|---|
| committer | Alex Deucher <alexander.deucher@amd.com> | 2019-08-12 12:47:47 -0500 | 
| commit | 965ebe3d5d641925e0014a5a8c967fe579929b1d (patch) | |
| tree | 0f66c509d979c3872009ee5dc78c4dd0d17e23e2 /drivers/gpu/drm/amd/amdgpu/dce_v11_0.c | |
| parent | 29c9d8eadc7a7e2fbfe4632c9050c814c260923b (diff) | |
drm/amdgpu: Update pitch on page flips without DC as well
DC already handles this correctly since amdgpu minor version 31. Bump
the minor version again so that xf86-video-amdgpu can take advantage of
this working without DC as well now.
Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
Signed-off-by: Michel Dänzer <michel.daenzer@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/dce_v11_0.c')
| -rw-r--r-- | drivers/gpu/drm/amd/amdgpu/dce_v11_0.c | 4 | 
1 files changed, 4 insertions, 0 deletions
| diff --git a/drivers/gpu/drm/amd/amdgpu/dce_v11_0.c b/drivers/gpu/drm/amd/amdgpu/dce_v11_0.c index 9e0782b54066..d9f470632b2c 100644 --- a/drivers/gpu/drm/amd/amdgpu/dce_v11_0.c +++ b/drivers/gpu/drm/amd/amdgpu/dce_v11_0.c @@ -254,6 +254,7 @@ static void dce_v11_0_page_flip(struct amdgpu_device *adev,  				int crtc_id, u64 crtc_base, bool async)  {  	struct amdgpu_crtc *amdgpu_crtc = adev->mode_info.crtcs[crtc_id]; +	struct drm_framebuffer *fb = amdgpu_crtc->base.primary->fb;  	u32 tmp;  	/* flip immediate for async, default is vsync */ @@ -261,6 +262,9 @@ static void dce_v11_0_page_flip(struct amdgpu_device *adev,  	tmp = REG_SET_FIELD(tmp, GRPH_FLIP_CONTROL,  			    GRPH_SURFACE_UPDATE_IMMEDIATE_EN, async ? 1 : 0);  	WREG32(mmGRPH_FLIP_CONTROL + amdgpu_crtc->crtc_offset, tmp); +	/* update pitch */ +	WREG32(mmGRPH_PITCH + amdgpu_crtc->crtc_offset, +	       fb->pitches[0] / fb->format->cpp[0]);  	/* update the scanout addresses */  	WREG32(mmGRPH_PRIMARY_SURFACE_ADDRESS_HIGH + amdgpu_crtc->crtc_offset,  	       upper_32_bits(crtc_base)); | 
