[FFmpeg-devel] [PATCH] avformat/hlsenc: process hls_time value too small sence

Steven Liu lingjiujianke at gmail.com
Tue Oct 20 06:42:48 EEST 2020


Steven Liu <lq at chinaffmpeg.org> 于2020年8月18日周二 上午10:44写道:
>
> The target duration will be a negative value when there are
> some b frames after prevous frame, the pts after current packet
> is large than the pts of current packet, so the target duration
> will compute as 0.040000 - 0.080000, then the value of the target
> duration will be -0.040000. so hls muxer should check the pts after
> current packet minus the pts of current packet, hls muxer can split
> the stream as a segment if the target duration is neither negative nor
> zero, hls muxer cannot split the stream as a segment if the
> target duration is either negative or zero then get the next packet
> until the target duration is not negative or zero.
>
> Signed-off-by: Steven Liu <lq at chinaffmpeg.org>
> Suggested-by: Zhili Zhao <quinkblack at foxmail.com>
> ---
>  libavformat/hlsenc.c | 2 +-
>  1 file changed, 1 insertion(+), 1 deletion(-)
>
> diff --git a/libavformat/hlsenc.c b/libavformat/hlsenc.c
> index cb31d6aed7..4471858222 100644
> --- a/libavformat/hlsenc.c
> +++ b/libavformat/hlsenc.c
> @@ -2398,9 +2398,9 @@ static int hls_write_packet(AVFormatContext *s, AVPacket *pkt)
>                  vs->duration = (double)(pkt->pts - vs->end_pts) * st->time_base.num / st->time_base.den;
>              }
>          }
> -
>      }
>
> +    can_split = can_split && (pkt->pts - vs->end_pts > 0);
>      if (vs->packets_written && can_split && av_compare_ts(pkt->pts - vs->start_pts, st->time_base,
>                                                            end_pts, AV_TIME_BASE_Q) >= 0) {
>          int64_t new_start_pos;
> --
> 2.25.0
>
>
>
> _______________________________________________
> 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".

pushed


Thanks
Steven


More information about the ffmpeg-devel mailing list