The AAC decoder and ADTS-to-ASC BSF both require the header decoder but not full parsing capabilities. Originally committed as revision 24217 to svn://svn.ffmpeg.org/ffmpeg/trunktags/n0.8
| @@ -1162,7 +1162,7 @@ mdct_select="fft" | |||
| rdft_select="fft" | |||
| # decoders / encoders / hardware accelerators | |||
| aac_decoder_select="mdct rdft aac_parser" | |||
| aac_decoder_select="mdct rdft" | |||
| aac_encoder_select="mdct" | |||
| ac3_decoder_select="mdct ac3_parser" | |||
| alac_encoder_select="lpc" | |||
| @@ -1294,9 +1294,6 @@ vdpau_deps="vdpau_vdpau_h vdpau_vdpau_x11_h" | |||
| # parsers | |||
| h264_parser_select="golomb h264dsp" | |||
| # bitstream_filters | |||
| aac_adtstoasc_bsf_select="aac_parser" | |||
| # external libraries | |||
| libdirac_decoder_deps="libdirac !libschroedinger" | |||
| libdirac_encoder_deps="libdirac" | |||
| @@ -42,7 +42,8 @@ OBJS-$(CONFIG_VAAPI) += vaapi.o | |||
| OBJS-$(CONFIG_VDPAU) += vdpau.o | |||
| # decoders/encoders/hardware accelerators | |||
| OBJS-$(CONFIG_AAC_DECODER) += aacdec.o aactab.o aacsbr.o aacps.o | |||
| OBJS-$(CONFIG_AAC_DECODER) += aacdec.o aactab.o aacsbr.o aacps.o \ | |||
| aacadtsdec.o mpeg4audio.o | |||
| OBJS-$(CONFIG_AAC_ENCODER) += aacenc.o aaccoder.o \ | |||
| aacpsy.o aactab.o \ | |||
| psymodel.o iirfilter.o \ | |||
| @@ -550,7 +551,7 @@ OBJS-$(CONFIG_LIBXVID) += libxvidff.o libxvid_rc.o | |||
| # parsers | |||
| OBJS-$(CONFIG_AAC_PARSER) += aac_parser.o aac_ac3_parser.o \ | |||
| mpeg4audio.o | |||
| aacadtsdec.o mpeg4audio.o | |||
| OBJS-$(CONFIG_AC3_PARSER) += ac3_parser.o ac3tab.o \ | |||
| aac_ac3_parser.o | |||
| OBJS-$(CONFIG_CAVSVIDEO_PARSER) += cavs_parser.o | |||
| @@ -586,7 +587,8 @@ OBJS-$(CONFIG_VP3_PARSER) += vp3_parser.o | |||
| OBJS-$(CONFIG_VP8_PARSER) += vp8_parser.o | |||
| # bitstream filters | |||
| OBJS-$(CONFIG_AAC_ADTSTOASC_BSF) += aac_adtstoasc_bsf.o | |||
| OBJS-$(CONFIG_AAC_ADTSTOASC_BSF) += aac_adtstoasc_bsf.o aacadtsdec.o \ | |||
| mpeg4audio.o | |||
| OBJS-$(CONFIG_CHOMP_BSF) += chomp_bsf.o | |||
| OBJS-$(CONFIG_DUMP_EXTRADATA_BSF) += dump_extradata_bsf.o | |||
| OBJS-$(CONFIG_H264_MP4TOANNEXB_BSF) += h264_mp4toannexb_bsf.o | |||
| @@ -20,7 +20,7 @@ | |||
| */ | |||
| #include "avcodec.h" | |||
| #include "aac_parser.h" | |||
| #include "aacadtsdec.h" | |||
| #include "put_bits.h" | |||
| #include "get_bits.h" | |||
| #include "mpeg4audio.h" | |||
| @@ -22,53 +22,10 @@ | |||
| #include "parser.h" | |||
| #include "aac_ac3_parser.h" | |||
| #include "aac_parser.h" | |||
| #include "aacadtsdec.h" | |||
| #include "get_bits.h" | |||
| #include "mpeg4audio.h" | |||
| int ff_aac_parse_header(GetBitContext *gbc, AACADTSHeaderInfo *hdr) | |||
| { | |||
| int size, rdb, ch, sr; | |||
| int aot, crc_abs; | |||
| if(get_bits(gbc, 12) != 0xfff) | |||
| return AAC_AC3_PARSE_ERROR_SYNC; | |||
| 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 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(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(gbc, 11); /* adts_buffer_fullness */ | |||
| rdb = get_bits(gbc, 2); /* number_of_raw_data_blocks_in_frame */ | |||
| 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) | |||
| { | |||
| @@ -0,0 +1,70 @@ | |||
| /* | |||
| * Audio and Video frame extraction | |||
| * Copyright (c) 2003 Fabrice Bellard | |||
| * Copyright (c) 2003 Michael Niedermayer | |||
| * Copyright (c) 2009 Alex Converse | |||
| * | |||
| * This file is part of FFmpeg. | |||
| * | |||
| * FFmpeg is free software; you can redistribute it and/or | |||
| * modify it under the terms of the GNU Lesser General Public | |||
| * License as published by the Free Software Foundation; either | |||
| * version 2.1 of the License, or (at your option) any later version. | |||
| * | |||
| * FFmpeg is distributed in the hope that it will be useful, | |||
| * but WITHOUT ANY WARRANTY; without even the implied warranty of | |||
| * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |||
| * Lesser General Public License for more details. | |||
| * | |||
| * You should have received a copy of the GNU Lesser General Public | |||
| * License along with FFmpeg; if not, write to the Free Software | |||
| * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA | |||
| */ | |||
| #include "aac_ac3_parser.h" | |||
| #include "aacadtsdec.h" | |||
| #include "get_bits.h" | |||
| #include "mpeg4audio.h" | |||
| int ff_aac_parse_header(GetBitContext *gbc, AACADTSHeaderInfo *hdr) | |||
| { | |||
| int size, rdb, ch, sr; | |||
| int aot, crc_abs; | |||
| if(get_bits(gbc, 12) != 0xfff) | |||
| return AAC_AC3_PARSE_ERROR_SYNC; | |||
| 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 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(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(gbc, 11); /* adts_buffer_fullness */ | |||
| rdb = get_bits(gbc, 2); /* number_of_raw_data_blocks_in_frame */ | |||
| 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; | |||
| } | |||
| @@ -1,5 +1,5 @@ | |||
| /* | |||
| * AAC parser prototypes | |||
| * AAC ADTS header decoding prototypes and structures | |||
| * Copyright (c) 2003 Fabrice Bellard | |||
| * Copyright (c) 2003 Michael Niedermayer | |||
| * | |||
| @@ -20,11 +20,10 @@ | |||
| * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA | |||
| */ | |||
| #ifndef AVCODEC_AAC_PARSER_H | |||
| #define AVCODEC_AAC_PARSER_H | |||
| #ifndef AVCODEC_AACADTSDEC_H | |||
| #define AVCODEC_AACADTSDEC_H | |||
| #include <stdint.h> | |||
| #include "aac_ac3_parser.h" | |||
| #include "get_bits.h" | |||
| #define AAC_ADTS_HEADER_SIZE 7 | |||
| @@ -52,4 +51,4 @@ typedef struct { | |||
| */ | |||
| int ff_aac_parse_header(GetBitContext *gbc, AACADTSHeaderInfo *hdr); | |||
| #endif /* AVCODEC_AAC_PARSER_H */ | |||
| #endif /* AVCODEC_AACADTSDEC_H */ | |||
| @@ -90,7 +90,7 @@ | |||
| #include "sbr.h" | |||
| #include "aacsbr.h" | |||
| #include "mpeg4audio.h" | |||
| #include "aac_parser.h" | |||
| #include "aacadtsdec.h" | |||
| #include <assert.h> | |||
| #include <errno.h> | |||
| @@ -43,7 +43,7 @@ | |||
| #include "avformat.h" | |||
| #include "libavcodec/ac3.h" | |||
| #include "libavcodec/dca.h" | |||
| #include "libavcodec/aac_parser.h" | |||
| #include "libavcodec/aacadtsdec.h" | |||
| #define SYNCWORD1 0xF872 | |||
| #define SYNCWORD2 0x4E1F | |||