RE: [PATCH 1/9] media: Changes in include/linux/videodev2.h for MFC 5.1

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi, Kamil

k.debski@xxxxxxxxxxx wrote: 
> Hi Hans,
> 
> > -----Original Message-----
> > From: Hans Verkuil [mailto:hverkuil@xxxxxxxxx]
> > Sent: 22 December 2010 13:42
> > To: Jeongtae Park
> > Cc: linux-media@xxxxxxxxxxxxxxx; linux-samsung-soc@xxxxxxxxxxxxxxx;
> > k.debski@xxxxxxxxxxx; jaeryul.oh@xxxxxxxxxxx; kgene.kim@xxxxxxxxxxx;
> > ben-linux@xxxxxxxxx; jonghun.han@xxxxxxxxxxx
> > Subject: Re: [PATCH 1/9] media: Changes in include/linux/videodev2.h
> > for MFC 5.1
> 
> <snip>
> 
> > >  #define V4L2_PIX_FMT_DV       v4l2_fourcc('d', 'v', 's', 'd') /*
> > 1394          */
> > >  #define V4L2_PIX_FMT_MPEG     v4l2_fourcc('M', 'P', 'E', 'G') /*
> > MPEG-1/2/4    */
> > >
> > > +
> > > +#define V4L2_PIX_FMT_H264     v4l2_fourcc('H', '2', '6', '4') /*
> > H264    */
> > > +#define V4L2_PIX_FMT_H263     v4l2_fourcc('H', '2', '6', '3') /*
> > H263    */
> > > +#define V4L2_PIX_FMT_MPEG12   v4l2_fourcc('M', 'P', '1', '2') /*
> > MPEG-1/2  */
> > > +#define V4L2_PIX_FMT_MPEG4    v4l2_fourcc('M', 'P', 'G', '4') /*
> > MPEG-4  */
> > > +#define V4L2_PIX_FMT_DIVX     v4l2_fourcc('D', 'I', 'V', 'X') /*
> > DivX  */
> > > +#define V4L2_PIX_FMT_DIVX3    v4l2_fourcc('D', 'I', 'V', '3') /*
> > DivX 3.11  */
> > > +#define V4L2_PIX_FMT_DIVX4    v4l2_fourcc('D', 'I', 'V', '4') /*
> > DivX 4.12  */
> > > +#define V4L2_PIX_FMT_DIVX500    v4l2_fourcc('D', 'X', '5', '2') /*
> > DivX 5.00 - 5.02  */
> > > +#define V4L2_PIX_FMT_DIVX503    v4l2_fourcc('D', 'X', '5', '3') /*
> > DivX 5.03 - x  */
> > > +#define V4L2_PIX_FMT_XVID     v4l2_fourcc('X', 'V', 'I', 'D') /*
> > Xvid */
> > > +#define V4L2_PIX_FMT_VC1      v4l2_fourcc('V', 'C', '1', 'A') /* VC-
> > 1 */
> > > +#define V4L2_PIX_FMT_VC1_RCV      v4l2_fourcc('V', 'C', '1', 'R') /*
> > VC-1 RCV */
> >
> > What do these formats describe? Are these container formats or the
> > actual
> > compressed video stream that is normally packaged inside a container?
> 
> Apart from VC-1 RCV those are elementary streams. If I understand
> correctly
> RCV is a simple semi-container that contains necessary information to play
> the ES. I have asked a person from HW team if all those fourccs are
> necessary.
> I am waiting for reply.
> 
> The idea was to have a fourcc for each supported codec (by this I mean the
> elementary stream).

I'm reviewing what we really should add for MFC except for  previously
defined FOURCC type 
based on http://www.fourcc.org/fourcc.php
FOURCC there seems that there is  a little bit different from codec
supported by MFC(HW codec)

> 
> >
> > > +
> > > +
> > >  /*  Vendor-specific formats   */
> > >  #define V4L2_PIX_FMT_CPIA1    v4l2_fourcc('C', 'P', 'I', 'A') /*
> > cpia1 YUV */
> > >  #define V4L2_PIX_FMT_WNVA     v4l2_fourcc('W', 'N', 'V', 'A') /*
> > Winnov hw compress */
> > > @@ -1009,6 +1034,7 @@ struct v4l2_ext_controls {
> > >  #define V4L2_CTRL_CLASS_MPEG 0x00990000	/* MPEG-compression
> > controls */
> > >  #define V4L2_CTRL_CLASS_CAMERA 0x009a0000	/* Camera class
> > controls */
> > >  #define V4L2_CTRL_CLASS_FM_TX 0x009b0000	/* FM Modulator control
> > class */
> > > +#define V4L2_CTRL_CLASS_CODEC 0x009c0000	/* Codec control class
> > */
> > >
> > >  #define V4L2_CTRL_ID_MASK      	  (0x0fffffff)
> > >  #define V4L2_CTRL_ID2CLASS(id)    ((id) & 0x0fff0000UL)
> > > @@ -1342,6 +1368,150 @@ enum
> > v4l2_mpeg_cx2341x_video_median_filter_type {
> > >  #define V4L2_CID_MPEG_CX2341X_VIDEO_CHROMA_MEDIAN_FILTER_TOP
> > 	(V4L2_CID_MPEG_CX2341X_BASE+10)
> > >  #define V4L2_CID_MPEG_CX2341X_STREAM_INSERT_NAV_PACKETS
> > 	(V4L2_CID_MPEG_CX2341X_BASE+11)
> > >
> > > +/* For codecs */
> > > +#define V4L2_CID_CODEC_BASE
> (V4L2_CTRL_CLASS_CODEC
> > | 0x900)
> > > +#define V4L2_CID_CODEC_CLASS
> (V4L2_CTRL_CLASS_CODEC
> > | 1)
> > > +
> > > +/* For decoding */
> > > +#define V4L2_CID_CODEC_LOOP_FILTER_MPEG4_ENABLE
> > 	(V4L2_CID_CODEC_BASE + 110)
> > > +#define V4L2_CID_CODEC_DISPLAY_DELAY		(V4L2_CID_CODEC_BASE
> +
> > 137)
> > > +#define V4L2_CID_CODEC_REQ_NUM_BUFS		(V4L2_CID_CODEC_BASE
> +
> > 140)
> > > +#define V4L2_CID_CODEC_SLICE_INTERFACE		(V4L2_CID_CODEC_BASE
> +
> > 141)
> > > +#define V4L2_CID_CODEC_PACKED_PB		(V4L2_CID_CODEC_BASE + 142)
> >
> > ??? Weird CODEC_BASE offsets?
> >
> > Are all these codec controls above general? I.e., applicable to any
> > codec? What
> > do they mean?
> 
> My mistake - I forgot to tidy up the offsets. It is difficult for me to
> say which of those controls are MFC specific as I have little experience
> with other codecs.
> 
> Currently PACKED_PB has been replaced with a simple mechanism that can
> detect
> if the stream has packed PB frames. You can read more about such streams
> here:
> http://itsjustonesandzeros.blogspot.com/2007/01/what-is-packed-
> bitstream.htm
> l
> First approach required the application to set if the stream contained
> packed-PB
> Frames. Now the driver detects it the stream contains packed-PB frames.
> Another
> approach would require the stream parser to detect those frames and divide
> them
> into two buffers queued to MFC.
> 
> DISPLAY_DELAY is a number of frames that should be decoded before the
> first
> frame is
> returned to the application. It is valid for H264 streams.
> 
> REQ_NUM_BUFS is the minimum number of CAPTURE buffers required for MFC
> decoder to work.
> This is a read-only control, by reading this value the application can
> adjust count when
> doing REQBUFS. If the application needs 3 dequeued CAPTURE buffers for
> processing it
> should set count when doing REQBUFS to the value of REQ_NUM_BUFS + 3.
> 
> When SLICE_INTERFACE the codec expects compressed slices in OUTPUT buffers
> instead of
> full frames.
> 
> LOOP_FILTER_MPEG4_ENABLE controls deblocking filter for MPEG4 codec. You
> are
> right that
> name this should be more general and name is not intuitive.
> DECODING_DEBLOCK_FILTER
> would be way better, as more codec can have this option.
> 
> I think that DECODING_DEBLOCK_FILTER (LOOP_FILTER_MPEG4_ENABLE),
> SLICE_INTERFACE and
> DISPLAY_DELAY should be general. Here I would really welcome comment from
> other
> developers working on codec v4l2 drivers.
> 
> >
> > > +
> > > +/* For encoding */
> > > +#define V4L2_CID_CODEC_LOOP_FILTER_H264
> > 	(V4L2_CID_CODEC_BASE + 9)
> > > +enum v4l2_cid_codec_loop_filter_h264 {
> > > +	V4L2_CID_CODEC_LOOP_FILTER_H264_ENABLE = 0,
> > > +	V4L2_CID_CODEC_LOOP_FILTER_H264_DISABLE = 1,
> > > +	V4L2_CID_CODEC_LOOP_FILTER_H264_DISABLE_AT_BOUNDARY = 2,
> > > +};
> > > +
> > > +/* Codec class control IDs specific to the MFC51 driver */
> > > +#define V4L2_CID_CODEC_MFC51_BASE
(V4L2_CTRL_CLASS_CODEC
> > | 0x1000)
> >
> > It's probably a good idea to only add this BASE define to videodev2.h
> > (please include a comment describing the control range reserved for the
> > MFC51).
> > All others should go to a public mfc51 header. Which should include
> > documentation
> > for these controls as well.
> 
> Great idea.
> 
> >
> > > +
> > > +/* common */
> > > +enum v4l2_codec_mfc5x_enc_switch {
> > > +	V4L2_CODEC_MFC51_ENC_SW_DISABLE	= 0,
> > > +	V4L2_CODEC_MFC51_ENC_SW_ENABLE	= 1,
> > > +};
> > > +enum v4l2_codec_mfc5x_enc_switch_inv {
> > > +	V4L2_CODEC_MFC51_ENC_SW_INV_ENABLE	= 0,
> > > +	V4L2_CODEC_MFC51_ENC_SW_INV_DISABLE	= 1,
> > > +};
> > > +#define V4L2_CID_CODEC_MFC51_ENC_GOP_SIZE
> > 	(V4L2_CID_CODEC_MFC51_BASE+300)
> >
> > Why the +300?
> 
> This is question should be answered by Jeongtae Park, as he did the
> encoding
> part. Unfortunately our patches got mixed up.
> 
> I can only guess that this offset was added to distinguish between
> decoding
> and encoding.
> 
> <snip>
> 
> --
> Kamil Debski
> Linux Platform Group
> Samsung Poland R&D Center
> 
> --
> To unsubscribe from this list: send the line "unsubscribe linux-media" in
> the body of a message to majordomo@xxxxxxxxxxxxxxx
> More majordomo info at  http://vger.kernel.org/majordomo-info.html

--
To unsubscribe from this list: send the line "unsubscribe linux-samsung-soc" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Linux SoC Development]     [Linux Rockchip Development]     [Linux USB Development]     [Video for Linux]     [Linux Audio Users]     [Linux SCSI]     [Yosemite News]

  Powered by Linux