[FFmpeg-devel] [PATCH] spdifenc: support ac3 core+eac3 dependent streams

Hendrik Leppkes h.leppkes at gmail.com
Wed Apr 11 12:38:11 EEST 2018


On Tue, Apr 3, 2018 at 4:06 PM, Anssi Hannula <anssi.hannula at iki.fi> wrote:
> Hi,
>
> Hendrik Leppkes kirjoitti 2018-04-03 13:35:
>>
>> Such streams are found on Blu-ray, and identified as EAC3 type in
>> avformat, while the bitstream of the core stream is actually a pure AC3
>> frame.
>>
>> Adjust the parsing accordingly, since AC3 frames always hold 6 blocks
>> and the numblkscod syntax element is not present.
>> ---
>>  libavformat/spdifenc.c | 3 ++-
>>  1 file changed, 2 insertions(+), 1 deletion(-)
>>
>> diff --git a/libavformat/spdifenc.c b/libavformat/spdifenc.c
>> index 3a50aebbef..9514ff8e10 100644
>> --- a/libavformat/spdifenc.c
>> +++ b/libavformat/spdifenc.c
>> @@ -118,7 +118,8 @@ static int spdif_header_eac3(AVFormatContext *s,
>> AVPacket *pkt)
>>      static const uint8_t eac3_repeat[4] = {6, 3, 2, 1};
>>      int repeat = 1;
>>
>> -    if ((pkt->data[4] & 0xc0) != 0xc0) /* fscod */
>> +    int bsid = pkt->data[5] >> 3;
>> +    if (bsid > 10 && (pkt->data[4] & 0xc0) != 0xc0) /* fscod */
>>          repeat = eac3_repeat[(pkt->data[4] & 0x30) >> 4]; /* numblkscod
>> */
>>
>>      ctx->hd_buf = av_fast_realloc(ctx->hd_buf, &ctx->hd_buf_size,
>> ctx->hd_buf_filled + pkt->size);
>
>
>
> Looks good to me.
>

Pushed.


More information about the ffmpeg-devel mailing list