Received: by 2002:a05:6a10:d5a5:0:0:0:0 with SMTP id gn37csp2277539pxb; Fri, 8 Oct 2021 04:47:54 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwXWH0c6exjR2hv3WenqCn14WDPAkeizu4CzOKSaAe5+48ktreDWZgI4NJ8meoGG+gI/9ER X-Received: by 2002:a17:90a:638b:: with SMTP id f11mr11802601pjj.52.1633693673841; Fri, 08 Oct 2021 04:47:53 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1633693673; cv=none; d=google.com; s=arc-20160816; b=RjauMNQVwNRxQrEQaivaz13bPjPEXsWpZv50dw+YHjB07ctIuYVSQpzcrhhagM/lU+ uNE+LoTjZA3pQLKQkTFgzWvtBWdC9+44HG1LZ9u4d5a2SHyhO9Lz8ZcK+ccU7YtYNK7n piLbbWRp4sYKhkQ8+IiR0wDjcacLCfLeWclEOiJDK4OJCJqZFO0RSO5xEUPvWMxw/14Y w2eAAwG5phTeZBBQGi4Ft1jzLnIXEHlwUaOfd4Mz409sHPUyis5zJAF78itLTa2729nJ qkGkxc0W/SF3vn+KBGDEnU1XldTKOyhQDErOQUfp+IySV+l4epetlohKVZL07NkjUhX8 t21g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=DXpoD3oDZrKV8QtdRuxL6pqOpnLAebcj0SdO2ln/m4Q=; b=MJ+58Cioie0hxf/tcRrPdHakqvFvcqNQjK1x5xZhbIO5I6IFimTJ9nzrpQWnEQfvCb 18KEniYPJZdpupt+8n8VNbaNjsrWuClnIh6MxC/JREBWWRrjImy7FmUUjl1Gy92emYVs bKCOTttUeKp97TLUMC4JEhyoUFKGATmVlB4rCn+UxKZOM8+Gvk0RiHX7py5OvuBUHPE1 2b6Yi6579nRZjxOrgVj/IApZ762Pa+y/k5F0Sgn8sVQhktyKR6Z1ecqWq2G9SIuOhBRC OLKh4rZLZ+ryxcbRbl6pzcbImBcXiC5S4hQfT+zu6YsVJoqBEVSJyRj3yzTOb441wIhc GM1w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b="JoHG/uBT"; 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=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id s197si12151361pfc.152.2021.10.08.04.47.40; Fri, 08 Oct 2021 04:47:53 -0700 (PDT) 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; dkim=pass header.i=@gmail.com header.s=20210112 header.b="JoHG/uBT"; 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=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S240861AbhJHLro (ORCPT + 99 others); Fri, 8 Oct 2021 07:47:44 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:36818 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S243144AbhJHLrH (ORCPT ); Fri, 8 Oct 2021 07:47:07 -0400 Received: from mail-wr1-x42d.google.com (mail-wr1-x42d.google.com [IPv6:2a00:1450:4864:20::42d]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id D1891C08C5E7; Fri, 8 Oct 2021 04:32:18 -0700 (PDT) Received: by mail-wr1-x42d.google.com with SMTP id t2so28806065wrb.8; Fri, 08 Oct 2021 04:32:18 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=message-id:date:mime-version:user-agent:subject:content-language:to :cc:references:from:in-reply-to:content-transfer-encoding; bh=DXpoD3oDZrKV8QtdRuxL6pqOpnLAebcj0SdO2ln/m4Q=; b=JoHG/uBTZMFntcRACH/l+sr2pkbeCEVIUKfEOvxMk1fWVn5q2LHM8DZPmPRFJOd52s ZxJjmOKW7/QvhflfrNabweN1S65/lH0zjlKxZc/tygVFjih2yS5wafk843o/KTHTQqxu cLmgYxNVKLp0zRTVXcyzCb4xKK2ttp+eSzIAK8ANBjfwTbhK2zqnajKjiYzE/YVdVdj1 S09HZ567+0FgaGV91WbgLql6DD/pfjWbDUawiWYgNQHCqoWyTXm9VU0UGaTaGSs4Mhpn kUzdalLUqugjbrsf26a6oUuO+IF92o2rPDRvJjYCvHKknFCsH5FpRaF4+ujGXsyiOOQK oh2Q== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:message-id:date:mime-version:user-agent:subject :content-language:to:cc:references:from:in-reply-to :content-transfer-encoding; bh=DXpoD3oDZrKV8QtdRuxL6pqOpnLAebcj0SdO2ln/m4Q=; b=5z6rKZhK5RB/RE/aZhROrllO05ZGa6slHwp/EVv8Qja4AZztkGLcw4Jv0ClAg7l80c ZMlOQAnj8bCMl1mPQhsyL1R3Xa2SO2yTSotpoO4Vp2DX9eAymzJzzz057TNIj816Y8Ri ULm2C+1oHQ0/UDo9I1zgoeKY+iPkRy9pRVY/EZxZu1emv2W+5WWNBB5g1cAigcPTQBzL pm6jtdBG5gi4j/Hl2EEZxcLVa6IG/IM4fuZOr33Zdjq6qJgaTyA+WwzauuMsbCYEWbtp 7hff7gAKCQriY4Q41Pia3jJguOrKKjNrDWWPiXOTOgZOXtSUNasJFQzEuTl6BPPeJXsZ YQvQ== X-Gm-Message-State: AOAM5314aeQxOqbFII/3P93BXVivsPwNdHupTXRwu/Ao/hnN8SI0rsGB zbUSdrxEAfU2BVvKuVPWArY= X-Received: by 2002:a5d:5889:: with SMTP id n9mr3464217wrf.248.1633692737420; Fri, 08 Oct 2021 04:32:17 -0700 (PDT) Received: from [192.168.2.177] ([206.204.146.29]) by smtp.gmail.com with ESMTPSA id o6sm3272001wri.49.2021.10.08.04.32.15 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Fri, 08 Oct 2021 04:32:16 -0700 (PDT) Message-ID: <9e038baa-9f2e-bc72-e4a7-f184a30ce57a@gmail.com> Date: Fri, 8 Oct 2021 13:32:14 +0200 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:91.0) Gecko/20100101 Thunderbird/91.1.2 Subject: Re: [PATCH v10, 2/5] drm/mediatek: add component POSTMASK Content-Language: en-US To: "yongqiang.niu" , Dafna Hirschfeld , Chun-Kuang Hu Cc: Rob Herring , Philipp Zabel , David Airlie , Daniel Vetter , Jassi Brar , Fabien Parent , Dennis YC Hsieh , devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org, linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org, Project_Global_Chrome_Upstream_Group@mediatek.com, Hsin-Yi Wang , CK Hu References: <20210930155222.5861-1-yongqiang.niu@mediatek.com> <20210930155222.5861-3-yongqiang.niu@mediatek.com> <3eff2cfb15677f03d6dcd724fd977ab48fe101aa.camel@mediatek.com> From: Matthias Brugger In-Reply-To: <3eff2cfb15677f03d6dcd724fd977ab48fe101aa.camel@mediatek.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 08/10/2021 04:09, yongqiang.niu wrote: > On Fri, 2021-10-01 at 13:00 +0200, Dafna Hirschfeld wrote: >> >> On 30.09.21 17:52, Yongqiang Niu wrote: >>> This patch add component POSTMASK. >>> >>> Signed-off-by: Yongqiang Niu >>> Signed-off-by: Hsin-Yi Wang >>> Reviewed-by: CK Hu >>> --- >>> drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.c | 102 ++++++++++++++- >>> ----- >>> drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.h | 1 + >>> 2 files changed, 73 insertions(+), 30 deletions(-) >>> >>> diff --git a/drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.c >>> b/drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.c >>> index 4a2abcf3e5f9..89170ad825fd 100644 >>> --- a/drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.c >>> +++ b/drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.c >>> @@ -62,6 +62,12 @@ >>> #define DITHER_ADD_LSHIFT_G(x) (((x) & 0x7) << >>> 4) >>> #define DITHER_ADD_RSHIFT_G(x) (((x) & 0x7) << >>> 0) >>> >>> +#define DISP_POSTMASK_EN 0x0000 >>> +#define POSTMASK_EN BIT(0) >>> +#define DISP_POSTMASK_CFG 0x0020 >>> +#define POSTMASK_RELAY_MODE BIT(0) >>> +#define DISP_POSTMASK_SIZE 0x0030 >>> + >>> struct mtk_ddp_comp_dev { >>> struct clk *clk; >>> void __iomem *regs; >>> @@ -214,6 +220,32 @@ static void mtk_dither_stop(struct device >>> *dev) >>> writel_relaxed(0x0, priv->regs + DISP_DITHER_EN); >>> } >>> >>> +static void mtk_postmask_config(struct device *dev, unsigned int >>> w, >>> + unsigned int h, unsigned int vrefresh, >>> + unsigned int bpc, struct cmdq_pkt >>> *cmdq_pkt) >>> +{ >>> + struct mtk_ddp_comp_dev *priv = dev_get_drvdata(dev); >>> + >>> + mtk_ddp_write(cmdq_pkt, w << 16 | h, &priv->cmdq_reg, priv- >>>> regs, >>> + DISP_POSTMASK_SIZE); >>> + mtk_ddp_write(cmdq_pkt, POSTMASK_RELAY_MODE, &priv->cmdq_reg, >>> + priv->regs, DISP_POSTMASK_CFG); >>> +} >>> + >>> +static void mtk_postmask_start(struct device *dev) >>> +{ >>> + struct mtk_ddp_comp_dev *priv = dev_get_drvdata(dev); >>> + >>> + writel(POSTMASK_EN, priv->regs + DISP_POSTMASK_EN); >>> +} >>> + >>> +static void mtk_postmask_stop(struct device *dev) >>> +{ >>> + struct mtk_ddp_comp_dev *priv = dev_get_drvdata(dev); >>> + >>> + writel_relaxed(0x0, priv->regs + DISP_POSTMASK_EN); >>> +} >>> + >>> static const struct mtk_ddp_comp_funcs ddp_aal = { >>> .clk_enable = mtk_aal_clk_enable, >>> .clk_disable = mtk_aal_clk_disable, >>> @@ -289,6 +321,14 @@ static const struct mtk_ddp_comp_funcs ddp_ovl >>> = { >>> .bgclr_in_off = mtk_ovl_bgclr_in_off, >>> }; >>> >>> +static const struct mtk_ddp_comp_funcs ddp_postmask = { >>> + .clk_enable = mtk_ddp_clk_enable, >>> + .clk_disable = mtk_ddp_clk_disable, >>> + .config = mtk_postmask_config, >>> + .start = mtk_postmask_start, >>> + .stop = mtk_postmask_stop, >>> +}; >>> + >>> static const struct mtk_ddp_comp_funcs ddp_rdma = { >>> .clk_enable = mtk_rdma_clk_enable, >>> .clk_disable = mtk_rdma_clk_disable, >>> @@ -324,6 +364,7 @@ static const char * const >>> mtk_ddp_comp_stem[MTK_DDP_COMP_TYPE_MAX] = { >>> [MTK_DISP_MUTEX] = "mutex", >>> [MTK_DISP_OD] = "od", >>> [MTK_DISP_BLS] = "bls", >>> + [MTK_DISP_POSTMASK] = "postmask", >>> }; >>> >>> struct mtk_ddp_comp_match { >>> @@ -333,36 +374,37 @@ struct mtk_ddp_comp_match { >>> }; >>> >>> static const struct mtk_ddp_comp_match >>> mtk_ddp_matches[DDP_COMPONENT_ID_MAX] = { >>> - [DDP_COMPONENT_AAL0] = { MTK_DISP_AAL, 0, &ddp_aal >>> }, >>> - [DDP_COMPONENT_AAL1] = { MTK_DISP_AAL, 1, &ddp_aal >>> }, >>> - [DDP_COMPONENT_BLS] = { MTK_DISP_BLS, 0, NULL }, >>> - [DDP_COMPONENT_CCORR] = { MTK_DISP_CCORR, 0, >>> &ddp_ccorr }, >>> - [DDP_COMPONENT_COLOR0] = { MTK_DISP_COLOR, 0, >>> &ddp_color }, >>> - [DDP_COMPONENT_COLOR1] = { MTK_DISP_COLOR, 1, >>> &ddp_color }, >>> - [DDP_COMPONENT_DITHER] = { MTK_DISP_DITHER, 0, >>> &ddp_dither }, >>> - [DDP_COMPONENT_DPI0] = { MTK_DPI, 0, &ddp_dpi >>> }, >>> - [DDP_COMPONENT_DPI1] = { MTK_DPI, 1, &ddp_dpi >>> }, >>> - [DDP_COMPONENT_DSI0] = { MTK_DSI, 0, &ddp_dsi >>> }, >>> - [DDP_COMPONENT_DSI1] = { MTK_DSI, 1, &ddp_dsi >>> }, >>> - [DDP_COMPONENT_DSI2] = { MTK_DSI, 2, &ddp_dsi >>> }, >>> - [DDP_COMPONENT_DSI3] = { MTK_DSI, 3, &ddp_dsi >>> }, >>> - [DDP_COMPONENT_GAMMA] = { MTK_DISP_GAMMA, 0, >>> &ddp_gamma }, >>> - [DDP_COMPONENT_OD0] = { MTK_DISP_OD, 0, &ddp_od }, >>> - [DDP_COMPONENT_OD1] = { MTK_DISP_OD, 1, &ddp_od }, >>> - [DDP_COMPONENT_OVL0] = { MTK_DISP_OVL, 0, &ddp_ovl >>> }, >>> - [DDP_COMPONENT_OVL1] = { MTK_DISP_OVL, 1, &ddp_ovl >>> }, >>> - [DDP_COMPONENT_OVL_2L0] = { MTK_DISP_OVL_2L, 0, &ddp_ovl >>> }, >>> - [DDP_COMPONENT_OVL_2L1] = { MTK_DISP_OVL_2L, 1, &ddp_ovl >>> }, >>> - [DDP_COMPONENT_OVL_2L2] = { MTK_DISP_OVL_2L, 2, &ddp_ovl }, >>> - [DDP_COMPONENT_PWM0] = { MTK_DISP_PWM, 0, NULL }, >>> - [DDP_COMPONENT_PWM1] = { MTK_DISP_PWM, 1, NULL }, >>> - [DDP_COMPONENT_PWM2] = { MTK_DISP_PWM, 2, NULL }, >>> - [DDP_COMPONENT_RDMA0] = { MTK_DISP_RDMA, 0, >>> &ddp_rdma }, >>> - [DDP_COMPONENT_RDMA1] = { MTK_DISP_RDMA, 1, >>> &ddp_rdma }, >>> - [DDP_COMPONENT_RDMA2] = { MTK_DISP_RDMA, 2, >>> &ddp_rdma }, >>> - [DDP_COMPONENT_UFOE] = { MTK_DISP_UFOE, 0, >>> &ddp_ufoe }, >>> - [DDP_COMPONENT_WDMA0] = { MTK_DISP_WDMA, 0, NULL }, >>> - [DDP_COMPONENT_WDMA1] = { MTK_DISP_WDMA, 1, NULL }, >>> + [DDP_COMPONENT_AAL0] = { MTK_DISP_AAL, 0, >>> &ddp_aal }, >>> + [DDP_COMPONENT_AAL1] = { MTK_DISP_AAL, 1, >>> &ddp_aal }, >>> + [DDP_COMPONENT_BLS] = { MTK_DISP_BLS, 0, NULL }, >>> + [DDP_COMPONENT_CCORR] = { MTK_DISP_CCORR, 0, >>> &ddp_ccorr }, >>> + [DDP_COMPONENT_COLOR0] = { MTK_DISP_COLOR, 0, >>> &ddp_color }, >>> + [DDP_COMPONENT_COLOR1] = { MTK_DISP_COLOR, 1, >>> &ddp_color }, >>> + [DDP_COMPONENT_DITHER] = { MTK_DISP_DITHER, 0, >>> &ddp_dither }, >>> + [DDP_COMPONENT_DPI0] = { MTK_DPI, 0, >>> &ddp_dpi }, >>> + [DDP_COMPONENT_DPI1] = { MTK_DPI, 1, >>> &ddp_dpi }, >>> + [DDP_COMPONENT_DSI0] = { MTK_DSI, 0, >>> &ddp_dsi }, >>> + [DDP_COMPONENT_DSI1] = { MTK_DSI, 1, >>> &ddp_dsi }, >>> + [DDP_COMPONENT_DSI2] = { MTK_DSI, 2, >>> &ddp_dsi }, >>> + [DDP_COMPONENT_DSI3] = { MTK_DSI, 3, >>> &ddp_dsi }, >>> + [DDP_COMPONENT_GAMMA] = { MTK_DISP_GAMMA, 0, >>> &ddp_gamma }, >>> + [DDP_COMPONENT_OD0] = { MTK_DISP_OD, 0, &ddp_od >>> }, >>> + [DDP_COMPONENT_OD1] = { MTK_DISP_OD, 1, &ddp_od >>> }, >>> + [DDP_COMPONENT_OVL0] = { MTK_DISP_OVL, 0, >>> &ddp_ovl }, >>> + [DDP_COMPONENT_OVL1] = { MTK_DISP_OVL, 1, >>> &ddp_ovl }, >>> + [DDP_COMPONENT_OVL_2L0] = { MTK_DISP_OVL_2L, 0, >>> &ddp_ovl }, >>> + [DDP_COMPONENT_OVL_2L1] = { MTK_DISP_OVL_2L, 1, >>> &ddp_ovl }, >>> + [DDP_COMPONENT_OVL_2L2] = { MTK_DISP_OVL_2L, 2, >>> &ddp_ovl }, >>> + [DDP_COMPONENT_POSTMASK0] = { MTK_DISP_POSTMASK, 0, >>> &ddp_postmask }, >> >> Hi, I can't see where is DDP_COMPONENT_POSTMASK0 defined. >> >> Thanks, >> Dafna > > it is defined in mtk_mmsys.h > > > https://patchwork.kernel.org/project/linux-mediatek/patch/20210930155222.5861-3-yongqiang.niu@mediatek.com/ > That link is not really usefull. It's part of my maintainer repo: https://git.kernel.org/pub/scm/linux/kernel/git/matthias.bgg/linux.git/log/?h=v5.15-next/soc My fault not having pushed that to linux-next. Regards, Matthias >> >>> + [DDP_COMPONENT_PWM0] = { MTK_DISP_PWM, 0, >>> NULL }, >>> + [DDP_COMPONENT_PWM1] = { MTK_DISP_PWM, 1, >>> NULL }, >>> + [DDP_COMPONENT_PWM2] = { MTK_DISP_PWM, 2, >>> NULL }, >>> + [DDP_COMPONENT_RDMA0] = { MTK_DISP_RDMA, 0, >>> &ddp_rdma }, >>> + [DDP_COMPONENT_RDMA1] = { MTK_DISP_RDMA, 1, >>> &ddp_rdma }, >>> + [DDP_COMPONENT_RDMA2] = { MTK_DISP_RDMA, 2, >>> &ddp_rdma }, >>> + [DDP_COMPONENT_UFOE] = { MTK_DISP_UFOE, 0, >>> &ddp_ufoe }, >>> + [DDP_COMPONENT_WDMA0] = { MTK_DISP_WDMA, 0, >>> NULL }, >>> + [DDP_COMPONENT_WDMA1] = { MTK_DISP_WDMA, 1, >>> NULL }, >>> }; >>> >>> static bool mtk_drm_find_comp_in_ddp(struct device *dev, >>> diff --git a/drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.h >>> b/drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.h >>> index bb914d976cf5..cd1dec6b4cdf 100644 >>> --- a/drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.h >>> +++ b/drivers/gpu/drm/mediatek/mtk_drm_ddp_comp.h >>> @@ -30,6 +30,7 @@ enum mtk_ddp_comp_type { >>> MTK_DISP_UFOE, >>> MTK_DSI, >>> MTK_DPI, >>> + MTK_DISP_POSTMASK, >>> MTK_DISP_PWM, >>> MTK_DISP_MUTEX, >>> MTK_DISP_OD, >>>