Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp4244871imm; Mon, 6 Aug 2018 20:46:11 -0700 (PDT) X-Google-Smtp-Source: AAOMgpcgqdblmtFK6L6QBoFGI5U9FH6d5CHmTnRQ4kOVyOvxSffKulmtnXWxxyQi1s/MPjvoYYW7 X-Received: by 2002:a62:15c8:: with SMTP id 191-v6mr19662950pfv.194.1533613571429; Mon, 06 Aug 2018 20:46:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1533613571; cv=none; d=google.com; s=arc-20160816; b=iNHxC8kAWIcmlsuwzSoMtciBhlPQInrnYXLZtzJD9Nncm4XHvCEijqAM0WTuGgRQru USrJiyHfm7RVJLiq5PIuo1ImaRFaVSFfQ9SOzzODXYBVv4i/b36AC+dUrGYWhA0e6ORP g2i9T9/pfjCa0V5sZuxVy6M0seNFs0C5+neJm9d2buvqE3oyKymMCytJc3D8R6P5rh1C YKtCwP2XJ+rmHzUnOmP+tenpB7aKA9sijHnU044QunGNRXhVfk6UfIFBWnU+Y3u6hRiL 7uMD1S8SJyXdt0R1NNNkSNBn/waRKqNdgo5nwZsaV902b/wdohKN4zwQRKr2k2l745bf lYMA== 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=bFvsb6WRpcIEZ7vI/uBPlKYmzRXPIwMZymRNC41RBv4=; b=XrRTCQFKOYQLyidDE1OBArglZGLno2HLRtav0hLNlsANsECtjRkDZX5Wu9mn6kpUKR uzs+uwETXHMpxT22/paj+vlHgwt1YSZzV/bJDOqJD1k8KbpBIlcfy1yuS3qV9+l0GIwS eeMRLm18JwWLCQzcSIrYl4w+MIm+2OcXNSbdpXcL2uyJOrYbdGwGsG7P1+ozSiPLqo+o zfbQpuC/zvMFBgOzn7gS/L9zLiu2UlVs+4jl5wsugzDKN+KuMYdN1SUwpSjdcldTGz83 afMvf061lpJYTpYh2uXBe4pol9FMoA07axV7EBcDJdtTkoXxC6KHA6MwVRyOSMJkoAmy OI0A== 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 r5-v6si276528pga.602.2018.08.06.20.45.56; Mon, 06 Aug 2018 20:46:11 -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 S1732564AbeHGFp5 (ORCPT + 99 others); Tue, 7 Aug 2018 01:45:57 -0400 Received: from mailgw01.mediatek.com ([210.61.82.183]:34723 "EHLO mailgw01.mediatek.com" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S1726951AbeHGFp5 (ORCPT ); Tue, 7 Aug 2018 01:45:57 -0400 X-UUID: 1335ec8207544b1fbef869c1545d02b2-20180807 Received: from mtkexhb01.mediatek.inc [(172.21.101.102)] by mailgw01.mediatek.com (envelope-from ) (mhqrelay.mediatek.com ESMTP with TLS) with ESMTP id 1396005098; Tue, 07 Aug 2018 11:33:39 +0800 Received: from MTKCAS06.mediatek.inc (172.21.101.30) by mtkmbs03n1.mediatek.inc (172.21.101.181) with Microsoft SMTP Server (TLS) id 15.0.1210.3; Tue, 7 Aug 2018 11:33:37 +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; Tue, 7 Aug 2018 11:33:37 +0800 Message-ID: <1533612817.22668.5.camel@mtksdaap41> Subject: Re: [PATCH v3 07/13] drm/mediatek: add YUYV/UYVY color format support for RDMA From: CK Hu To: Stu Hsieh CC: Philipp Zabel , David Airlie , Matthias Brugger , , , , , Date: Tue, 7 Aug 2018 11:33:37 +0800 In-Reply-To: <1533556700-26525-8-git-send-email-stu.hsieh@mediatek.com> References: <1533556700-26525-1-git-send-email-stu.hsieh@mediatek.com> <1533556700-26525-8-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 Mon, 2018-08-06 at 19:58 +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 > --- > drivers/gpu/drm/mediatek/mtk_disp_rdma.c | 15 +++++++++++++++ > 1 file changed, 15 insertions(+) > > diff --git a/drivers/gpu/drm/mediatek/mtk_disp_rdma.c b/drivers/gpu/drm/mediatek/mtk_disp_rdma.c > index ba72d392dc27..91a8b6e27d39 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_SEL (7UL << 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 MATRIX_INT_MTX_SEL_DEFAULT 0xb00000 > #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; > @@ -176,6 +181,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; > } > } > > @@ -191,6 +200,12 @@ 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, 0xff0000, Symbolize 0xff0000. Maybe you should define as #define RDMA_MATRIX_INT_MTX_SEL GENMASK(23, 20) #define RDMA_MATRIX_INT_MTX_YUV_TO_RGB 0x7 #define RDMA_MATRIX_INT_MTX_RGB_TO_RGB 0xb Correct the naming to align data sheet. Regards, CK > + RDMA_MATRIX_ENABLE | RDMA_MATRIX_INT_MTX_SEL); > + else > + rdma_update_bits(comp, DISP_REG_RDMA_SIZE_CON_0, 0xff0000, > + MATRIX_INT_MTX_SEL_DEFAULT); > > writel_relaxed(addr, comp->regs + DISP_RDMA_MEM_START_ADDR); > writel_relaxed(pitch, comp->regs + DISP_RDMA_MEM_SRC_PITCH);