[FFmpeg-devel] [PATCH] avformat/movenc: fixed fmp4 packets containing incorrect flags after transcoding
Steven Liu
lingjiujianke at gmail.com
Sun Apr 23 04:54:08 EEST 2023
<1035567130 at qq.com> 于2023年4月10日周一 20:43写道:
>
> From: Wang Yaqiang <wangyaqiang03 at kuaishou.com>
>
> When write multi-trun box, the MOV_TRUN_FIRST_SAMPLE_FLAGS flag
> need judge by first param, not 0.
> If the original video contains consecutive I frames,
> this will cause the packets of fmp4 have error sample_flags ,
> and then incorrect keyframes were generated,
> and then error packet will be seeked.
>
> Signed-off-by: Wang Yaqiang <wangyaqiang03 at kuaishou.com>
> ---
> libavformat/movenc.c | 4 ++--
> 1 file changed, 2 insertions(+), 2 deletions(-)
>
> diff --git a/libavformat/movenc.c b/libavformat/movenc.c
> index c370922c7d..946e79c5ac 100644
> --- a/libavformat/movenc.c
> +++ b/libavformat/movenc.c
> @@ -4858,8 +4858,8 @@ static int mov_write_trun_tag(AVIOContext *pb, MOVMuxContext *mov,
> if (i > first && get_sample_flags(track, &track->cluster[i]) != track->default_sample_flags)
> flags |= MOV_TRUN_SAMPLE_FLAGS;
> }
> - if (!(flags & MOV_TRUN_SAMPLE_FLAGS) && track->entry > 0 &&
> - get_sample_flags(track, &track->cluster[0]) != track->default_sample_flags)
> + if (!(flags & MOV_TRUN_SAMPLE_FLAGS) && track->entry > first &&
> + get_sample_flags(track, &track->cluster[first]) != track->default_sample_flags)
> flags |= MOV_TRUN_FIRST_SAMPLE_FLAGS;
> if (track->flags & MOV_TRACK_CTTS)
> flags |= MOV_TRUN_SAMPLE_CTS;
> --
> 2.39.2
>
> _______________________________________________
> ffmpeg-devel mailing list
> ffmpeg-devel at ffmpeg.org
> https://ffmpeg.org/mailman/listinfo/ffmpeg-devel
>
> To unsubscribe, visit link above, or email
> ffmpeg-devel-request at ffmpeg.org with subject "unsubscribe".
Test ok here.
Thanks
Steven
More information about the ffmpeg-devel
mailing list