X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=libavcodec%2Faac_parser.c;h=30ce04d4ad7a62fc7c1f2e07a728219e19337792;hb=7817ddabc8ccb417c293c3c788dcbc6b225840b4;hp=db2c697725d6edcd5799032c16edb789b37f82c0;hpb=133ac890fbe48b2989a257eb58bfc0b3690ee054;p=ffmpeg diff --git a/libavcodec/aac_parser.c b/libavcodec/aac_parser.c index db2c697725d..30ce04d4ad7 100644 --- a/libavcodec/aac_parser.c +++ b/libavcodec/aac_parser.c @@ -1,7 +1,7 @@ /* * Audio and Video frame extraction - * Copyright (c) 2003 Fabrice Bellard. - * Copyright (c) 2003 Michael Niedermayer. + * Copyright (c) 2003 Fabrice Bellard + * Copyright (c) 2003 Michael Niedermayer * * This file is part of FFmpeg. * @@ -22,61 +22,82 @@ #include "parser.h" #include "aac_ac3_parser.h" -#include "bitstream.h" +#include "aac_parser.h" +#include "get_bits.h" #include "mpeg4audio.h" -#define AAC_HEADER_SIZE 7 - -static int aac_sync(uint64_t state, AACAC3ParseContext *hdr_info, - int *need_next_header, int *new_frame_start) +int ff_aac_parse_header(GetBitContext *gbc, AACADTSHeaderInfo *hdr) { - GetBitContext bits; int size, rdb, ch, sr; - uint64_t tmp = be2me_64(state); - - init_get_bits(&bits, ((uint8_t *)&tmp)+8-AAC_HEADER_SIZE, AAC_HEADER_SIZE * 8); + int aot, crc_abs; - if(get_bits(&bits, 12) != 0xfff) - return 0; + if(get_bits(gbc, 12) != 0xfff) + return AAC_AC3_PARSE_ERROR_SYNC; - skip_bits1(&bits); /* id */ - skip_bits(&bits, 2); /* layer */ - skip_bits1(&bits); /* protection_absent */ - skip_bits(&bits, 2); /* profile_objecttype */ - sr = get_bits(&bits, 4); /* sample_frequency_index */ + skip_bits1(gbc); /* id */ + skip_bits(gbc, 2); /* layer */ + crc_abs = get_bits1(gbc); /* protection_absent */ + aot = get_bits(gbc, 2); /* profile_objecttype */ + sr = get_bits(gbc, 4); /* sample_frequency_index */ if(!ff_mpeg4audio_sample_rates[sr]) - return 0; - skip_bits1(&bits); /* private_bit */ - ch = get_bits(&bits, 3); /* channel_configuration */ - if(!ff_mpeg4audio_channels[ch]) - return 0; - skip_bits1(&bits); /* original/copy */ - skip_bits1(&bits); /* home */ + return AAC_AC3_PARSE_ERROR_SAMPLE_RATE; + skip_bits1(gbc); /* private_bit */ + ch = get_bits(gbc, 3); /* channel_configuration */ + + skip_bits1(gbc); /* original/copy */ + skip_bits1(gbc); /* home */ /* adts_variable_header */ - skip_bits1(&bits); /* copyright_identification_bit */ - skip_bits1(&bits); /* copyright_identification_start */ - size = get_bits(&bits, 13); /* aac_frame_length */ - if(size < AAC_HEADER_SIZE) - return 0; + skip_bits1(gbc); /* copyright_identification_bit */ + skip_bits1(gbc); /* copyright_identification_start */ + size = get_bits(gbc, 13); /* aac_frame_length */ + if(size < AAC_ADTS_HEADER_SIZE) + return AAC_AC3_PARSE_ERROR_FRAME_SIZE; - skip_bits(&bits, 11); /* adts_buffer_fullness */ - rdb = get_bits(&bits, 2); /* number_of_raw_data_blocks_in_frame */ + skip_bits(gbc, 11); /* adts_buffer_fullness */ + rdb = get_bits(gbc, 2); /* number_of_raw_data_blocks_in_frame */ - hdr_info->channels = ff_mpeg4audio_channels[ch]; - hdr_info->sample_rate = ff_mpeg4audio_sample_rates[sr]; - hdr_info->samples = (rdb + 1) * 1024; - hdr_info->bit_rate = size * 8 * hdr_info->sample_rate / hdr_info->samples; + hdr->object_type = aot + 1; + hdr->chan_config = ch; + hdr->crc_absent = crc_abs; + hdr->num_aac_frames = rdb + 1; + hdr->sampling_index = sr; + hdr->sample_rate = ff_mpeg4audio_sample_rates[sr]; + hdr->samples = (rdb + 1) * 1024; + hdr->bit_rate = size * 8 * hdr->sample_rate / hdr->samples; + return size; +} + +static int aac_sync(uint64_t state, AACAC3ParseContext *hdr_info, + int *need_next_header, int *new_frame_start) +{ + GetBitContext bits; + AACADTSHeaderInfo hdr; + int size; + union { + uint64_t u64; + uint8_t u8[8]; + } tmp; + + tmp.u64 = be2me_64(state); + init_get_bits(&bits, tmp.u8+8-AAC_ADTS_HEADER_SIZE, AAC_ADTS_HEADER_SIZE * 8); + + if ((size = ff_aac_parse_header(&bits, &hdr)) < 0) + return 0; *need_next_header = 0; *new_frame_start = 1; + hdr_info->sample_rate = hdr.sample_rate; + hdr_info->channels = ff_mpeg4audio_channels[hdr.chan_config]; + hdr_info->samples = hdr.samples; + hdr_info->bit_rate = hdr.bit_rate; return size; } static av_cold int aac_parse_init(AVCodecParserContext *s1) { AACAC3ParseContext *s = s1->priv_data; - s->header_size = AAC_HEADER_SIZE; + s->header_size = AAC_ADTS_HEADER_SIZE; s->sync = aac_sync; return 0; } @@ -87,5 +108,5 @@ AVCodecParser aac_parser = { sizeof(AACAC3ParseContext), aac_parse_init, ff_aac_ac3_parse, - NULL, + ff_parse_close, };