Hi Steve,

On Wed, 2017-04-12 at 17:45 -0700, Steve Longerbeam wrote:
> This patch adds a call to imx_media_fill_empty_mbus_fields() in the
> *_try_fmt() functions at the sink pads, to set empty field order and
> colorimetry parameters.
> 
> If the field order is set to ANY, choose the currently set field order
> at the sink pad. If the colorspace is set to DEFAULT, choose the
> current colorspace at the sink pad.  If any of xfer_func, ycbcr_enc
> or quantization are set to DEFAULT, either choose the current sink pad
> setting, or the default setting for the new colorspace, if non-DEFAULT
> colorspace was given.
> 
> Colorimetry is also propagated from sink to source pads anywhere
> this has not already been done. The exception is ic-prpencvf at the
> source pad, since the Image Converter outputs fixed quantization and
> Y`CbCr encoding.
> 
> Signed-off-by: Steve Longerbeam <steve_longerb...@mentor.com>
> ---
>  drivers/staging/media/imx/imx-ic-prp.c      |  5 ++-
>  drivers/staging/media/imx/imx-ic-prpencvf.c | 25 +++++++++++---
>  drivers/staging/media/imx/imx-media-csi.c   | 12 +++++--
>  drivers/staging/media/imx/imx-media-utils.c | 53 
> +++++++++++++++++++++++++++++
>  drivers/staging/media/imx/imx-media-vdic.c  |  7 ++--
>  drivers/staging/media/imx/imx-media.h       |  3 +-
>  6 files changed, 95 insertions(+), 10 deletions(-)
> 
[...]
> diff --git a/drivers/staging/media/imx/imx-media-utils.c 
> b/drivers/staging/media/imx/imx-media-utils.c
> index 7b2f92d..b07d0ae 100644
> --- a/drivers/staging/media/imx/imx-media-utils.c
> +++ b/drivers/staging/media/imx/imx-media-utils.c
> @@ -464,6 +464,59 @@ int imx_media_init_mbus_fmt(struct v4l2_mbus_framefmt 
> *mbus,
>  }
>  EXPORT_SYMBOL_GPL(imx_media_init_mbus_fmt);
>  
> +/*
> + * Check whether the field or colorimetry params in tryfmt are
> + * uninitialized, and if so fill them with the values from fmt.
> + * The exception is when tryfmt->colorspace has been initialized,
> + * if so all the further default colorimetry params can be derived
> + * from tryfmt->colorspace.
> + */
> +void imx_media_fill_empty_mbus_fields(struct v4l2_mbus_framefmt *tryfmt,
> +                                   struct v4l2_mbus_framefmt *fmt)
> +{
> +     /* fill field if necessary */
> +     if (tryfmt->field == V4L2_FIELD_ANY)
> +             tryfmt->field = fmt->field;
> +
> +     /* fill colorimetry if necessary */
> +     if (tryfmt->colorspace == V4L2_COLORSPACE_DEFAULT) {
> +             tryfmt->colorspace = fmt->colorspace;
> +             if (tryfmt->xfer_func == V4L2_XFER_FUNC_DEFAULT)
> +                     tryfmt->xfer_func = fmt->xfer_func;
> +             if (tryfmt->ycbcr_enc == V4L2_YCBCR_ENC_DEFAULT)
> +                     tryfmt->ycbcr_enc = fmt->ycbcr_enc;
> +             if (tryfmt->quantization == V4L2_QUANTIZATION_DEFAULT)
> +                     tryfmt->quantization = fmt->quantization;

According to Hans' latest comments, this could be changed to:

----------8<----------
>From cca3cda9effcaca0891eb8044a79137023fed1c2 Mon Sep 17 00:00:00 2001
From: Philipp Zabel <p.za...@pengutronix.de>
Date: Mon, 8 May 2017 11:38:05 +0200
Subject: [PATCH] fixup! media: imx: set and propagate default field,
 colorimetry

Signed-off-by: Philipp Zabel <p.za...@pengutronix.de>
---
 drivers/staging/media/imx/imx-media-utils.c | 9 +++------
 1 file changed, 3 insertions(+), 6 deletions(-)

diff --git a/drivers/staging/media/imx/imx-media-utils.c 
b/drivers/staging/media/imx/imx-media-utils.c
index a8766489e8a18..ec2abd618cc44 100644
--- a/drivers/staging/media/imx/imx-media-utils.c
+++ b/drivers/staging/media/imx/imx-media-utils.c
@@ -497,12 +497,9 @@ void imx_media_fill_default_mbus_fields(struct 
v4l2_mbus_framefmt *tryfmt,
        /* fill colorimetry if necessary */
        if (tryfmt->colorspace == V4L2_COLORSPACE_DEFAULT) {
                tryfmt->colorspace = fmt->colorspace;
-               if (tryfmt->xfer_func == V4L2_XFER_FUNC_DEFAULT)
-                       tryfmt->xfer_func = fmt->xfer_func;
-               if (tryfmt->ycbcr_enc == V4L2_YCBCR_ENC_DEFAULT)
-                       tryfmt->ycbcr_enc = fmt->ycbcr_enc;
-               if (tryfmt->quantization == V4L2_QUANTIZATION_DEFAULT)
-                       tryfmt->quantization = fmt->quantization;
+               tryfmt->xfer_func = fmt->xfer_func;
+               tryfmt->ycbcr_enc = fmt->ycbcr_enc;
+               tryfmt->quantization = fmt->quantization;
        } else {
                if (tryfmt->xfer_func == V4L2_XFER_FUNC_DEFAULT) {
                        tryfmt->xfer_func =
-- 
2.11.0
---------->8----------

> +     } else {
> +             const struct imx_media_pixfmt *cc;
> +             bool is_rgb = false;
> +
> +             cc = imx_media_find_mbus_format(tryfmt->code,
> +                                             CS_SEL_ANY, false);
> +             if (!cc)
> +                     cc = imx_media_find_ipu_format(tryfmt->code,
> +                                                    CS_SEL_ANY);
> +             if (cc && cc->cs != IPUV3_COLORSPACE_YUV)
> +                     is_rgb = true;
> +
> +             if (tryfmt->xfer_func == V4L2_XFER_FUNC_DEFAULT) {
> +                     tryfmt->xfer_func =
> +                             V4L2_MAP_XFER_FUNC_DEFAULT(tryfmt->colorspace);
> +             }
> +             if (tryfmt->ycbcr_enc == V4L2_YCBCR_ENC_DEFAULT) {
> +                     tryfmt->ycbcr_enc =
> +                             V4L2_MAP_YCBCR_ENC_DEFAULT(tryfmt->colorspace);
> +             }
> +             if (tryfmt->quantization == V4L2_QUANTIZATION_DEFAULT) {
> +                     tryfmt->quantization =
> +                             V4L2_MAP_QUANTIZATION_DEFAULT(
> +                                     is_rgb, tryfmt->colorspace,
> +                                     tryfmt->ycbcr_enc);
> +             }
> +     }

I'm not sure about removing this part yet.

regards
Philipp

Reply via email to