Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp1521318imm; Wed, 8 Aug 2018 19:43:12 -0700 (PDT) X-Google-Smtp-Source: AA+uWPxQedMBYe1fYgoFVYbcnVBAHQhYLpowTAeP/ROSsoIZvRCQQSjGQsBl9nX3uI44slbJbmgk X-Received: by 2002:a63:a042:: with SMTP id u2-v6mr295140pgn.80.1533782592449; Wed, 08 Aug 2018 19:43:12 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1533782592; cv=none; d=google.com; s=arc-20160816; b=1I3vjIcjdFWEEOvHE5QDCiUnJcC1gKRvoQQktpWTjmHmgsQnWhqhFewww4+jr8Rdyo 0MW+vMluJlsgp8bBdEPfOYGzi6L+1u5VS/1bvNzlpRRR/UNreNgqYnMtIiAXvEmHPgKN aaEy9WU5aga0UlsJn6DYl59wYozUHnRYhTfK6vf97fDtGFxA7bfsUw2HoGVMXrAwxtUB SKdh8DBDBS+Y/+OZ9oSzeycSvk7OnW1jiQOn1h59/tl5orUJf9e5ZSUwNeBRFoJ4y2xI tgO+2iA4/T5IRfPf/Zz8j41pRNJrdRYhor7AAYVSQ7NH/y0eAwKCds3E+G0SUbFRtfku Kgrg== 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:date:cc:to:from:subject:message-id :arc-authentication-results; bh=xnwlVDq/e0QEu0EkcZ5s7mvoTTki1uPT6SMQO95rBiI=; b=aZDp8F9KUrg1kWlBdX7ALA7aot2z7hGTe9Q5iv4+6tAgHHLBQcvVG5tRKrjjj0pdOV pOBbho8qOYLT0qNgK94Zn7owKjaPQtRR2q8LTHPdbhI2nOOz3Pxp8JimApfNa6gSebbX 4ErmfhGiAeTZXWjPnCRpDYhOFvIdPNVBEEapaz25I8UIoDU5AGyteoDzW0la+2ltbbIN SY/uP1rrtQcapVqMlKfBb8w3q0QvVo4AfXkbHyIVx8tieRXMBazVKnI2zfzNsiE346Th M4hd2/F//3QtBe0UFtxSMFq4001Vmer+FHr+s0pn7+hKlAt8/WEdp8VVpLSKdkuuvAup n8Ww== ARC-Authentication-Results: i=1; mx.google.com; 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 x65-v6si6297572pff.196.2018.08.08.19.42.58; Wed, 08 Aug 2018 19:43:12 -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; 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 S1727716AbeHIFED (ORCPT + 99 others); Thu, 9 Aug 2018 01:04:03 -0400 Received: from mailgw01.mediatek.com ([210.61.82.183]:6367 "EHLO mailgw01.mediatek.com" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S1725779AbeHIFEC (ORCPT ); Thu, 9 Aug 2018 01:04:02 -0400 X-UUID: e3558f404bc54e48a04a38b7a7bd5483-20180809 Received: from mtkcas09.mediatek.inc [(172.21.101.178)] by mailgw01.mediatek.com (envelope-from ) (mhqrelay.mediatek.com ESMTP with TLS) with ESMTP id 1682476938; Thu, 09 Aug 2018 10:41:27 +0800 Received: from MTKCAS06.mediatek.inc (172.21.101.30) by mtkmbs01n2.mediatek.inc (172.21.101.79) with Microsoft SMTP Server (TLS) id 15.0.1210.3; Thu, 9 Aug 2018 10:41:26 +0800 Received: from [172.21.77.4] (172.21.77.4) by MTKCAS06.mediatek.inc (172.21.101.73) with Microsoft SMTP Server id 15.0.1210.3 via Frontend Transport; Thu, 9 Aug 2018 10:41:26 +0800 Message-ID: <1533782486.29986.2.camel@mtksdaap41> Subject: Re: [PATCH v4 08/14] drm/mediatek: add YUYV/UYVY color format support for RDMA From: CK Hu To: Stu Hsieh CC: Philipp Zabel , David Airlie , Matthias Brugger , , , , , Date: Thu, 9 Aug 2018 10:41:26 +0800 In-Reply-To: <1533780949-30141-9-git-send-email-stu.hsieh@mediatek.com> References: <1533780949-30141-1-git-send-email-stu.hsieh@mediatek.com> <1533780949-30141-9-git-send-email-stu.hsieh@mediatek.com> Content-Type: text/plain; charset="UTF-8" X-Mailer: Evolution 3.10.4-0ubuntu2 MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-MTK: N Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi, Stu: On Thu, 2018-08-09 at 10:15 +0800, Stu Hsieh wrote: > This patch add YUYV/UYVY color format support for RDMA > and transform matrix for YUYV/UYVY. > > Signed-off-by: Stu Hsieh Reviewed-by: CK Hu > --- > drivers/gpu/drm/mediatek/mtk_disp_rdma.c | 20 ++++++++++++++++++++ > 1 file changed, 20 insertions(+) > > diff --git a/drivers/gpu/drm/mediatek/mtk_disp_rdma.c b/drivers/gpu/drm/mediatek/mtk_disp_rdma.c > index 1f57f86c7910..8b015c2d4418 100644 > --- a/drivers/gpu/drm/mediatek/mtk_disp_rdma.c > +++ b/drivers/gpu/drm/mediatek/mtk_disp_rdma.c > @@ -33,6 +33,8 @@ > #define RDMA_ENGINE_EN BIT(0) > #define RDMA_MODE_MEMORY BIT(1) > #define DISP_REG_RDMA_SIZE_CON_0 0x0014 > +#define RDMA_MATRIX_ENABLE BIT(17) > +#define RDMA_MATRIX_INT_MTX_BT601_to_RGB (6 << 20) > #define DISP_REG_RDMA_SIZE_CON_1 0x0018 > #define DISP_REG_RDMA_TARGET_LINE 0x001c > #define DISP_RDMA_MEM_CON 0x0024 > @@ -46,12 +48,15 @@ > #define RDMA_FIFO_SIZE(rdma) ((rdma)->data->fifo_size) > #define DISP_RDMA_MEM_START_ADDR 0x0f00 > > +#define RDMA_MATRIX_INT_MTX_SEL GENMASK(23, 20) > #define RDMA_MEM_GMC 0x40402020 > > #define MEM_MODE_INPUT_FORMAT_RGB565 0x0 > #define MEM_MODE_INPUT_FORMAT_RGB888 (0x001 << 4) > #define MEM_MODE_INPUT_FORMAT_RGBA8888 (0x002 << 4) > #define MEM_MODE_INPUT_FORMAT_ARGB8888 (0x003 << 4) > +#define MEM_MODE_INPUT_FORMAT_UYVY (0x004 << 4) > +#define MEM_MODE_INPUT_FORMAT_YUYV (0x005 << 4) > > struct mtk_disp_rdma_data { > unsigned int fifo_size; > @@ -181,6 +186,10 @@ static unsigned int rdma_fmt_convert(struct mtk_disp_rdma *rdma, > case DRM_FORMAT_XBGR8888: > case DRM_FORMAT_ABGR8888: > return MEM_MODE_INPUT_FORMAT_RGBA8888 | MEM_MODE_INPUT_SWAP; > + case DRM_FORMAT_UYVY: > + return MEM_MODE_INPUT_FORMAT_UYVY; > + case DRM_FORMAT_YUYV: > + return MEM_MODE_INPUT_FORMAT_YUYV; > } > } > > @@ -197,6 +206,17 @@ static void mtk_rdma_layer_config(struct mtk_ddp_comp *comp, unsigned int idx, > con = rdma_fmt_convert(rdma, fmt); > writel_relaxed(con, comp->regs + DISP_RDMA_MEM_CON); > > + if (fmt == DRM_FORMAT_UYVY || fmt == DRM_FORMAT_YUYV) { > + rdma_update_bits(comp, DISP_REG_RDMA_SIZE_CON_0, > + RDMA_MATRIX_ENABLE, RDMA_MATRIX_ENABLE); > + rdma_update_bits(comp, DISP_REG_RDMA_SIZE_CON_0, > + RDMA_MATRIX_INT_MTX_SEL, > + RDMA_MATRIX_INT_MTX_BT601_to_RGB); > + } else { > + rdma_update_bits(comp, DISP_REG_RDMA_SIZE_CON_0, > + RDMA_MATRIX_ENABLE, 0); > + } > + > writel_relaxed(addr, comp->regs + DISP_RDMA_MEM_START_ADDR); > writel_relaxed(pitch, comp->regs + DISP_RDMA_MEM_SRC_PITCH); > writel(RDMA_MEM_GMC, comp->regs + DISP_RDMA_MEM_GMC_SETTING_0);