[FFmpeg-devel] [PATCH 7/8] avformat/mpegts: Fix for the DOVI video stream descriptor
lance.lmwang at gmail.com
lance.lmwang at gmail.com
Wed Oct 27 04:24:15 EEST 2021
On Thu, Oct 14, 2021 at 09:09:01PM +0800, lance.lmwang at gmail.com wrote:
> From: Limin Wang <lance.lmwang at gmail.com>
>
> By <<Dolby Vision Streams Within the MPEG-2 Transport Stream Format v1.2>>
>
> Signed-off-by: Limin Wang <lance.lmwang at gmail.com>
> ---
> libavformat/mpegts.c | 11 +++++++++--
> 1 file changed, 9 insertions(+), 2 deletions(-)
>
> diff --git a/libavformat/mpegts.c b/libavformat/mpegts.c
> index 44d9298..774964d 100644
> --- a/libavformat/mpegts.c
> +++ b/libavformat/mpegts.c
> @@ -2178,6 +2178,8 @@ int ff_parse_mpeg2_descriptor(AVFormatContext *fc, AVStream *st, int stream_type
> AVDOVIDecoderConfigurationRecord *dovi;
> size_t dovi_size;
> int ret;
> + int dependency_pid;
> +
> if (desc_end - *pp < 4) // (8 + 8 + 7 + 6 + 1 + 1 + 1) / 8
> return AVERROR_INVALIDDATA;
>
> @@ -2193,7 +2195,11 @@ int ff_parse_mpeg2_descriptor(AVFormatContext *fc, AVStream *st, int stream_type
> dovi->rpu_present_flag = (buf >> 2) & 0x01; // 1 bit
> dovi->el_present_flag = (buf >> 1) & 0x01; // 1 bit
> dovi->bl_present_flag = buf & 0x01; // 1 bit
> - if (desc_end - *pp >= 20) { // 4 + 4 * 4
> + if (!dovi->bl_present_flag && desc_end - *pp >= 2) {
> + buf = get16(pp, desc_end);
> + dependency_pid = buf >> 3; // 13 bits
> + }
> + if (desc_end - *pp >= 1) { // 8 bits
> buf = get8(pp, desc_end);
> dovi->dv_bl_signal_compatibility_id = (buf >> 4) & 0x0f; // 4 bits
> } else {
> @@ -2210,12 +2216,13 @@ int ff_parse_mpeg2_descriptor(AVFormatContext *fc, AVStream *st, int stream_type
> }
>
> av_log(fc, AV_LOG_TRACE, "DOVI, version: %d.%d, profile: %d, level: %d, "
> - "rpu flag: %d, el flag: %d, bl flag: %d, compatibility id: %d\n",
> + "rpu flag: %d, el flag: %d, bl flag: %d, dependency_pid: %d, compatibility id: %d\n",
> dovi->dv_version_major, dovi->dv_version_minor,
> dovi->dv_profile, dovi->dv_level,
> dovi->rpu_present_flag,
> dovi->el_present_flag,
> dovi->bl_present_flag,
> + dependency_pid,
> dovi->dv_bl_signal_compatibility_id);
> }
> break;
> --
> 1.8.3.1
>
will apply patch#5,#6,#7 tomorrow unless there are objections.
--
Thanks,
Limin Wang
More information about the ffmpeg-devel
mailing list