[PATCH v2 0/6] media: cedrus: h264: Support multi-slice frames

From: Jernej Skrabec
Date: Sun Sep 29 2019 - 16:01:05 EST


This series adds support for decoding multi-slice H264 frames along with
support for V4L2_DEC_CMD_FLUSH and V4L2_BUF_FLAG_M2M_HOLD_CAPTURE_BUF.

Code was tested by modified ffmpeg, which can be found here:
https://github.com/jernejsk/FFmpeg, branch mainline-test
It has to be configured with at least following options:
--enable-v4l2-request --enable-libudev --enable-libdrm

Samples used for testing:
http://jernej.libreelec.tv/videos/h264/BA1_FT_C.mp4
http://jernej.libreelec.tv/videos/h264/h264.mp4

Command line used for testing:
ffmpeg -hwaccel drm -hwaccel_device /dev/dri/card0 -i h264.mp4 -pix_fmt bgra -f fbdev /dev/fb0

Please note that V4L2_DEC_CMD_FLUSH was not tested because I'm
not sure how. ffmpeg follows exactly which slice is last in frame
and sets hold flag accordingly. Improper usage of hold flag would
corrupt ffmpeg assumptions and it would probably crash. Any ideas
how to test this are welcome!

Thanks to Jonas for adjusting ffmpeg.

Please let me know what you think.

Best regards,
Jernej

Changes from v1:
- added Rb tags
- updated V4L2_DEC_CMD_FLUSH documentation
- updated first slice detection in Cedrus
- hold capture buffer flag is set according to source format
- added v4l m2m stateless_(try_)decoder_cmd ioctl helpers

Hans Verkuil (2):
vb2: add V4L2_BUF_FLAG_M2M_HOLD_CAPTURE_BUF
videodev2.h: add V4L2_DEC_CMD_FLUSH

Jernej Skrabec (4):
media: v4l2-mem2mem: add stateless_(try_)decoder_cmd ioctl helpers
media: cedrus: Detect first slice of a frame
media: cedrus: h264: Support multiple slices per frame
media: cedrus: Add support for holding capture buffer

Documentation/media/uapi/v4l/buffer.rst | 13 ++++++
.../media/uapi/v4l/vidioc-decoder-cmd.rst | 10 +++-
.../media/uapi/v4l/vidioc-reqbufs.rst | 6 +++
.../media/videodev2.h.rst.exceptions | 1 +
.../media/common/videobuf2/videobuf2-v4l2.c | 8 +++-
drivers/media/v4l2-core/v4l2-mem2mem.c | 35 ++++++++++++++
drivers/staging/media/sunxi/cedrus/cedrus.h | 1 +
.../staging/media/sunxi/cedrus/cedrus_dec.c | 11 +++++
.../staging/media/sunxi/cedrus/cedrus_h264.c | 11 ++++-
.../staging/media/sunxi/cedrus/cedrus_hw.c | 8 ++--
.../staging/media/sunxi/cedrus/cedrus_video.c | 14 ++++++
include/media/v4l2-mem2mem.h | 46 +++++++++++++++++++
include/media/videobuf2-core.h | 3 ++
include/media/videobuf2-v4l2.h | 5 ++
include/uapi/linux/videodev2.h | 14 ++++--
15 files changed, 175 insertions(+), 11 deletions(-)

--
2.23.0