[FFmpeg-devel] [PATCH] avformat/hlsenc: fix duration wrong when no pkt duration

Alexander Strasser eclipse7 at gmx.net
Thu Mar 16 00:24:05 EET 2017


Hi!

On 2017-03-13 17:12 +0800, Steven Liu wrote:
> when cannot get pkt duration, hlsenc segments duration will
> be set to 0, this patch can fix it.
> 
> Signed-off-by: Steven Liu <lq at chinaffmpeg.org>
> ---
>  libavformat/hlsenc.c | 7 ++++++-
>  1 file changed, 6 insertions(+), 1 deletion(-)
> 
> diff --git a/libavformat/hlsenc.c b/libavformat/hlsenc.c
> index 5df2514..d6f0631 100644
> --- a/libavformat/hlsenc.c
> +++ b/libavformat/hlsenc.c
> @@ -1354,7 +1354,12 @@ static int hls_write_packet(AVFormatContext *s, AVPacket *pkt)
>                                         * st->time_base.num / st->time_base.den;
>              hls->dpp = (double)(pkt->duration) * st->time_base.num / st->time_base.den;
>          } else {
> -            hls->duration += (double)(pkt->duration) * st->time_base.num / st->time_base.den;
> +            if (pkt->duration) {
> +                hls->duration += (double)(pkt->duration) * st->time_base.num / st->time_base.den;
> +            } else {
> +                av_log(s, AV_LOG_WARNING, "pkt->duration = 0, maybe the hls segment duration will not precise\n");
                                                                                                        ^

There is a word missing in the log message: "be"

For a warning it might have been better to use more natural language and to convey a bit more information:

  "Packet duration is 0. Trying to compensate. Segment duration may not be accurate.\n"



> +                hls->duration = (double)(pkt->pts - hls->end_pts) * st->time_base.num / st->time_base.den;
> +            }
>          }
>  
>      }


  I am sorry to comment after you pushed already. Anyway my remarks are only 
cosmetics and not so important. I did not investigate the issue at all.


Thank you,
  Alexander


More information about the ffmpeg-devel mailing list