All of lore.kernel.org
 help / color / mirror / Atom feed
From: Steve Longerbeam <steve_longerbeam@mentor.com>
To: Philipp Zabel <p.zabel@pengutronix.de>
Cc: Marek Vasut <marex@denx.de>,
	Robert Schwebel <r.schwebel@pengutronix.de>,
	Jean-Michel Hautbois <jean-michel.hautbois@veo-labs.com>,
	Sakari Ailus <sakari.ailus@iki.fi>,
	Gary Bisson <gary.bisson@boundarydevices.com>,
	Sascha Hauer <kernel@pengutronix.de>,
	Hans Verkuil <hverkuil@xs4all.nl>,
	Linux Media Mailing List <linux-media@vger.kernel.org>
Subject: Re: [PATCH v2 00/21] Basic i.MX IPUv3 capture support
Date: Thu, 12 Jan 2017 15:22:16 -0800	[thread overview]
Message-ID: <8e6092a3-d80b-fe01-11b4-fbebe1de3102@mentor.com> (raw)
In-Reply-To: <1484136644.2934.89.camel@pengutronix.de>

Hi Philipp, JM,


First, let me say that you both have convinced me that we need a VDIC
entity. I've implemented that in the branch imx-media-staging-md-vdic.
At this point it only implements the M/C de-interlacing function, not the
plane Combiner. So it has only one input and one output pad. I would
imagine it will need two additional inputs and another output to support
the Combiner (two pads for each plane to be combined, and a combiner
output pad).

More below...

On 01/11/2017 04:10 AM, Philipp Zabel wrote:
> Hi Steve,
>
> Am Dienstag, den 10.01.2017, 15:52 -0800 schrieb Steve Longerbeam:
>> On 01/09/2017 04:15 PM, Steve Longerbeam wrote:
>>> Hi Philipp,
>>>
>>>
>>> On 01/09/2017 11:43 AM, Philipp Zabel wrote:
>>>
>>>
>>> <snip>
>>>> One is the amount and organization of subdevices/media entities visible
>>>> to userspace. The SMFCs should not be user controllable subdevices, but
>>>> can be implicitly enabled when a CSI is directly linked to a camif.
>>> I agree the SMFC could be folded into the CSI, but I see at least one
>>> issue.
> I don't suggest to fold it into the CSI.
> The CSI should have one output pad that that can be connected either to
> the IC PRP input (CSIx_DATA_DEST=1) or to the IDMAC via SMFC
> (CSIx_DATA_DEST=2).

Right, and CSI can connect to VDIC. I don't know if it is documented,
but to route to VDIC, set CSIx_DATA_DEST=1, as if to IC PRP. Confusing,
but it's as if the VDIC is somehow part of the IC.

>   The SMFC should be considered part of the link
> between CSI and IDMAC.

sure, I can agree with that.

> The IC PRP input pad should be connected to either the CSI0 output pad
> (CSI_SEL=0,IC_INPUT=0), the CSI1 output pad (CSI_SEL=1,IC_INPUT=0), or
> to the VDIC (IC_INPUT=1).

correct.

>
>>>  From the dot graph you'll see that the PRPVF entity can receive directly
>>> from the CSI, or indirectly via the SMFC.
> And that's one reason why I think representing the mem2mem paths as
> links in the media controller interface is questionable. The path "via
> SMFC" is not really a hardware connection between CSI -> SMFC -> IC PRP,
> but two completely separate paths:
> CSI -> SMFC -> IDMAC -> mem and mem -> IDMAC -> IC PRP with different
> IDMAC read/write channels. The only real connection is that one DMA the
> IC DMA transfers are triggered automatically by the frame
> synchronisation unit on every CSI frame.
> There is no way to convey to the user which links are real connections
> and which are just linked DMA write and read channels somewhere else.
>
> Is there even a reason for the user to switch between direct and via
> memory paths manually, or could this be inferred from other state
> (formats, active links)?

a CSI -> VDIC link doesn't convey whether that is a direct link using
the FSU, or whether it is via SMFC and memory buffers.

If you'll recall, the VDIC has three motion modes: low, medium, and
high.

When VDIC receives directly from CSI, it can only operate in
high motion mode (it processes a single field F(n-1) sent directly
from the CSI using the FSU). The reference manual refers to this
as "real time mode".

The low and medium motion modes require processing all three
fields F(n-1), F(n), and F(n+1). These fields must come from IDMAC
channels 8, 9, and 10 respectively.

So in order to support low and medium motion modes, there needs to
be a pipeline where the VDIC receives F(n-1), F(n), and F(n+1) from
memory buffers.

How about this: we can do away with SMFC entities by having two
output pads from the CSI: a "direct" output pad that can link to PRP and
VDIC, and a "IDMAC via SMFC" output pad that links to the entities that
require memory buffers (VDIC in low/medium motion mode, camif, and
PP). Only one of those output pads can be active at a time. I'm not sure if
that allowed by the media framework, do two source pads imply that the
entity can activate both of those pads simultaneously, or is allowed that
only one source pad of two or more can be activated at a time? It's not
clear to me.

Let me know if you agree with this proposal.

> <snip>
>>>> Also I'm not convinced the 1:1 mapping of IC task to subdevices is the
>>>> best choice. It is true that the three tasks can be enabled separately,
>>>> but to my understanding, the PRP ENC and PRP VF tasks share a single
>>>> input channel. Shouldn't this be a single PRP subdevice with one input
>>>> and two (VF, ENC) outputs?
>>> Since the VDIC sends its motion compensated frames to the PRP VF task,
>>> I've created the PRPVF entity solely for motion compensated de-interlace
>>> support. I don't really see any other use for the PRPVF task except for
>>> motion compensated de-interlace.
> I suppose simultaneous scaling to two different resolutions without
> going through memory could be one interesting use case:
>
>             ,--> VF --> IDMAC -> mem -> to display
> CSI -> IC PRP
>             `--> ENC -> IDMAC -> mem -> to VPU

Yes, that is one possibility.

>>> So really, the PRPVF entity is a combination of the VDIC and PRPVF
>>> subunits.
> I'd prefer to keep them separate, we could then use a deactivated VDIC
> -> IC PRP link to mark the VDIC as available to be used for its
> combining functionality by another driver.
>
> Also logically, the VDIC subdev would be the right user interface to
> switch from interlaced to non-interlaced pad modes, whereas the IC
> subdev(s) should just allow changing color space and size between its
> inputs and outputs.

right, that has been implemented in branch imx-media-staging-md-vdic.

> <snip>
>> Here also, I'd prefer to keep distinct PRPENC and PRPVF entities. You
>> are correct that PRPENC and PRPVF do share an input channel (the CSIs).
>> But the PRPVF has an additional input channel from the VDIC,
> Wait, that is a VDIC -> PRP connection, not a VDIC -> PRPVF connection,
> or am I mistaken?

The FSU only sends VDIC output to PRPVF, not PRPENC. It's not
well documented, but see "IPU main flows" section in the manual.
All listed pipelines that route VDIC to IC go to IC (PRP VF).

Which suggests that when IC receives from VDIC, PRPENC can
receive no data and is effectively unusable.

> The VDIC direct input is enabled with ipu_set_ic_src_mux(vdi=true)
> (IC_INPUT=1), and that is the same for both PRP->ENC and PRP->VF.

true, but in fact the FSU only sends to PRP VF.

>> and since my PRPVF entity roles
>> up the VDIC internally, it is actually receiving from the VDIC channel.
>> So unless you think we should have a distinct VDIC entity, I would like
>> to keep this
>> the way it is.
> Yes, I think VDIC should be separated out of PRPVF. What do you think
> about splitting the IC PRP into three parts?
>
> PRP could have one input pad connected to either CSI0, CSI1, or VDIC,
> and two output pads connected to PRPVF and PRPENC, respectively. This
> would even allow to have the PRP describe the downscale and PRPVF and
> PRPENC describe the bilinear upscale part of the IC.

Sure sounds good to me. PRPENC and PRPVF are independent,
but they cannot process different data streams, they both have to
work with CSI0 or CSI1, so this makes sense.

I'll start looking into it.

Steve


  reply	other threads:[~2017-01-12 23:23 UTC|newest]

Thread overview: 61+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2016-10-14 17:34 [PATCH v2 00/21] Basic i.MX IPUv3 capture support Philipp Zabel
2016-10-14 17:34 ` [PATCH v2 01/21] [media] v4l2-async: move code out of v4l2_async_notifier_register into v4l2_async_test_nofity_all Philipp Zabel
2016-10-14 17:34 ` [PATCH v2 02/21] [media] v4l2-async: allow subdevices to add further subdevices to the notifier waiting list Philipp Zabel
2016-10-14 17:34 ` [PATCH v2 03/21] [media] v4l: of: add v4l2_of_subdev_registered Philipp Zabel
2016-10-14 17:34 ` [PATCH v2 04/21] [media] v4l2-async: add new subdevices to the tail of subdev_list Philipp Zabel
2016-10-14 17:34 ` [PATCH v2 05/21] [media] imx: Add i.MX SoC wide media device driver Philipp Zabel
2016-10-14 17:34 ` [PATCH v2 06/21] [media] imx: Add IPUv3 media common code Philipp Zabel
2016-10-14 17:34 ` [PATCH v2 07/21] [media] imx-ipu: Add i.MX IPUv3 CSI subdevice driver Philipp Zabel
2016-11-08  7:18   ` Ying Liu
2016-10-14 17:34 ` [PATCH v2 08/21] [media] imx: Add i.MX IPUv3 capture driver Philipp Zabel
2016-10-17 11:32   ` Jack Mitchell
2016-10-17 11:35     ` Marek Vasut
2016-10-17 11:40       ` Jack Mitchell
2016-10-17 12:12     ` Philipp Zabel
2016-10-19 16:22       ` Jack Mitchell
2016-10-19 19:25         ` Marek Vasut
2016-10-26 11:29           ` Jack Mitchell
2016-11-08  7:21   ` Ying Liu
2016-10-14 17:34 ` [PATCH v2 09/21] [media] platform: add video-multiplexer subdevice driver Philipp Zabel
2016-10-14 17:34 ` [PATCH v2 10/21] [media] imx: Add i.MX MIPI CSI-2 " Philipp Zabel
2016-10-14 17:34 ` [PATCH v2 11/21] [media] tc358743: put lanes in STOP state before starting streaming Philipp Zabel
2016-10-14 17:34 ` [PATCH v2 12/21] ARM: dts: imx6qdl: Add capture-subsystem node Philipp Zabel
2016-10-14 17:34 ` [PATCH v2 13/21] ARM: dts: imx6qdl: Add mipi_ipu1/2 multiplexers, mipi_csi, and their connections Philipp Zabel
2016-11-08  8:23   ` Ying Liu
2016-10-14 17:34 ` [PATCH v2 14/21] ARM: dts: imx6qdl: Add MIPI CSI-2 D-PHY compatible and clocks Philipp Zabel
2016-10-14 17:34 ` [PATCH v2 15/21] ARM: dts: nitrogen6x: Add dtsi for BD_HDMI_MIPI HDMI to MIPI CSI-2 receiver board Philipp Zabel
2016-10-14 17:34 ` [PATCH v2 16/21] gpu: ipuv3: add ipu_csi_set_downsize Philipp Zabel
2016-10-14 17:34 ` [PATCH v2 17/21] [media] imx-ipuv3-csi: support downsizing Philipp Zabel
2016-10-14 17:34 ` [PATCH v2 18/21] [media] add mux and video interface bridge entity functions Philipp Zabel
2016-10-14 17:34 ` [PATCH v2 19/21] [media] video-multiplexer: set entity function to mux Philipp Zabel
2016-10-14 17:34 ` [PATCH v2 20/21] [media] imx: Set i.MX MIPI CSI-2 entity function to bridge Philipp Zabel
2016-10-14 17:34 ` [PATCH v2 21/21] [media] tc358743: set entity function to video interface bridge Philipp Zabel
2016-10-17 10:18 ` [PATCH v2 00/21] Basic i.MX IPUv3 capture support Gary Bisson
2016-10-17 12:41   ` Philipp Zabel
2016-10-19 21:30 ` Sakari Ailus
     [not found]   ` <CAH-u=807nRYzza0kTfOMv1AiWazk6FGJyz6W5_bYw7v9nOrccA@mail.gmail.com>
2016-12-29 15:10     ` Jean-Michel Hautbois
2016-12-29 20:51     ` Robert Schwebel
2016-12-30 19:06       ` Marek Vasut
2016-12-30 20:26         ` Steve Longerbeam
2017-01-02 13:51           ` Jean-Michel Hautbois
2017-01-02 14:45             ` Hans Verkuil
2017-01-02 14:59               ` Jean-Michel Hautbois
2017-01-02 19:19                 ` Fabio Estevam
2017-01-02 19:20                 ` Steve Longerbeam
2017-01-02 17:04               ` Fabio Estevam
2017-01-02 19:17               ` Steve Longerbeam
2017-01-09 19:43           ` Philipp Zabel
2017-01-10  0:15             ` Steve Longerbeam
2017-01-10 23:52               ` Steve Longerbeam
2017-01-11  9:12                 ` Jean-Michel Hautbois
2017-01-11 12:10                 ` Philipp Zabel
2017-01-12 23:22                   ` Steve Longerbeam [this message]
2017-01-12 23:43                     ` Steve Longerbeam
2017-01-13  2:22                       ` Steve Longerbeam
2017-01-13 11:18                         ` Philipp Zabel
2017-01-13 11:04                     ` Philipp Zabel
2017-01-13 11:05                     ` Philipp Zabel
2017-01-14 20:26                       ` Steve Longerbeam
2017-01-16 11:49                         ` Philipp Zabel
2017-01-11 12:11               ` Philipp Zabel
2017-01-24 18:11             ` Philipp Zabel

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=8e6092a3-d80b-fe01-11b4-fbebe1de3102@mentor.com \
    --to=steve_longerbeam@mentor.com \
    --cc=gary.bisson@boundarydevices.com \
    --cc=hverkuil@xs4all.nl \
    --cc=jean-michel.hautbois@veo-labs.com \
    --cc=kernel@pengutronix.de \
    --cc=linux-media@vger.kernel.org \
    --cc=marex@denx.de \
    --cc=p.zabel@pengutronix.de \
    --cc=r.schwebel@pengutronix.de \
    --cc=sakari.ailus@iki.fi \
    /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.