[FFmpeg-devel] [PATCH 1/2] avformat/dashenc: Added option to repeatedly publish master playlist

Jeyapal, Karthick kjeyapal at akamai.com
Mon Feb 25 08:35:07 EET 2019


On 2/19/19 12:18 PM, Karthick J wrote:
> The master playlist can be published at a specified interval with this option
> ---
>  doc/muxers.texi       | 3 +++
>  libavformat/dashenc.c | 9 ++++++++-
>  2 files changed, 11 insertions(+), 1 deletion(-)
>
> diff --git a/doc/muxers.texi b/doc/muxers.texi
> index 36010cf2d1..372fab2f92 100644
> --- a/doc/muxers.texi
> +++ b/doc/muxers.texi
> @@ -315,6 +315,9 @@ This option will also try to comply with the above open spec, till Apple's spec
>  Applicable only when @var{streaming} and @var{hls_playlist} options are enabled.
>  This is an experimental feature.
>  
> + at item -master_m3u8_publish_rate @var{master_m3u8_publish_rate}
> +Publish master playlist repeatedly every after specified number of segment intervals.
> +
>  @end table
>  
>  @anchor{framecrc}
> diff --git a/libavformat/dashenc.c b/libavformat/dashenc.c
> index 37a7547b12..a0b44a0ec3 100644
> --- a/libavformat/dashenc.c
> +++ b/libavformat/dashenc.c
> @@ -141,6 +141,7 @@ typedef struct DASHContext {
>      SegmentType segment_type_option;  /* segment type as specified in options */
>      int ignore_io_errors;
>      int lhls;
> +    int master_publish_rate;
>  } DASHContext;
>  
>  static struct codec_string {
> @@ -965,13 +966,18 @@ static int write_manifest(AVFormatContext *s, int final)
>              return ret;
>      }
>  
> -    if (c->hls_playlist && !c->master_playlist_created) {
> +    if (c->hls_playlist) {
>          char filename_hls[1024];
>          const char *audio_group = "A1";
>          char audio_codec_str[128] = "\0";
>          int is_default = 1;
>          int max_audio_bitrate = 0;
>  
> +        // Publish master playlist only the configured rate
> +        if (c->master_playlist_created && (!c->master_publish_rate ||
> +             c->streams[0].segment_index % c->master_publish_rate))
> +            return 0;
> +
>          if (*c->dirname)
>              snprintf(filename_hls, sizeof(filename_hls), "%smaster.m3u8", c->dirname);
>          else
> @@ -1798,6 +1804,7 @@ static const AVOption options[] = {
>      { "webm", "make segment file in WebM format", 0, AV_OPT_TYPE_CONST, {.i64 = SEGMENT_TYPE_WEBM }, 0, UINT_MAX,   E, "segment_type"},
>      { "ignore_io_errors", "Ignore IO errors during open and write. Useful for long-duration runs with network output", OFFSET(ignore_io_errors), AV_OPT_TYPE_BOOL, { .i64 = 0 }, 0, 1, E },
>      { "lhls", "Enable Low-latency HLS(Experimental). Adds #EXT-X-PREFETCH tag with current segment's URI", OFFSET(lhls), AV_OPT_TYPE_BOOL, { .i64 = 0 }, 0, 1, E },
> +    { "master_m3u8_publish_rate", "Publish master playlist every after this many segment intervals", OFFSET(master_publish_rate), AV_OPT_TYPE_INT, {.i64 = 0}, 0, UINT_MAX, E},
>      { NULL },
>  };
Pushed Patchset.
>  



More information about the ffmpeg-devel mailing list