Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S945062AbcJaRdO (ORCPT ); Mon, 31 Oct 2016 13:33:14 -0400 Received: from arroyo.ext.ti.com ([198.47.19.12]:49745 "EHLO arroyo.ext.ti.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S945024AbcJaRdM (ORCPT ); Mon, 31 Oct 2016 13:33:12 -0400 Subject: Re: [PATCH 1/2] drm: tilcdc: Add revision handling for FB_CEILING To: Daniel Schultz , , , , References: <1477655562-19642-1-git-send-email-d.schultz@phytec.de> From: Jyri Sarha Message-ID: Date: Mon, 31 Oct 2016 19:33:04 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:45.0) Gecko/20100101 Thunderbird/45.3.0 MIME-Version: 1.0 In-Reply-To: <1477655562-19642-1-git-send-email-d.schultz@phytec.de> Content-Type: text/plain; charset="windows-1252" Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1852 Lines: 48 On 10/28/16 14:52, Daniel Schultz wrote: > The commit d8ff0c63fbcb ("drm/tilcdc: Adjust the FB_CEILING address") > added an adjustment of the FB_CEILING address. This is done by decrementing > the address by one. > > On the AM335x (rev 0x4F201000) the framebuffer is rotated left over the > display border, because the ceiling address is 8f276fff instead of > 8f277000. Since this adjustment isn't necessary for the LCDC v2, the > origin ceiling address should be used. > I can not see the rotation on any of my HW. However, there is no harm in taking this patch either, so I'll take your word for it and pick this up for my next pull request. Best regards, Jyri > Signed-off-by: Daniel Schultz > --- > drivers/gpu/drm/tilcdc/tilcdc_crtc.c | 6 +++++- > 1 file changed, 5 insertions(+), 1 deletion(-) > > diff --git a/drivers/gpu/drm/tilcdc/tilcdc_crtc.c b/drivers/gpu/drm/tilcdc/tilcdc_crtc.c > index 788999e..fe1d088 100644 > --- a/drivers/gpu/drm/tilcdc/tilcdc_crtc.c > +++ b/drivers/gpu/drm/tilcdc/tilcdc_crtc.c > @@ -69,6 +69,7 @@ static void set_scanout(struct drm_crtc *crtc, struct drm_framebuffer *fb) > { > struct tilcdc_crtc *tilcdc_crtc = to_tilcdc_crtc(crtc); > struct drm_device *dev = crtc->dev; > + struct tilcdc_drm_private *priv = dev->dev_private; > struct drm_gem_cma_object *gem; > unsigned int depth, bpp; > dma_addr_t start, end; > @@ -88,7 +89,10 @@ static void set_scanout(struct drm_crtc *crtc, struct drm_framebuffer *fb) > * unlikely that LCDC would fetch the DMA addresses in the middle of > * an update. > */ > - dma_base_and_ceiling = (u64)(end - 1) << 32 | start; > + if (priv->rev == 1) > + end -= 1; > + > + dma_base_and_ceiling = (u64)end << 32 | start; > tilcdc_write64(dev, LCDC_DMA_FB_BASE_ADDR_0_REG, dma_base_and_ceiling); > > if (tilcdc_crtc->curr_fb) >