Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp4514842imm; Tue, 7 Aug 2018 02:53:30 -0700 (PDT) X-Google-Smtp-Source: AAOMgpdZ8ORGHpbfY4LTwHJvaq/VffnSdzp/uXWLrVu2pXyBqz2FYJOKp5lw0NSei89LOUHthoOr X-Received: by 2002:a65:6292:: with SMTP id f18-v6mr17961201pgv.85.1533635610642; Tue, 07 Aug 2018 02:53:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1533635610; cv=none; d=google.com; s=arc-20160816; b=VG8t0UfR+ZCVLmkGpwIQcw3wwp44lUDQC6IZPHmzUX/8Obu2sQ/C0W2oDUcBbM1sRS nAPltLxbAOV2EVcVBE7NyPefjoXvksXd4nGJ0MLlmcIg/TyNlTQ4EfheGO875ZTiGrjV ByoCFP3EP3i+pXdJvlbFQvztoh2pTrFGxw/9/UI3rzCOjTjIt+0TrTAd/lIvPa8cfWBU 2lUDwnm+ojsJZ43e2Vp4KkzeBDTjHg+Uk+2/Plsc9qye1UF3ao5htZoeNmIpq/CKr/Mv 8PiUgXI2R3K4D66heF2qUrlSuFabHOfqklDRASI4oKz5Zwv9k16EhiI+PgbMsIDj4CyJ cwRg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:content-transfer-encoding :references:in-reply-to:date:cc:to:from:subject:message-id :arc-authentication-results; bh=usmkboBifT82W9W2KPvjJqCaSMKAK1dhpeCdFmcMtX4=; b=utWZIYp4LP4Xm0v/P6cjTA5L+gm/jxQuwjbR4BKUlrHXghlyhrHNGBLe+gJY4vWxi6 qgvsQlKTx9vN900bMJRAxHmEGSi+lE1qcc+XR/uMTY0M1UZOoQzVr8MRKSgTcjwdP6m+ +GR76BdDPsBPXLIt4Z5op059s70UTi3O9pexmMN6GsIZVixybHEBqvOeNf0EiPuci5Be /pcK0TjrZD+j5kUbq9KqG4VhqJ6VUvPu8m/riUWLNv7v0uIFeCau57SkIA2GWmPMbKHV OD6JBell+1UQadAo3ye2q+y5nTSwTO5cyuiK12w6mv68Y9FLNrYLyRCjHiEWvFbjB6ii 558Q== 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 e132-v6si1026106pfg.171.2018.08.07.02.52.52; Tue, 07 Aug 2018 02:53:30 -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 S2388354AbeHGMCs (ORCPT + 99 others); Tue, 7 Aug 2018 08:02:48 -0400 Received: from mailgw02.mediatek.com ([210.61.82.184]:21264 "EHLO mailgw02.mediatek.com" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S2387677AbeHGMCr (ORCPT ); Tue, 7 Aug 2018 08:02:47 -0400 X-UUID: 29fd712761714056957751dcac96eab0-20180807 Received: from mtkcas08.mediatek.inc [(172.21.101.126)] by mailgw02.mediatek.com (envelope-from ) (mhqrelay.mediatek.com ESMTP with TLS) with ESMTP id 512792169; Tue, 07 Aug 2018 17:49:05 +0800 Received: from mtkcas07.mediatek.inc (172.21.101.84) by mtkmbs03n2.mediatek.inc (172.21.101.182) with Microsoft SMTP Server (TLS) id 15.0.1210.3; Tue, 7 Aug 2018 17:49:03 +0800 Received: from [172.21.84.99] (172.21.84.99) by mtkcas07.mediatek.inc (172.21.101.73) with Microsoft SMTP Server id 15.0.1210.3 via Frontend Transport; Tue, 7 Aug 2018 17:49:03 +0800 Message-ID: <1533635342.11190.73.camel@mtksdccf07> Subject: Re: [PATCH v3 07/13] drm/mediatek: add YUYV/UYVY color format support for RDMA From: Stu Hsieh To: CK Hu CC: Philipp Zabel , David Airlie , Matthias Brugger , , , , , Date: Tue, 7 Aug 2018 17:49:02 +0800 In-Reply-To: <1533612817.22668.5.camel@mtksdaap41> References: <1533556700-26525-1-git-send-email-stu.hsieh@mediatek.com> <1533556700-26525-8-git-send-email-stu.hsieh@mediatek.com> <1533612817.22668.5.camel@mtksdaap41> Content-Type: text/plain; charset="UTF-8" X-Mailer: Evolution 3.2.3-0ubuntu6 Content-Transfer-Encoding: 7bit MIME-Version: 1.0 X-MTK: N Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi, CK: On Tue, 2018-08-07 at 11:33 +0800, CK Hu wrote: > 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 > OK Regards, Stu > > + 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); > >