Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp3391101pxb; Mon, 17 Jan 2022 19:26:12 -0800 (PST) X-Google-Smtp-Source: ABdhPJzLoyfBBmMMVS3lScjlJDqiCcPVgen1sNEX8PiqrSczS9Qq6eLKAG+dVFScYFg+Jsf68RiZ X-Received: by 2002:a05:6a00:188c:b0:4c0:ecce:784b with SMTP id x12-20020a056a00188c00b004c0ecce784bmr23764490pfh.22.1642476247298; Mon, 17 Jan 2022 19:24:07 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1642476247; cv=none; d=google.com; s=arc-20160816; b=1EW/ipOp3fIU5bPQOGoKQQxL3UN0EFNjsbcwucfG2Wm1U9lXazQY98xWv56/VAz+Sg j4uusEz2vkNcEjBOl5UftyAatRYzspor/vfSqi+RMKruM3hmokLsuk7qM2F1iVf8SF4n TZuKcemE4IML8xQQSeGg/ZBBS9jzbDbk5WoeAx9mI2rvgmnjkN8Kbi0U3ELT9lKGd3lD O8yeMGwGM3pF/knK+P/ot99eHYR60Bmqn9xqSBSM+sn0W5oqz99RVS+EyUnVk0xsj6Vd lOGy8z1LUE7C2uWphYT5Ixf7VeNC3SEP4sORCjRzb1oeRmmWzRVcMy6DZx43px6e2dCw I1VA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:date:cc:to:from:subject:message-id; bh=A3IobeEH8TAdXTWw77zEPmfr3R5p5fpgp9O7xstrjQQ=; b=jZN0fY2pdClD+d2CISp/KW/fBN3z0sPHXvxUSl0SY0V/E/Cif21PKZINKRmFdDA4ut rJmK/FF+kIejJNOis7RcJgrQxyDMIBOJv80+miQX8ON/q2fe+zKQduuKQsGa7ZHxdbQr 80lUJa5GhVdcM+8JttcE/bBXPmIJWebfeiQIuYvB4wBrZIo5gjurGHq3bHi/gPTy4csx cp7mOeAFCClUrZZuxPn3hl//W2TKRZjKEsCK1ELarB5cV9DcQqtorNG+EFeExubFHR6/ ngCcAYntVCCnQNxS+YYG/vkG7BE3n7FWJXvZqN6eXLT06jVZIf+I6y81yfwP6HcSn3BP W3fA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=mediatek.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id h3si1186455pja.88.2022.01.17.19.23.55; Mon, 17 Jan 2022 19:24:07 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=mediatek.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1346275AbiARCff (ORCPT + 99 others); Mon, 17 Jan 2022 21:35:35 -0500 Received: from mailgw01.mediatek.com ([60.244.123.138]:42298 "EHLO mailgw01.mediatek.com" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S1344205AbiARC3V (ORCPT ); Mon, 17 Jan 2022 21:29:21 -0500 X-UUID: 55fead7361b54f23ab6d7eada7852afd-20220118 X-UUID: 55fead7361b54f23ab6d7eada7852afd-20220118 Received: from mtkmbs10n1.mediatek.inc [(172.21.101.34)] by mailgw01.mediatek.com (envelope-from ) (Generic MTA with TLSv1.2 ECDHE-RSA-AES256-GCM-SHA384 256/256) with ESMTP id 1671992361; Tue, 18 Jan 2022 10:29:17 +0800 Received: from mtkcas10.mediatek.inc (172.21.101.39) by mtkmbs10n2.mediatek.inc (172.21.101.183) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384) id 15.2.792.3; Tue, 18 Jan 2022 10:29:15 +0800 Received: from mtksdccf07 (172.21.84.99) by mtkcas10.mediatek.inc (172.21.101.73) with Microsoft SMTP Server id 15.0.1497.2 via Frontend Transport; Tue, 18 Jan 2022 10:29:15 +0800 Message-ID: <1bd816c2f26cd8e42debf066a57e24eb5e2f580d.camel@mediatek.com> Subject: Re: [v9,2/3] drm/mediatek: implement the DSI hs packets aligned From: Rex-BC Chen To: Andrzej Hajda , AngeloGioacchino Del Regno , , , , , , , CC: , , , , , , Jitao Shi Date: Tue, 18 Jan 2022 10:29:15 +0800 In-Reply-To: <86b76e9f-96b0-7d54-bd38-449745e30aa2@intel.com> References: <20220114092110.12137-1-rex-bc.chen@mediatek.com> <20220114092110.12137-3-rex-bc.chen@mediatek.com> <4076cb55-4546-6bbd-1a1f-19395dcd9ccd@collabora.com> <86b76e9f-96b0-7d54-bd38-449745e30aa2@intel.com> Content-Type: text/plain; charset="UTF-8" X-Mailer: Evolution 3.28.5-0ubuntu0.18.04.2 MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-MTK: N Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hello Andrzej, Thanks for your review. I will give the explanation for this in next version. BRs, Rex-BC hen On Fri, 2022-01-14 at 12:11 +0100, Andrzej Hajda wrote: > On 14.01.2022 11:20, Rex-BC Chen wrote: > > Hello AngeloGioacchino, > > > > Thanks for your review. > > I will modify this in next version. > > > > BRs, > > Rex-BC Chen > > > > On Fri, 2022-01-14 at 10:36 +0100, AngeloGioacchino Del Regno > > wrote: > > > Il 14/01/22 10:21, Rex-BC Chen ha scritto: > > > > Some DSI RX devices require the packets on all lanes aligned at > > > > the > > > > end. > > > > Otherwise, there will be some issues of shift or scroll for > > > > screen. > > > > > > > > Signed-off-by: Jitao Shi > > > > Signed-off-by: Rex-BC Chen > > > > > > Hello, > > > thanks for the patch! However, there's something to improve... > > > > > > > --- > > > > drivers/gpu/drm/mediatek/mtk_dsi.c | 12 ++++++++++++ > > > > 1 file changed, 12 insertions(+) > > > > > > > > diff --git a/drivers/gpu/drm/mediatek/mtk_dsi.c > > > > b/drivers/gpu/drm/mediatek/mtk_dsi.c > > > > index 5d90d2eb0019..ccdda15f5a66 100644 > > > > --- a/drivers/gpu/drm/mediatek/mtk_dsi.c > > > > +++ b/drivers/gpu/drm/mediatek/mtk_dsi.c > > > > @@ -195,6 +195,8 @@ struct mtk_dsi { > > > > struct clk *hs_clk; > > > > > > > > u32 data_rate; > > > > + /* force dsi line end without dsi_null data */ > > > > + bool hs_packet_end_aligned; > > > > > > There's no need to introduce a new variable here... > > > > > > > > unsigned long mode_flags; > > > > enum mipi_dsi_pixel_format format; > > > > @@ -500,6 +502,13 @@ static void > > > > mtk_dsi_config_vdo_timing(struct > > > > mtk_dsi *dsi) > > > > DRM_WARN("HFP + HBP less than d-phy, FPS will > > > > under > > > > 60Hz\n"); > > > > } > > > > > > > > + if (dsi->hs_packet_end_aligned) { > > > > > > You can simply check mode_flags here: > > > if (dsi->mode_flags & MIPI_DSI_HS_PKT_END_ALIGNED) { > > > > > > > + horizontal_sync_active_byte = > > > > roundup(horizontal_sync_active_byte, dsi->lanes) - 2; > > > > + horizontal_frontporch_byte = > > > > roundup(horizontal_frontporch_byte, dsi->lanes) - 2; > > > > + horizontal_backporch_byte = > > > > roundup(horizontal_backporch_byte, dsi->lanes) - 2; > > > > + horizontal_backporch_byte -= (vm->hactive * > > > > dsi_tmp_buf_bpp + 2) % dsi->lanes; > > > > + } > > > > + > > > And if you could add comment explaining the magic here it would be > nice. > > > Regards > > Andrzej > > > > > > writel(horizontal_sync_active_byte, dsi->regs + > > > > DSI_HSA_WC); > > > > writel(horizontal_backporch_byte, dsi->regs + > > > > DSI_HBP_WC); > > > > writel(horizontal_frontporch_byte, dsi->regs + > > > > DSI_HFP_WC); > > > > @@ -794,6 +803,9 @@ static int mtk_dsi_host_attach(struct > > > > mipi_dsi_host *host, > > > > dsi->lanes = device->lanes; > > > > dsi->format = device->format; > > > > dsi->mode_flags = device->mode_flags; > > > > + dsi->hs_packet_end_aligned = (dsi->mode_flags & > > > > + MIPI_DSI_HS_PKT_END_ALIGN > > > > ED) > > > > + ? true : false; > > > > > > ...so there's no need for this one, either. > > > > > > > > > > > return 0; > > > > } > > > > > > > > > > Regards, > > > - Angelo > > >