All of lore.kernel.org
 help / color / mirror / Atom feed
From: Rex-BC Chen <rex-bc.chen@mediatek.com>
To: CK Hu <ck.hu@mediatek.com>, <chunkuang.hu@kernel.org>,
	<p.zabel@pengutronix.de>, <daniel@ffwll.ch>, <robh+dt@kernel.org>,
	<krzysztof.kozlowski+dt@linaro.org>, <matthias.bgg@gmail.com>,
	<airlied@linux.ie>
Cc: <msp@baylibre.com>, <granquet@baylibre.com>,
	<jitao.shi@mediatek.com>, <wenst@chromium.org>,
	<angelogioacchino.delregno@collabora.com>,
	<xinlei.lee@mediatek.com>, <liangxu.xu@mediatek.com>,
	<dri-devel@lists.freedesktop.org>,
	<linux-mediatek@lists.infradead.org>,
	<devicetree@vger.kernel.org>, <linux-kernel@vger.kernel.org>,
	<linux-arm-kernel@lists.infradead.org>,
	<Project_Global_Chrome_Upstream_Group@mediatek.com>
Subject: Re: [PATCH v15 13/16] drm/mediatek: dpi: Add YUV422 output support
Date: Tue, 5 Jul 2022 16:51:57 +0800	[thread overview]
Message-ID: <6b472fa9e7ce6da775b222b0f9ee00b6d8552dd1.camel@mediatek.com> (raw)
In-Reply-To: <807fa1a3e896eaaa02aec6166f5fb833d7917da7.camel@mediatek.com>

On Tue, 2022-07-05 at 16:39 +0800, Rex-BC Chen wrote:
> On Tue, 2022-07-05 at 13:21 +0800, CK Hu wrote:
> > Hi, Bo-Chen:
> > 
> > On Fri, 2022-07-01 at 11:58 +0800, Bo-Chen Chen wrote:
> > > Dp_intf supports YUV422 as output format. In MT8195 Chrome
> > > project,
> > > YUV422 output format is used for 4K resolution.
> > > 
> > > To support this, it is also needed to support color format
> > > transfer.
> > > Color format transfer is a new feature for both dpi and dpintf of
> > > MT8195.
> > > 
> > > The input format could be RGB888 and output format for dp_intf
> > > should
> > > be
> > > YUV422. Therefore, we add a mtk_dpi_matrix_sel() helper to update
> > > the
> > > DPI_MATRIX_SET register depending on the color format.
> > > 
> > > Signed-off-by: Guillaume Ranquet <granquet@baylibre.com>
> > > Signed-off-by: Bo-Chen Chen <rex-bc.chen@mediatek.com>
> > > Reviewed-by: AngeloGioacchino Del Regno <
> > > angelogioacchino.delregno@collabora.com>
> > > ---
> > >  drivers/gpu/drm/mediatek/mtk_dpi.c      | 61
> > > +++++++++++++++++++++
> > > ----
> > >  drivers/gpu/drm/mediatek/mtk_dpi_regs.h |  6 +++
> > >  2 files changed, 59 insertions(+), 8 deletions(-)
> > > 
> > > diff --git a/drivers/gpu/drm/mediatek/mtk_dpi.c
> > > b/drivers/gpu/drm/mediatek/mtk_dpi.c
> > > index 3085033becbd..0a604bf68b1b 100644
> > > --- a/drivers/gpu/drm/mediatek/mtk_dpi.c
> > > +++ b/drivers/gpu/drm/mediatek/mtk_dpi.c
> > > @@ -54,7 +54,8 @@ enum mtk_dpi_out_channel_swap {
> > >  };
> > >  
> > >  enum mtk_dpi_out_color_format {
> > > -	MTK_DPI_COLOR_FORMAT_RGB
> > > +	MTK_DPI_COLOR_FORMAT_RGB,
> > > +	MTK_DPI_COLOR_FORMAT_YCBCR_422
> > >  };
> > >  
> > >  struct mtk_dpi {
> > > @@ -122,6 +123,7 @@ struct mtk_dpi_yc_limit {
> > >   * @num_output_fmts: Quantity of supported output formats.
> > >   * @is_ck_de_pol: Support CK/DE polarity.
> > >   * @swap_input_support: Support input swap function.
> > > + * @color_fmt_trans_support: Enable color format transfer.
> > >   * @dimension_mask: Mask used for HWIDTH, HPORCH, VSYNC_WIDTH
> > > and
> > > VSYNC_PORCH
> > >   *		    (no shift).
> > >   * @hvsize_mask: Mask of HSIZE and VSIZE mask (no shift).
> > > @@ -138,6 +140,7 @@ struct mtk_dpi_conf {
> > >  	u32 num_output_fmts;
> > >  	bool is_ck_de_pol;
> > >  	bool swap_input_support;
> > > +	bool color_fmt_trans_support;
> > >  	u32 dimension_mask;
> > >  	u32 hvsize_mask;
> > >  	u32 channel_swap_shift;
> > > @@ -406,15 +409,54 @@ static void
> > > mtk_dpi_config_disable_edge(struct
> > > mtk_dpi *dpi)
> > >  		mtk_dpi_mask(dpi, dpi->conf->reg_h_fre_con, 0,
> > > EDGE_SEL_EN);
> > >  }
> > >  
> > > +static void mtk_dpi_matrix_sel(struct mtk_dpi *dpi,
> > > +			       enum mtk_dpi_out_color_format format)
> > 
> > The format would only be MTK_DPI_COLOR_FORMAT_YCBCR_422, so drop
> > the
> > parameter format.
> > 
> > > +{
> > > +	u32 matrix_sel;
> > > +
> > > +	if (!dpi->conf->color_fmt_trans_support) {
> > 
> > Only YUV format would call this function, and I think YUV support
> > would
> > imply that color_fmt_trans_support is true. So drop
> > color_fmt_trans_support.
> > 
> > > +		dev_info(dpi->dev, "matrix_sel is not supported.\n");
> > > +		return;
> > > +	}
> > > +
> > > +	switch (format) {
> > > +	case MTK_DPI_COLOR_FORMAT_YCBCR_422:
> > > +		/*
> > > +		 * If height is smaller than 720, we need to use
> > > RGB_TO_BT601
> > > +		 * to transfer to yuv422. Otherwise, we use
> > > RGB_TO_JPEG.
> > > +		 */
> > > +		if (dpi->mode.hdisplay <= 720)
> > > +			matrix_sel = MATRIX_SEL_RGB_TO_BT601;
> > > +		else
> > > +			matrix_sel = MATRIX_SEL_RGB_TO_JPEG;
> > > +		break;
> > > +	default:
> > > +		matrix_sel = MATRIX_SEL_RGB_TO_JPEG;
> > > +		break;
> > > +	}
> > > +	mtk_dpi_mask(dpi, DPI_MATRIX_SET, matrix_sel,
> > > INT_MATRIX_SEL_MASK);
> > 
> > it seems that we could drop this function and write register as:
> > 
> > mtk_dpi_mask(dpi, DPI_MATRIX_SET, dpi->mode.hdisplay <= 720
> > ? MATRIX_SEL_RGB_TO_BT601 : MATRIX_SEL_RGB_TO_JPEG,
> > INT_MATRIX_SEL_MASK);
> > 
> 
> Hello CK,
> 
> ok, I will drop this function and config.
> 
> > > +}
> > > +
> > >  static void mtk_dpi_config_color_format(struct mtk_dpi *dpi,
> > >  					enum mtk_dpi_out_color_format
> > > format)
> > >  {
> > > -	/* only support RGB888 */
> > > -	mtk_dpi_config_yuv422_enable(dpi, false);
> > > -	mtk_dpi_config_csc_enable(dpi, false);
> > > -	if (dpi->conf->swap_input_support)
> > > -		mtk_dpi_config_swap_input(dpi, false);
> > > -	mtk_dpi_config_channel_swap(dpi, MTK_DPI_OUT_CHANNEL_SWAP_RGB);
> > > +	if (format == MTK_DPI_COLOR_FORMAT_YCBCR_422) {
> > > +		mtk_dpi_config_yuv422_enable(dpi, true);
> > > +		mtk_dpi_config_csc_enable(dpi, true);
> > > +		mtk_dpi_matrix_sel(dpi, format);
> > > +		if (dpi->conf->swap_input_support)
> > 
> > This would never be true because only MT8195 support
> > MTK_DPI_COLOR_FORMAT_YCBCR_422 and swap_input_support of MT8195 is
> > false.
> > 
> 
> I think for mt8195, it should be support output format yuv422 and
> rgb888.
> 
> please refer to [16/16]
> 
> +static const u32 mt8195_output_fmts[] = {
> +	MEDIA_BUS_FMT_RGB888_1X24,
> +	MEDIA_BUS_FMT_YUYV8_1X16,
> +};
> 
> BRs,
> Bo-Chen

Hello CK,

Sorry, I misunderstand your comments.
ok, I will drop this.

BRs,
Bo-Chen
> > Regards,
> > CK
> > 
> > > +			mtk_dpi_config_swap_input(dpi, true);
> > > +		else
> > > +			dev_warn(dpi->dev,
> > > +				 "Failed to swap input, hw is not
> > > supported.\n");
> > > +		mtk_dpi_config_channel_swap(dpi,
> > > MTK_DPI_OUT_CHANNEL_SWAP_RGB);
> > > +	} else {
> > > +		mtk_dpi_config_yuv422_enable(dpi, false);
> > > +		mtk_dpi_config_csc_enable(dpi, false);
> > > +		if (dpi->conf->swap_input_support)
> > > +			mtk_dpi_config_swap_input(dpi, false);
> > > +		mtk_dpi_config_channel_swap(dpi,
> > > MTK_DPI_OUT_CHANNEL_SWAP_RGB);
> > > +	}
> > >  }
> > >  
> > >  static void mtk_dpi_dual_edge(struct mtk_dpi *dpi)
> > > @@ -649,7 +691,10 @@ static int
> > > mtk_dpi_bridge_atomic_check(struct
> > > drm_bridge *bridge,
> > >  	dpi->bit_num = MTK_DPI_OUT_BIT_NUM_8BITS;
> > >  	dpi->channel_swap = MTK_DPI_OUT_CHANNEL_SWAP_RGB;
> > >  	dpi->yc_map = MTK_DPI_OUT_YC_MAP_RGB;
> > > -	dpi->color_format = MTK_DPI_COLOR_FORMAT_RGB;
> > > +	if (out_bus_format == MEDIA_BUS_FMT_YUYV8_1X16)
> > > +		dpi->color_format = MTK_DPI_COLOR_FORMAT_YCBCR_422;
> > > +	else
> > > +		dpi->color_format = MTK_DPI_COLOR_FORMAT_RGB;
> > >  
> > >  	return 0;
> > >  }
> > > diff --git a/drivers/gpu/drm/mediatek/mtk_dpi_regs.h
> > > b/drivers/gpu/drm/mediatek/mtk_dpi_regs.h
> > > index 3a02fabe1662..9ce300313f3e 100644
> > > --- a/drivers/gpu/drm/mediatek/mtk_dpi_regs.h
> > > +++ b/drivers/gpu/drm/mediatek/mtk_dpi_regs.h
> > > @@ -217,4 +217,10 @@
> > >  
> > >  #define EDGE_SEL_EN			BIT(5)
> > >  #define H_FRE_2N			BIT(25)
> > > +
> > > +#define DPI_MATRIX_SET		0xB4
> > > +#define INT_MATRIX_SEL_MASK		GENMASK(4, 0)
> > > +#define MATRIX_SEL_RGB_TO_JPEG		0
> > > +#define MATRIX_SEL_RGB_TO_BT601		2
> > > +
> > >  #endif /* __MTK_DPI_REGS_H */
> > 
> > 
> 
> 


WARNING: multiple messages have this Message-ID (diff)
From: Rex-BC Chen <rex-bc.chen@mediatek.com>
To: CK Hu <ck.hu@mediatek.com>, <chunkuang.hu@kernel.org>,
	<p.zabel@pengutronix.de>, <daniel@ffwll.ch>, <robh+dt@kernel.org>,
	<krzysztof.kozlowski+dt@linaro.org>, <matthias.bgg@gmail.com>,
	<airlied@linux.ie>
Cc: <msp@baylibre.com>, <granquet@baylibre.com>,
	<jitao.shi@mediatek.com>, <wenst@chromium.org>,
	<angelogioacchino.delregno@collabora.com>,
	<xinlei.lee@mediatek.com>, <liangxu.xu@mediatek.com>,
	<dri-devel@lists.freedesktop.org>,
	<linux-mediatek@lists.infradead.org>,
	<devicetree@vger.kernel.org>, <linux-kernel@vger.kernel.org>,
	<linux-arm-kernel@lists.infradead.org>,
	<Project_Global_Chrome_Upstream_Group@mediatek.com>
Subject: Re: [PATCH v15 13/16] drm/mediatek: dpi: Add YUV422 output support
Date: Tue, 5 Jul 2022 16:51:57 +0800	[thread overview]
Message-ID: <6b472fa9e7ce6da775b222b0f9ee00b6d8552dd1.camel@mediatek.com> (raw)
In-Reply-To: <807fa1a3e896eaaa02aec6166f5fb833d7917da7.camel@mediatek.com>

On Tue, 2022-07-05 at 16:39 +0800, Rex-BC Chen wrote:
> On Tue, 2022-07-05 at 13:21 +0800, CK Hu wrote:
> > Hi, Bo-Chen:
> > 
> > On Fri, 2022-07-01 at 11:58 +0800, Bo-Chen Chen wrote:
> > > Dp_intf supports YUV422 as output format. In MT8195 Chrome
> > > project,
> > > YUV422 output format is used for 4K resolution.
> > > 
> > > To support this, it is also needed to support color format
> > > transfer.
> > > Color format transfer is a new feature for both dpi and dpintf of
> > > MT8195.
> > > 
> > > The input format could be RGB888 and output format for dp_intf
> > > should
> > > be
> > > YUV422. Therefore, we add a mtk_dpi_matrix_sel() helper to update
> > > the
> > > DPI_MATRIX_SET register depending on the color format.
> > > 
> > > Signed-off-by: Guillaume Ranquet <granquet@baylibre.com>
> > > Signed-off-by: Bo-Chen Chen <rex-bc.chen@mediatek.com>
> > > Reviewed-by: AngeloGioacchino Del Regno <
> > > angelogioacchino.delregno@collabora.com>
> > > ---
> > >  drivers/gpu/drm/mediatek/mtk_dpi.c      | 61
> > > +++++++++++++++++++++
> > > ----
> > >  drivers/gpu/drm/mediatek/mtk_dpi_regs.h |  6 +++
> > >  2 files changed, 59 insertions(+), 8 deletions(-)
> > > 
> > > diff --git a/drivers/gpu/drm/mediatek/mtk_dpi.c
> > > b/drivers/gpu/drm/mediatek/mtk_dpi.c
> > > index 3085033becbd..0a604bf68b1b 100644
> > > --- a/drivers/gpu/drm/mediatek/mtk_dpi.c
> > > +++ b/drivers/gpu/drm/mediatek/mtk_dpi.c
> > > @@ -54,7 +54,8 @@ enum mtk_dpi_out_channel_swap {
> > >  };
> > >  
> > >  enum mtk_dpi_out_color_format {
> > > -	MTK_DPI_COLOR_FORMAT_RGB
> > > +	MTK_DPI_COLOR_FORMAT_RGB,
> > > +	MTK_DPI_COLOR_FORMAT_YCBCR_422
> > >  };
> > >  
> > >  struct mtk_dpi {
> > > @@ -122,6 +123,7 @@ struct mtk_dpi_yc_limit {
> > >   * @num_output_fmts: Quantity of supported output formats.
> > >   * @is_ck_de_pol: Support CK/DE polarity.
> > >   * @swap_input_support: Support input swap function.
> > > + * @color_fmt_trans_support: Enable color format transfer.
> > >   * @dimension_mask: Mask used for HWIDTH, HPORCH, VSYNC_WIDTH
> > > and
> > > VSYNC_PORCH
> > >   *		    (no shift).
> > >   * @hvsize_mask: Mask of HSIZE and VSIZE mask (no shift).
> > > @@ -138,6 +140,7 @@ struct mtk_dpi_conf {
> > >  	u32 num_output_fmts;
> > >  	bool is_ck_de_pol;
> > >  	bool swap_input_support;
> > > +	bool color_fmt_trans_support;
> > >  	u32 dimension_mask;
> > >  	u32 hvsize_mask;
> > >  	u32 channel_swap_shift;
> > > @@ -406,15 +409,54 @@ static void
> > > mtk_dpi_config_disable_edge(struct
> > > mtk_dpi *dpi)
> > >  		mtk_dpi_mask(dpi, dpi->conf->reg_h_fre_con, 0,
> > > EDGE_SEL_EN);
> > >  }
> > >  
> > > +static void mtk_dpi_matrix_sel(struct mtk_dpi *dpi,
> > > +			       enum mtk_dpi_out_color_format format)
> > 
> > The format would only be MTK_DPI_COLOR_FORMAT_YCBCR_422, so drop
> > the
> > parameter format.
> > 
> > > +{
> > > +	u32 matrix_sel;
> > > +
> > > +	if (!dpi->conf->color_fmt_trans_support) {
> > 
> > Only YUV format would call this function, and I think YUV support
> > would
> > imply that color_fmt_trans_support is true. So drop
> > color_fmt_trans_support.
> > 
> > > +		dev_info(dpi->dev, "matrix_sel is not supported.\n");
> > > +		return;
> > > +	}
> > > +
> > > +	switch (format) {
> > > +	case MTK_DPI_COLOR_FORMAT_YCBCR_422:
> > > +		/*
> > > +		 * If height is smaller than 720, we need to use
> > > RGB_TO_BT601
> > > +		 * to transfer to yuv422. Otherwise, we use
> > > RGB_TO_JPEG.
> > > +		 */
> > > +		if (dpi->mode.hdisplay <= 720)
> > > +			matrix_sel = MATRIX_SEL_RGB_TO_BT601;
> > > +		else
> > > +			matrix_sel = MATRIX_SEL_RGB_TO_JPEG;
> > > +		break;
> > > +	default:
> > > +		matrix_sel = MATRIX_SEL_RGB_TO_JPEG;
> > > +		break;
> > > +	}
> > > +	mtk_dpi_mask(dpi, DPI_MATRIX_SET, matrix_sel,
> > > INT_MATRIX_SEL_MASK);
> > 
> > it seems that we could drop this function and write register as:
> > 
> > mtk_dpi_mask(dpi, DPI_MATRIX_SET, dpi->mode.hdisplay <= 720
> > ? MATRIX_SEL_RGB_TO_BT601 : MATRIX_SEL_RGB_TO_JPEG,
> > INT_MATRIX_SEL_MASK);
> > 
> 
> Hello CK,
> 
> ok, I will drop this function and config.
> 
> > > +}
> > > +
> > >  static void mtk_dpi_config_color_format(struct mtk_dpi *dpi,
> > >  					enum mtk_dpi_out_color_format
> > > format)
> > >  {
> > > -	/* only support RGB888 */
> > > -	mtk_dpi_config_yuv422_enable(dpi, false);
> > > -	mtk_dpi_config_csc_enable(dpi, false);
> > > -	if (dpi->conf->swap_input_support)
> > > -		mtk_dpi_config_swap_input(dpi, false);
> > > -	mtk_dpi_config_channel_swap(dpi, MTK_DPI_OUT_CHANNEL_SWAP_RGB);
> > > +	if (format == MTK_DPI_COLOR_FORMAT_YCBCR_422) {
> > > +		mtk_dpi_config_yuv422_enable(dpi, true);
> > > +		mtk_dpi_config_csc_enable(dpi, true);
> > > +		mtk_dpi_matrix_sel(dpi, format);
> > > +		if (dpi->conf->swap_input_support)
> > 
> > This would never be true because only MT8195 support
> > MTK_DPI_COLOR_FORMAT_YCBCR_422 and swap_input_support of MT8195 is
> > false.
> > 
> 
> I think for mt8195, it should be support output format yuv422 and
> rgb888.
> 
> please refer to [16/16]
> 
> +static const u32 mt8195_output_fmts[] = {
> +	MEDIA_BUS_FMT_RGB888_1X24,
> +	MEDIA_BUS_FMT_YUYV8_1X16,
> +};
> 
> BRs,
> Bo-Chen

Hello CK,

Sorry, I misunderstand your comments.
ok, I will drop this.

BRs,
Bo-Chen
> > Regards,
> > CK
> > 
> > > +			mtk_dpi_config_swap_input(dpi, true);
> > > +		else
> > > +			dev_warn(dpi->dev,
> > > +				 "Failed to swap input, hw is not
> > > supported.\n");
> > > +		mtk_dpi_config_channel_swap(dpi,
> > > MTK_DPI_OUT_CHANNEL_SWAP_RGB);
> > > +	} else {
> > > +		mtk_dpi_config_yuv422_enable(dpi, false);
> > > +		mtk_dpi_config_csc_enable(dpi, false);
> > > +		if (dpi->conf->swap_input_support)
> > > +			mtk_dpi_config_swap_input(dpi, false);
> > > +		mtk_dpi_config_channel_swap(dpi,
> > > MTK_DPI_OUT_CHANNEL_SWAP_RGB);
> > > +	}
> > >  }
> > >  
> > >  static void mtk_dpi_dual_edge(struct mtk_dpi *dpi)
> > > @@ -649,7 +691,10 @@ static int
> > > mtk_dpi_bridge_atomic_check(struct
> > > drm_bridge *bridge,
> > >  	dpi->bit_num = MTK_DPI_OUT_BIT_NUM_8BITS;
> > >  	dpi->channel_swap = MTK_DPI_OUT_CHANNEL_SWAP_RGB;
> > >  	dpi->yc_map = MTK_DPI_OUT_YC_MAP_RGB;
> > > -	dpi->color_format = MTK_DPI_COLOR_FORMAT_RGB;
> > > +	if (out_bus_format == MEDIA_BUS_FMT_YUYV8_1X16)
> > > +		dpi->color_format = MTK_DPI_COLOR_FORMAT_YCBCR_422;
> > > +	else
> > > +		dpi->color_format = MTK_DPI_COLOR_FORMAT_RGB;
> > >  
> > >  	return 0;
> > >  }
> > > diff --git a/drivers/gpu/drm/mediatek/mtk_dpi_regs.h
> > > b/drivers/gpu/drm/mediatek/mtk_dpi_regs.h
> > > index 3a02fabe1662..9ce300313f3e 100644
> > > --- a/drivers/gpu/drm/mediatek/mtk_dpi_regs.h
> > > +++ b/drivers/gpu/drm/mediatek/mtk_dpi_regs.h
> > > @@ -217,4 +217,10 @@
> > >  
> > >  #define EDGE_SEL_EN			BIT(5)
> > >  #define H_FRE_2N			BIT(25)
> > > +
> > > +#define DPI_MATRIX_SET		0xB4
> > > +#define INT_MATRIX_SEL_MASK		GENMASK(4, 0)
> > > +#define MATRIX_SEL_RGB_TO_JPEG		0
> > > +#define MATRIX_SEL_RGB_TO_BT601		2
> > > +
> > >  #endif /* __MTK_DPI_REGS_H */
> > 
> > 
> 
> 


_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel

WARNING: multiple messages have this Message-ID (diff)
From: Rex-BC Chen <rex-bc.chen@mediatek.com>
To: CK Hu <ck.hu@mediatek.com>, <chunkuang.hu@kernel.org>,
	<p.zabel@pengutronix.de>, <daniel@ffwll.ch>, <robh+dt@kernel.org>,
	<krzysztof.kozlowski+dt@linaro.org>, <matthias.bgg@gmail.com>,
	<airlied@linux.ie>
Cc: devicetree@vger.kernel.org, granquet@baylibre.com,
	jitao.shi@mediatek.com, xinlei.lee@mediatek.com,
	liangxu.xu@mediatek.com, linux-kernel@vger.kernel.org,
	dri-devel@lists.freedesktop.org, msp@baylibre.com,
	Project_Global_Chrome_Upstream_Group@mediatek.com,
	linux-mediatek@lists.infradead.org, wenst@chromium.org,
	linux-arm-kernel@lists.infradead.org,
	angelogioacchino.delregno@collabora.com
Subject: Re: [PATCH v15 13/16] drm/mediatek: dpi: Add YUV422 output support
Date: Tue, 5 Jul 2022 16:51:57 +0800	[thread overview]
Message-ID: <6b472fa9e7ce6da775b222b0f9ee00b6d8552dd1.camel@mediatek.com> (raw)
In-Reply-To: <807fa1a3e896eaaa02aec6166f5fb833d7917da7.camel@mediatek.com>

On Tue, 2022-07-05 at 16:39 +0800, Rex-BC Chen wrote:
> On Tue, 2022-07-05 at 13:21 +0800, CK Hu wrote:
> > Hi, Bo-Chen:
> > 
> > On Fri, 2022-07-01 at 11:58 +0800, Bo-Chen Chen wrote:
> > > Dp_intf supports YUV422 as output format. In MT8195 Chrome
> > > project,
> > > YUV422 output format is used for 4K resolution.
> > > 
> > > To support this, it is also needed to support color format
> > > transfer.
> > > Color format transfer is a new feature for both dpi and dpintf of
> > > MT8195.
> > > 
> > > The input format could be RGB888 and output format for dp_intf
> > > should
> > > be
> > > YUV422. Therefore, we add a mtk_dpi_matrix_sel() helper to update
> > > the
> > > DPI_MATRIX_SET register depending on the color format.
> > > 
> > > Signed-off-by: Guillaume Ranquet <granquet@baylibre.com>
> > > Signed-off-by: Bo-Chen Chen <rex-bc.chen@mediatek.com>
> > > Reviewed-by: AngeloGioacchino Del Regno <
> > > angelogioacchino.delregno@collabora.com>
> > > ---
> > >  drivers/gpu/drm/mediatek/mtk_dpi.c      | 61
> > > +++++++++++++++++++++
> > > ----
> > >  drivers/gpu/drm/mediatek/mtk_dpi_regs.h |  6 +++
> > >  2 files changed, 59 insertions(+), 8 deletions(-)
> > > 
> > > diff --git a/drivers/gpu/drm/mediatek/mtk_dpi.c
> > > b/drivers/gpu/drm/mediatek/mtk_dpi.c
> > > index 3085033becbd..0a604bf68b1b 100644
> > > --- a/drivers/gpu/drm/mediatek/mtk_dpi.c
> > > +++ b/drivers/gpu/drm/mediatek/mtk_dpi.c
> > > @@ -54,7 +54,8 @@ enum mtk_dpi_out_channel_swap {
> > >  };
> > >  
> > >  enum mtk_dpi_out_color_format {
> > > -	MTK_DPI_COLOR_FORMAT_RGB
> > > +	MTK_DPI_COLOR_FORMAT_RGB,
> > > +	MTK_DPI_COLOR_FORMAT_YCBCR_422
> > >  };
> > >  
> > >  struct mtk_dpi {
> > > @@ -122,6 +123,7 @@ struct mtk_dpi_yc_limit {
> > >   * @num_output_fmts: Quantity of supported output formats.
> > >   * @is_ck_de_pol: Support CK/DE polarity.
> > >   * @swap_input_support: Support input swap function.
> > > + * @color_fmt_trans_support: Enable color format transfer.
> > >   * @dimension_mask: Mask used for HWIDTH, HPORCH, VSYNC_WIDTH
> > > and
> > > VSYNC_PORCH
> > >   *		    (no shift).
> > >   * @hvsize_mask: Mask of HSIZE and VSIZE mask (no shift).
> > > @@ -138,6 +140,7 @@ struct mtk_dpi_conf {
> > >  	u32 num_output_fmts;
> > >  	bool is_ck_de_pol;
> > >  	bool swap_input_support;
> > > +	bool color_fmt_trans_support;
> > >  	u32 dimension_mask;
> > >  	u32 hvsize_mask;
> > >  	u32 channel_swap_shift;
> > > @@ -406,15 +409,54 @@ static void
> > > mtk_dpi_config_disable_edge(struct
> > > mtk_dpi *dpi)
> > >  		mtk_dpi_mask(dpi, dpi->conf->reg_h_fre_con, 0,
> > > EDGE_SEL_EN);
> > >  }
> > >  
> > > +static void mtk_dpi_matrix_sel(struct mtk_dpi *dpi,
> > > +			       enum mtk_dpi_out_color_format format)
> > 
> > The format would only be MTK_DPI_COLOR_FORMAT_YCBCR_422, so drop
> > the
> > parameter format.
> > 
> > > +{
> > > +	u32 matrix_sel;
> > > +
> > > +	if (!dpi->conf->color_fmt_trans_support) {
> > 
> > Only YUV format would call this function, and I think YUV support
> > would
> > imply that color_fmt_trans_support is true. So drop
> > color_fmt_trans_support.
> > 
> > > +		dev_info(dpi->dev, "matrix_sel is not supported.\n");
> > > +		return;
> > > +	}
> > > +
> > > +	switch (format) {
> > > +	case MTK_DPI_COLOR_FORMAT_YCBCR_422:
> > > +		/*
> > > +		 * If height is smaller than 720, we need to use
> > > RGB_TO_BT601
> > > +		 * to transfer to yuv422. Otherwise, we use
> > > RGB_TO_JPEG.
> > > +		 */
> > > +		if (dpi->mode.hdisplay <= 720)
> > > +			matrix_sel = MATRIX_SEL_RGB_TO_BT601;
> > > +		else
> > > +			matrix_sel = MATRIX_SEL_RGB_TO_JPEG;
> > > +		break;
> > > +	default:
> > > +		matrix_sel = MATRIX_SEL_RGB_TO_JPEG;
> > > +		break;
> > > +	}
> > > +	mtk_dpi_mask(dpi, DPI_MATRIX_SET, matrix_sel,
> > > INT_MATRIX_SEL_MASK);
> > 
> > it seems that we could drop this function and write register as:
> > 
> > mtk_dpi_mask(dpi, DPI_MATRIX_SET, dpi->mode.hdisplay <= 720
> > ? MATRIX_SEL_RGB_TO_BT601 : MATRIX_SEL_RGB_TO_JPEG,
> > INT_MATRIX_SEL_MASK);
> > 
> 
> Hello CK,
> 
> ok, I will drop this function and config.
> 
> > > +}
> > > +
> > >  static void mtk_dpi_config_color_format(struct mtk_dpi *dpi,
> > >  					enum mtk_dpi_out_color_format
> > > format)
> > >  {
> > > -	/* only support RGB888 */
> > > -	mtk_dpi_config_yuv422_enable(dpi, false);
> > > -	mtk_dpi_config_csc_enable(dpi, false);
> > > -	if (dpi->conf->swap_input_support)
> > > -		mtk_dpi_config_swap_input(dpi, false);
> > > -	mtk_dpi_config_channel_swap(dpi, MTK_DPI_OUT_CHANNEL_SWAP_RGB);
> > > +	if (format == MTK_DPI_COLOR_FORMAT_YCBCR_422) {
> > > +		mtk_dpi_config_yuv422_enable(dpi, true);
> > > +		mtk_dpi_config_csc_enable(dpi, true);
> > > +		mtk_dpi_matrix_sel(dpi, format);
> > > +		if (dpi->conf->swap_input_support)
> > 
> > This would never be true because only MT8195 support
> > MTK_DPI_COLOR_FORMAT_YCBCR_422 and swap_input_support of MT8195 is
> > false.
> > 
> 
> I think for mt8195, it should be support output format yuv422 and
> rgb888.
> 
> please refer to [16/16]
> 
> +static const u32 mt8195_output_fmts[] = {
> +	MEDIA_BUS_FMT_RGB888_1X24,
> +	MEDIA_BUS_FMT_YUYV8_1X16,
> +};
> 
> BRs,
> Bo-Chen

Hello CK,

Sorry, I misunderstand your comments.
ok, I will drop this.

BRs,
Bo-Chen
> > Regards,
> > CK
> > 
> > > +			mtk_dpi_config_swap_input(dpi, true);
> > > +		else
> > > +			dev_warn(dpi->dev,
> > > +				 "Failed to swap input, hw is not
> > > supported.\n");
> > > +		mtk_dpi_config_channel_swap(dpi,
> > > MTK_DPI_OUT_CHANNEL_SWAP_RGB);
> > > +	} else {
> > > +		mtk_dpi_config_yuv422_enable(dpi, false);
> > > +		mtk_dpi_config_csc_enable(dpi, false);
> > > +		if (dpi->conf->swap_input_support)
> > > +			mtk_dpi_config_swap_input(dpi, false);
> > > +		mtk_dpi_config_channel_swap(dpi,
> > > MTK_DPI_OUT_CHANNEL_SWAP_RGB);
> > > +	}
> > >  }
> > >  
> > >  static void mtk_dpi_dual_edge(struct mtk_dpi *dpi)
> > > @@ -649,7 +691,10 @@ static int
> > > mtk_dpi_bridge_atomic_check(struct
> > > drm_bridge *bridge,
> > >  	dpi->bit_num = MTK_DPI_OUT_BIT_NUM_8BITS;
> > >  	dpi->channel_swap = MTK_DPI_OUT_CHANNEL_SWAP_RGB;
> > >  	dpi->yc_map = MTK_DPI_OUT_YC_MAP_RGB;
> > > -	dpi->color_format = MTK_DPI_COLOR_FORMAT_RGB;
> > > +	if (out_bus_format == MEDIA_BUS_FMT_YUYV8_1X16)
> > > +		dpi->color_format = MTK_DPI_COLOR_FORMAT_YCBCR_422;
> > > +	else
> > > +		dpi->color_format = MTK_DPI_COLOR_FORMAT_RGB;
> > >  
> > >  	return 0;
> > >  }
> > > diff --git a/drivers/gpu/drm/mediatek/mtk_dpi_regs.h
> > > b/drivers/gpu/drm/mediatek/mtk_dpi_regs.h
> > > index 3a02fabe1662..9ce300313f3e 100644
> > > --- a/drivers/gpu/drm/mediatek/mtk_dpi_regs.h
> > > +++ b/drivers/gpu/drm/mediatek/mtk_dpi_regs.h
> > > @@ -217,4 +217,10 @@
> > >  
> > >  #define EDGE_SEL_EN			BIT(5)
> > >  #define H_FRE_2N			BIT(25)
> > > +
> > > +#define DPI_MATRIX_SET		0xB4
> > > +#define INT_MATRIX_SEL_MASK		GENMASK(4, 0)
> > > +#define MATRIX_SEL_RGB_TO_JPEG		0
> > > +#define MATRIX_SEL_RGB_TO_BT601		2
> > > +
> > >  #endif /* __MTK_DPI_REGS_H */
> > 
> > 
> 
> 


  reply	other threads:[~2022-07-05  8:52 UTC|newest]

Thread overview: 105+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2022-07-01  3:58 [PATCH v15 00/16] drm/mediatek: Add MT8195 dp_intf driver Bo-Chen Chen
2022-07-01  3:58 ` Bo-Chen Chen
2022-07-01  3:58 ` Bo-Chen Chen
2022-07-01  3:58 ` [PATCH v15 01/16] dt-bindings: mediatek,dpi: Add DP_INTF compatible Bo-Chen Chen
2022-07-01  3:58   ` Bo-Chen Chen
2022-07-01  3:58   ` Bo-Chen Chen
2022-07-05  3:42   ` CK Hu
2022-07-05  3:42     ` CK Hu
2022-07-05  3:42     ` CK Hu
2022-07-01  3:58 ` [PATCH v15 02/16] dt-bindings: mediatek,dpi: Revise mediatek strings to correct format Bo-Chen Chen
2022-07-01  3:58   ` Bo-Chen Chen
2022-07-01  3:58   ` [PATCH v15 02/16] dt-bindings: mediatek, dpi: " Bo-Chen Chen
2022-07-05  3:43   ` [PATCH v15 02/16] dt-bindings: mediatek,dpi: " CK Hu
2022-07-05  3:43     ` CK Hu
2022-07-05  3:43     ` CK Hu
2022-07-01  3:58 ` [PATCH v15 03/16] drm/mediatek: dpi: Add kernel document for struct mtk_dpi_conf Bo-Chen Chen
2022-07-01  3:58   ` Bo-Chen Chen
2022-07-01  3:58   ` Bo-Chen Chen
2022-07-05  3:44   ` CK Hu
2022-07-05  3:44     ` CK Hu
2022-07-05  3:44     ` CK Hu
2022-07-01  3:58 ` [PATCH v15 04/16] drm/mediatek: dpi: Remove output format of YUV Bo-Chen Chen
2022-07-01  3:58   ` Bo-Chen Chen
2022-07-01  3:58   ` Bo-Chen Chen
2022-07-05  3:48   ` CK Hu
2022-07-05  3:48     ` CK Hu
2022-07-05  3:48     ` CK Hu
2022-07-01  3:58 ` [PATCH v15 05/16] drm/mediatek: dpi: Add support for quantization range Bo-Chen Chen
2022-07-01  3:58   ` Bo-Chen Chen
2022-07-01  3:58   ` Bo-Chen Chen
2022-07-05  3:49   ` CK Hu
2022-07-05  3:49     ` CK Hu
2022-07-05  3:49     ` CK Hu
2022-07-01  3:58 ` [PATCH v15 06/16] drm/mediatek: dpi: implement a CK/DE pol toggle in SoC config Bo-Chen Chen
2022-07-01  3:58   ` Bo-Chen Chen
2022-07-01  3:58   ` Bo-Chen Chen
2022-07-05  3:50   ` CK Hu
2022-07-05  3:50     ` CK Hu
2022-07-05  3:50     ` CK Hu
2022-07-01  3:58 ` [PATCH v15 07/16] drm/mediatek: dpi: implement a swap_input " Bo-Chen Chen
2022-07-01  3:58   ` Bo-Chen Chen
2022-07-01  3:58   ` Bo-Chen Chen
2022-07-05  3:51   ` CK Hu
2022-07-05  3:51     ` CK Hu
2022-07-05  3:51     ` CK Hu
2022-07-01  3:58 ` [PATCH v15 08/16] drm/mediatek: dpi: move dimension mask to " Bo-Chen Chen
2022-07-01  3:58   ` Bo-Chen Chen
2022-07-01  3:58   ` Bo-Chen Chen
2022-07-05  3:52   ` CK Hu
2022-07-05  3:52     ` CK Hu
2022-07-05  3:52     ` CK Hu
2022-07-01  3:58 ` [PATCH v15 09/16] drm/mediatek: dpi: move hvsize_mask " Bo-Chen Chen
2022-07-01  3:58   ` Bo-Chen Chen
2022-07-01  3:58   ` Bo-Chen Chen
2022-07-05  3:53   ` CK Hu
2022-07-05  3:53     ` CK Hu
2022-07-05  3:53     ` CK Hu
2022-07-01  3:58 ` [PATCH v15 10/16] drm/mediatek: dpi: move swap_shift " Bo-Chen Chen
2022-07-01  3:58   ` Bo-Chen Chen
2022-07-01  3:58   ` Bo-Chen Chen
2022-07-05  3:53   ` CK Hu
2022-07-05  3:53     ` CK Hu
2022-07-05  3:53     ` CK Hu
2022-07-01  3:58 ` [PATCH v15 11/16] drm/mediatek: dpi: move the yuv422_en_bit " Bo-Chen Chen
2022-07-01  3:58   ` Bo-Chen Chen
2022-07-01  3:58   ` Bo-Chen Chen
2022-07-05  3:54   ` CK Hu
2022-07-05  3:54     ` CK Hu
2022-07-05  3:54     ` CK Hu
2022-07-01  3:58 ` [PATCH v15 12/16] drm/mediatek: dpi: move the csc_enable bit " Bo-Chen Chen
2022-07-01  3:58   ` Bo-Chen Chen
2022-07-01  3:58   ` Bo-Chen Chen
2022-07-05  3:55   ` CK Hu
2022-07-05  3:55     ` CK Hu
2022-07-05  3:55     ` CK Hu
2022-07-01  3:58 ` [PATCH v15 13/16] drm/mediatek: dpi: Add YUV422 output support Bo-Chen Chen
2022-07-01  3:58   ` Bo-Chen Chen
2022-07-01  3:58   ` Bo-Chen Chen
2022-07-05  5:21   ` CK Hu
2022-07-05  5:21     ` CK Hu
2022-07-05  5:21     ` CK Hu
2022-07-05  8:39     ` Rex-BC Chen
2022-07-05  8:39       ` Rex-BC Chen
2022-07-05  8:39       ` Rex-BC Chen
2022-07-05  8:51       ` Rex-BC Chen [this message]
2022-07-05  8:51         ` Rex-BC Chen
2022-07-05  8:51         ` Rex-BC Chen
2022-07-01  3:58 ` [PATCH v15 14/16] drm/mediatek: dpi: add config to support direct connection to dpi panels Bo-Chen Chen
2022-07-01  3:58   ` Bo-Chen Chen
2022-07-01  3:58   ` Bo-Chen Chen
2022-07-05  5:24   ` CK Hu
2022-07-05  5:24     ` CK Hu
2022-07-05  5:24     ` CK Hu
2022-07-01  3:58 ` [PATCH v15 15/16] drm/mediatek: dpi: Only enable dpi after the bridge is enabled Bo-Chen Chen
2022-07-01  3:58   ` Bo-Chen Chen
2022-07-01  3:58   ` Bo-Chen Chen
2022-07-05  3:56   ` CK Hu
2022-07-05  3:56     ` CK Hu
2022-07-05  3:56     ` CK Hu
2022-07-01  3:58 ` [PATCH v15 16/16] drm/mediatek: dpi: Add dp_intf support Bo-Chen Chen
2022-07-01  3:58   ` Bo-Chen Chen
2022-07-01  3:58   ` Bo-Chen Chen
2022-07-05  5:29   ` CK Hu
2022-07-05  5:29     ` CK Hu
2022-07-05  5:29     ` CK Hu

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=6b472fa9e7ce6da775b222b0f9ee00b6d8552dd1.camel@mediatek.com \
    --to=rex-bc.chen@mediatek.com \
    --cc=Project_Global_Chrome_Upstream_Group@mediatek.com \
    --cc=airlied@linux.ie \
    --cc=angelogioacchino.delregno@collabora.com \
    --cc=chunkuang.hu@kernel.org \
    --cc=ck.hu@mediatek.com \
    --cc=daniel@ffwll.ch \
    --cc=devicetree@vger.kernel.org \
    --cc=dri-devel@lists.freedesktop.org \
    --cc=granquet@baylibre.com \
    --cc=jitao.shi@mediatek.com \
    --cc=krzysztof.kozlowski+dt@linaro.org \
    --cc=liangxu.xu@mediatek.com \
    --cc=linux-arm-kernel@lists.infradead.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-mediatek@lists.infradead.org \
    --cc=matthias.bgg@gmail.com \
    --cc=msp@baylibre.com \
    --cc=p.zabel@pengutronix.de \
    --cc=robh+dt@kernel.org \
    --cc=wenst@chromium.org \
    --cc=xinlei.lee@mediatek.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.