Re: [PATCH 2/2] media: docs-rst: Document memory-to-memory video encoder interface

From: Tomasz Figa
Date: Tue Oct 16 2018 - 03:44:31 EST


On Tue, Aug 7, 2018 at 3:54 PM Tomasz Figa <tfiga@xxxxxxxxxxxx> wrote:
>
> Hi Hans,
>
> On Wed, Jul 25, 2018 at 10:57 PM Hans Verkuil <hverkuil@xxxxxxxxx> wrote:
> >
> > On 24/07/18 16:06, Tomasz Figa wrote:
[snip]
> > > +4. The client may set the raw source format on the ``OUTPUT`` queue via
> > > + :c:func:`VIDIOC_S_FMT`.
> > > +
> > > + * **Required fields:**
> > > +
> > > + ``type``
> > > + a ``V4L2_BUF_TYPE_*`` enum appropriate for ``OUTPUT``
> > > +
> > > + ``pixelformat``
> > > + raw format of the source
> > > +
> > > + ``width``, ``height``
> > > + source resolution
> > > +
> > > + ``num_planes`` (for _MPLANE)
> > > + set to number of planes for pixelformat
> > > +
> > > + ``sizeimage``, ``bytesperline``
> > > + follow standard semantics
> > > +
> > > + * **Return fields:**
> > > +
> > > + ``width``, ``height``
> > > + may be adjusted by driver to match alignment requirements, as
> > > + required by the currently selected formats
> > > +
> > > + ``sizeimage``, ``bytesperline``
> > > + follow standard semantics
> > > +
> > > + * Setting the source resolution will reset visible resolution to the
> > > + adjusted source resolution rounded up to the closest visible
> > > + resolution supported by the driver. Similarly, coded resolution will
> >
> > coded -> the coded
>
> Ack.
>
> >
> > > + be reset to source resolution rounded up to the closest coded
> >
> > reset -> set
> > source -> the source
>
> Ack.
>

Actually, I'd prefer to keep it at "reset", so that it signifies the
fact that the driver will actually override whatever was set by the
application before.

[snip]
> > > + * The driver must expose following selection targets on ``OUTPUT``:
> > > +
> > > + ``V4L2_SEL_TGT_CROP_BOUNDS``
> > > + maximum crop bounds within the source buffer supported by the
> > > + encoder
> > > +
> > > + ``V4L2_SEL_TGT_CROP_DEFAULT``
> > > + suggested cropping rectangle that covers the whole source picture
> > > +
> > > + ``V4L2_SEL_TGT_CROP``
> > > + rectangle within the source buffer to be encoded into the
> > > + ``CAPTURE`` stream; defaults to ``V4L2_SEL_TGT_CROP_DEFAULT``
> > > +
> > > + ``V4L2_SEL_TGT_COMPOSE_BOUNDS``
> > > + maximum rectangle within the coded resolution, which the cropped
> > > + source frame can be output into; always equal to (0, 0)x(width of
> > > + ``V4L2_SEL_TGT_CROP``, height of ``V4L2_SEL_TGT_CROP``), if the
> > > + hardware does not support compose/scaling
> > > +
> > > + ``V4L2_SEL_TGT_COMPOSE_DEFAULT``
> > > + equal to ``V4L2_SEL_TGT_CROP``
> > > +
> > > + ``V4L2_SEL_TGT_COMPOSE``
> > > + rectangle within the coded frame, which the cropped source frame
> > > + is to be output into; defaults to
> > > + ``V4L2_SEL_TGT_COMPOSE_DEFAULT``; read-only on hardware without
> > > + additional compose/scaling capabilities; resulting stream will
> > > + have this rectangle encoded as the visible rectangle in its
> > > + metadata
> > > +
> > > + ``V4L2_SEL_TGT_COMPOSE_PADDED``
> > > + always equal to coded resolution of the stream, as selected by the
> > > + encoder based on source resolution and crop/compose rectangles
> >
> > Are there codec drivers that support composition? I can't remember seeing any.
> >
>
> Hmm, I was convinced that MFC could scale and we just lacked support
> in the driver, but I checked the documentation and it doesn't seem to
> be able to do so. I guess we could drop the COMPOSE rectangles for
> now, until we find any hardware that can do scaling or composing on
> the fly.
>

On the other hand, having them defined already wouldn't complicate
existing drivers too much either, because they would just handle all
of them in the same switch case, i.e.

case V4L2_SEL_TGT_COMPOSE_BOUNDS:
case V4L2_SEL_TGT_COMPOSE_DEFAULT:
case V4L2_SEL_TGT_COMPOSE:
case V4L2_SEL_TGT_COMPOSE_PADDED:
return visible_rectangle;

That would need one change, though. We would define
V4L2_SEL_TGT_COMPOSE_DEFAULT to be equal to (0, 0)x(width of
V4L2_SEL_TGT_CROP - 1, height of ``V4L2_SEL_TGT_CROP - 1), which
makes more sense than current definition, since it would bypass any
compose/scaling by default.

> > > +
> > > + .. note::
> > > +
> > > + The driver may adjust the crop/compose rectangles to the nearest
> > > + supported ones to meet codec and hardware requirements.
> > > +
> > > +6. Allocate buffers for both ``OUTPUT`` and ``CAPTURE`` via
> > > + :c:func:`VIDIOC_REQBUFS`. This may be performed in any order.
> > > +
> > > + * **Required fields:**
> > > +
> > > + ``count``
> > > + requested number of buffers to allocate; greater than zero
> > > +
> > > + ``type``
> > > + a ``V4L2_BUF_TYPE_*`` enum appropriate for ``OUTPUT`` or
> > > + ``CAPTURE``
> > > +
> > > + ``memory``
> > > + follows standard semantics
> > > +
> > > + * **Return fields:**
> > > +
> > > + ``count``
> > > + adjusted to allocated number of buffers
> > > +
> > > + * The driver must adjust count to minimum of required number of
> > > + buffers for given format and count passed.
> >
> > I'd rephrase this:
> >
> > The driver must adjust ``count`` to the maximum of ``count`` and
> > the required number of buffers for the given format.
> >
> > Note that this is set to the maximum, not minimum.
> >
>
> Good catch. Will fix it.
>

Actually this is not always the maximum. Encoders may also have
constraints on the maximum number of buffers, so how about just making
it a bit less specific:

The count will be adjusted by the driver to match the hardware
requirements. The client must check the final value after the ioctl
returns to get the number of buffers allocated.

[snip]
> > One general comment:
> >
> > you often talk about 'the driver must', e.g.:
> >
> > "The driver must process and encode as normal all ``OUTPUT`` buffers
> > queued by the client before the :c:func:`VIDIOC_ENCODER_CMD` was issued."
> >
> > But this is not a driver specification, it is an API specification.
> >
> > I think it would be better to phrase it like this:
> >
> > "All ``OUTPUT`` buffers queued by the client before the :c:func:`VIDIOC_ENCODER_CMD`
> > was issued will be processed and encoded as normal."
> >
> > (or perhaps even 'shall' if you want to be really formal)
> >
> > End-users do not really care what drivers do, they want to know what the API does,
> > and that implies rules for drivers.
>
> While I see the point, I'm not fully convinced that it makes the
> documentation easier to read. We defined "client" for the purpose of
> not using the passive form too much, so possibly we could also define
> "driver" in the glossary. Maybe it's just me, but I find that
> referring directly to both sides of the API and using the active form
> is much easier to read.
>
> Possibly just replacing "driver" with "encoder" would ease your concern?

I actually went ahead and rephrased the text of both encoder and
decoder to be more userspace-centric. There are still mentions of a
driver, but only limited to the places
where it is necessary to signify the driver-specific bits, such as
alignments, capabilities, etc.

Best regards,
Tomasz