[FFmpeg-devel] [PATCH 3/3] avformat/dashenc: Addition of #EXT-X-MEDIA tag and AUDIO attribute

Jeyapal, Karthick kjeyapal at akamai.com
Fri Dec 29 08:50:38 EET 2017


On 12/29/17 12:13 PM, 刘歧 wrote:
>
>> On 27 Dec 2017, at 15:26, Steven Liu <lingjiujianke at gmail.com> wrote:
>>
>> 2017-12-26 19:11 GMT+08:00 Karthick J <kjeyapal at akamai.com>:
>>> From: Karthick Jeyapal <kjeyapal at akamai.com>
>>>
>>> This is required for AV playout from master.m3u8.
>>> Otherwise master.m3u8 lists only video-only and/or audio-only streams.
>>> ---
>>> libavformat/dashenc.c | 24 ++++++++++++++++++++++--
>>> 1 file changed, 22 insertions(+), 2 deletions(-)
>>>
>>> diff --git a/libavformat/dashenc.c b/libavformat/dashenc.c
>>> index 478a384..a3eb522 100644
>>> --- a/libavformat/dashenc.c
>>> +++ b/libavformat/dashenc.c
>>> @@ -737,6 +737,9 @@ static int write_manifest(AVFormatContext *s, int final)
>>>
>>>     if (c->hls_playlist && !c->master_playlist_created) {
>>>         char filename_hls[1024];
>>> +        const char *audio_group = "A1";
>>> +        int is_default = 1;
>>> +        int max_audio_bitrate = 0;
>>>
>>>         if (*c->dirname)
>>>             snprintf(filename_hls, sizeof(filename_hls), "%s/master.m3u8", c->dirname);
>>> @@ -758,9 +761,26 @@ static int write_manifest(AVFormatContext *s, int final)
>>>         for (i = 0; i < s->nb_streams; i++) {
>>>             char playlist_file[64];
>>>             AVStream *st = s->streams[i];
>>> +            if (st->codecpar->codec_type != AVMEDIA_TYPE_AUDIO)
>>> +                continue;
>>> +            get_hls_playlist_name(playlist_file, sizeof(playlist_file), NULL, i);
>>> +            ff_hls_write_audio_rendition(out, (char *)audio_group,
>>> +                                         playlist_file, i, is_default);
>>> +            max_audio_bitrate = FFMAX(st->codecpar->bit_rate, max_audio_bitrate);
>>> +            is_default = 0;
>>> +        }
>>> +
>>> +        for (i = 0; i < s->nb_streams; i++) {
>>> +            char playlist_file[64];
>>> +            AVStream *st = s->streams[i];
>>> +            char *agroup = NULL;
>>> +            int stream_bitrate = st->codecpar->bit_rate;
>>> +            if ((st->codecpar->codec_type == AVMEDIA_TYPE_VIDEO) && max_audio_bitrate) {
>>> +                agroup = (char *)audio_group;
>>> +                stream_bitrate += max_audio_bitrate;
>>> +            }
>>>             get_hls_playlist_name(playlist_file, sizeof(playlist_file), NULL, i);
>>> -            ff_hls_write_stream_info(st, out, st->codecpar->bit_rate,
>>> -                    playlist_file, NULL);
>>> +            ff_hls_write_stream_info(st, out, stream_bitrate, playlist_file, agroup);
>>>         }
>>>         avio_close(out);
>>>         if (use_rename)
>>> --
>>> 1.9.1
>>>
>>
>> Patchset LGTM
>
> Pushed
Thanks.

Regards,
Karthick
>
> Thanks
>
> Steven
>>
>>
>> Thanks
>>
>> Steven
>> _______________________________________________
>> ffmpeg-devel mailing list
>> ffmpeg-devel at ffmpeg.org
>> http://ffmpeg.org/mailman/listinfo/ffmpeg-devel
>
>
>




More information about the ffmpeg-devel mailing list