Received: by 2002:ac0:98c7:0:0:0:0:0 with SMTP id g7-v6csp233750imd; Fri, 26 Oct 2018 07:46:50 -0700 (PDT) X-Google-Smtp-Source: AJdET5feT/nd8NHRvF7QBwF/qYDdJG9kaRQHi0l6Hv/W98MQ50g4WDuJh2NWe0Qq5uXLtCLbUUwx X-Received: by 2002:a63:4f61:: with SMTP id p33-v6mr3755707pgl.71.1540565210253; Fri, 26 Oct 2018 07:46:50 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1540565210; cv=none; d=google.com; s=arc-20160816; b=Fd0RjC9D6W7PueWmB68KloZjcbF1kraQJdl5zcMshc0pRxboLw9oDv6AiLSAnlWbP7 6ycQLxuIswY0bgUneedu3Evv7V1F54LZyj+aQ8JIKenqvmiXEWXLy/cDmcL+C663ukmV 6VR3DWjzi+Q5khp54AFTPjxCYfGPRwalT9w9475FPYXOPlGAIjdDyo5KWOHQefDdVkg7 bwmv4yJUVZ2ot3L7tSXypeE6ZaqxrlyyvbNkLjlbHL6kxmawCE5o1IVLDOFWJGIfYoJi J5bqEI+ly2fsKhdPR0mWxIwSQWJ60146+Npcgrj2SzouymEuqP7JvwHdva5Lo5ExW74U bihA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=efp6sFiQWGhKGiEpT9DPizID7xKe3bNjf2I9V30y+Ys=; b=At+9YBFfMAA3Yl3ea+M5YXhreB8xIn8rzD87ZOEmeoMa4JoC22CcGhII2HTmkIqDqR ZkF+Q9YXMBBlnE0okMNtiZpzzVQdltnPXgYXeKq0vLDW6X97aTY+Zcr/+b/rifNcdinb p6UlwIyCuLiU70pY1oiydMN6m/4qN5heX1bxZqqUxmCDba4VvG4RGe5M3hcd3vBcChfk reCEP185cnT+ZWGWat3+nVSyknS35+Fp9X08eM7ufSetgPk/YR0w50i/AeeDCiSKv7Z2 166hFzvV2AlHPTIoItiTQv+U7KS/TE3RgpaurZP22hUg3AJxWFA9gXxBGro0DgYOIhc0 0JRw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@amarulasolutions.com header.s=google header.b="fgB+w/jt"; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id w19-v6si11320233pgl.278.2018.10.26.07.46.34; Fri, 26 Oct 2018 07:46:50 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@amarulasolutions.com header.s=google header.b="fgB+w/jt"; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728101AbeJZXWx (ORCPT + 99 others); Fri, 26 Oct 2018 19:22:53 -0400 Received: from mail-pl1-f196.google.com ([209.85.214.196]:38653 "EHLO mail-pl1-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727736AbeJZXWw (ORCPT ); Fri, 26 Oct 2018 19:22:52 -0400 Received: by mail-pl1-f196.google.com with SMTP id p7-v6so625285plk.5 for ; Fri, 26 Oct 2018 07:45:31 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amarulasolutions.com; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=efp6sFiQWGhKGiEpT9DPizID7xKe3bNjf2I9V30y+Ys=; b=fgB+w/jtIZgJ3cUnZ6wBZHi5PXY/IpocFCJWrAWselKgGvHeS0V9aqCXHUEbdEjQ44 ErNWTafUecoXd3fhSrnYeSt4xcw75Y5R0o04cGYTSrXjiMnk4792xGpiZ62SxA2fnZAd 0FIzExMCXDksaN/p57I3Lqn531A2ajs+387Z4= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=efp6sFiQWGhKGiEpT9DPizID7xKe3bNjf2I9V30y+Ys=; b=W+JVgnRBzwcvxRKBaQII16ae0st2oNLkNAW33LQJqHotMc8Guyoyjw29No4p+l9ZG/ JVGX/i1GIIw98uJKr8+4A2XEAy7G2hNn2D/DKxeDa/fhzDE99Z5vmIhU7dZSHwa//w+y oVhVWeATzXLdzwqnPkDqh8CgBeGZdvx0Lfa3W9nAqdSlktUASwFFqi4cwa4des8Mthjm X6YmvN19ql6ARdin5gCSP3SyYG8WQdaIA8gnWKz7+QgPHhKfmP0EQooGP0Q5+kyKaayf UQ6+6KFlkfmxMu5r42c2iL9tLDVJ4xfhjwZ+1ElJy/j+vQaqbPWFVCOCiA5SEyr88BGz sCwA== X-Gm-Message-State: AGRZ1gJScd2IerneaNk3zN4F1OSS4iUyHi9kMebrHGJd6x6VvU+LWuWK JycxKf/hGSnnu1BvNYRxVCokjQ== X-Received: by 2002:a17:902:b106:: with SMTP id q6-v6mr3811436plr.238.1540565131346; Fri, 26 Oct 2018 07:45:31 -0700 (PDT) Received: from localhost.localdomain ([27.7.51.1]) by smtp.gmail.com with ESMTPSA id z22-v6sm12044467pgv.24.2018.10.26.07.45.25 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Fri, 26 Oct 2018 07:45:30 -0700 (PDT) From: Jagan Teki To: Maxime Ripard , Chen-Yu Tsai , Icenowy Zheng , Jernej Skrabec , Vasily Khoruzhick , Rob Herring , Mark Rutland , Catalin Marinas , Will Deacon , David Airlie , dri-devel@lists.freedesktop.org, Michael Turquette , Stephen Boyd , linux-clk@vger.kernel.org, Michael Trimarchi , linux-arm-kernel@lists.infradead.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-sunxi@googlegroups.com Cc: Jagan Teki Subject: [PATCH v3 14/25] drm/sun4i: sun6i_mipi_dsi: Increase hfp packet overhead Date: Fri, 26 Oct 2018 20:13:33 +0530 Message-Id: <20181026144344.27778-15-jagan@amarulasolutions.com> X-Mailer: git-send-email 2.18.0.321.gffc6fa0e3 In-Reply-To: <20181026144344.27778-1-jagan@amarulasolutions.com> References: <20181026144344.27778-1-jagan@amarulasolutions.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Increase the hfp packet overhead with another 10 bytes, the extra 10 bytes(which is hblk packet overhead) is adding for hfp packet overhead since hfp depends on hblk. This is truely as per BSP code from BPI-M64-bsp. The real computation from BSP is (in drivers/video/sunxi/disp2/disp/de/lowlevel_sun50iw1/de_dsi.c) dsi_hbp = (hbp-hspw)*dsi_pixel_bits[format]/8 - (4+2); dsi_hact = x * dsi_pixel_bits[format]/8; dsi_hblk = (ht-hspw)*dsi_pixel_bits[format]/8-(4+4+2); dsi_hfp = dsi_hblk - (4+dsi_hact+2) - (4+dsi_hbp+2); Example, u32 fmt = dsi_pixel_bits[format]/8; => ((ht-hspw)*fmt - 10) - (6 + x * fmt) - (6 + (hbp-hspw)*fmt - 6) => (ht - hspw - x - (hbp - hspw)) * fmt - 16 => (ht - x - hbp) * fmt - 16 => (ht - x - (timmings->hor_total_time - timmings->hor_front_porch - x) * fmt - 16 => (timmings->hor_total_time - x - timmings->hor_total_time + timmings->hor_front_porch + x) * fmt - 16 => timmings->hor_front_porch * fmt - 16 So, increase the DSI hfp packet overhead by hblk packet overhead. Tested on 2-lane, 4-lane MIPI-DSI LCD panels. Signed-off-by: Jagan Teki Tested-by: Jagan Teki --- Changes for v3: - new patch Changes for v2: - none drivers/gpu/drm/sun4i/sun6i_mipi_dsi.c | 22 +++++++++++++--------- 1 file changed, 13 insertions(+), 9 deletions(-) diff --git a/drivers/gpu/drm/sun4i/sun6i_mipi_dsi.c b/drivers/gpu/drm/sun4i/sun6i_mipi_dsi.c index 6584b51736a9..20e330186b7f 100644 --- a/drivers/gpu/drm/sun4i/sun6i_mipi_dsi.c +++ b/drivers/gpu/drm/sun4i/sun6i_mipi_dsi.c @@ -461,7 +461,7 @@ static void sun6i_dsi_setup_timings(struct sun6i_dsi *dsi, { struct mipi_dsi_device *device = dsi->device; unsigned int Bpp = mipi_dsi_pixel_format_to_bpp(device->format) / 8; - u16 hbp, hfp, hsa, hblk_max, hblk, vblk; + u16 hbp, hfp_pkt_overhead, hfp, hsa, hblk_max, hblk, vblk; size_t bytes; u8 *buffer; @@ -484,14 +484,6 @@ static void sun6i_dsi_setup_timings(struct sun6i_dsi *dsi, hbp = max((unsigned int)HBP_PACKET_OVERHEAD, (mode->htotal - mode->hsync_end) * Bpp - HBP_PACKET_OVERHEAD); - /* - * The frontporch is set using a blanking packet (4 bytes + - * payload + 2 bytes). Its minimal size is therefore 6 bytes - */ -#define HFP_PACKET_OVERHEAD 6 - hfp = max((unsigned int)HFP_PACKET_OVERHEAD, - (mode->hsync_start - mode->hdisplay) * Bpp - HFP_PACKET_OVERHEAD); - /* * hblk seems to be the line + porches length. * The blank is set using a blanking packet (4 bytes + 4 bytes + @@ -502,6 +494,18 @@ static void sun6i_dsi_setup_timings(struct sun6i_dsi *dsi, hblk_max -= HBLK_PACKET_OVERHEAD; hblk = max((unsigned int)HBLK_PACKET_OVERHEAD, hblk_max); + /* + * The frontporch is set using a blanking packet (4 bytes + + * payload + 2 bytes). Its minimal size is therefore 6 bytes + * + * According to BSP code, extra 10 bytes(which is hblk packet overhead) + * is adding for hfp packet overhead since hfp depends on hblk. + */ +#define HFP_PACKET_OVERHEAD 6 + hfp_pkt_overhead = (HFP_PACKET_OVERHEAD + HBLK_PACKET_OVERHEAD); + hfp = max((unsigned int)hfp_pkt_overhead, + (mode->hsync_start - mode->hdisplay) * Bpp - hfp_pkt_overhead); + /* * And I'm not entirely sure what vblk is about. The driver in * Allwinner BSP is using a rather convoluted calculation -- 2.18.0.321.gffc6fa0e3