]> rtime.felk.cvut.cz Git - frescor/ffmpeg.git/blob - libavcodec/aac_parser.c
Pass AACAC3ParseContext to sync() instead of individual arguments. Patch by
[frescor/ffmpeg.git] / libavcodec / aac_parser.c
1 /*
2  * Audio and Video frame extraction
3  * Copyright (c) 2003 Fabrice Bellard.
4  * Copyright (c) 2003 Michael Niedermayer.
5  *
6  * This file is part of FFmpeg.
7  *
8  * FFmpeg is free software; you can redistribute it and/or
9  * modify it under the terms of the GNU Lesser General Public
10  * License as published by the Free Software Foundation; either
11  * version 2.1 of the License, or (at your option) any later version.
12  *
13  * FFmpeg is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
16  * Lesser General Public License for more details.
17  *
18  * You should have received a copy of the GNU Lesser General Public
19  * License along with FFmpeg; if not, write to the Free Software
20  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
21  */
22
23 #include "parser.h"
24 #include "aac_ac3_parser.h"
25 #include "bitstream.h"
26
27
28 #define AAC_HEADER_SIZE 7
29
30
31 static const int aac_sample_rates[16] = {
32     96000, 88200, 64000, 48000, 44100, 32000,
33     24000, 22050, 16000, 12000, 11025, 8000, 7350
34 };
35
36 static const int aac_channels[8] = {
37     0, 1, 2, 3, 4, 5, 6, 8
38 };
39
40
41 static int aac_sync(AACAC3ParseContext *hdr_info)
42 {
43     GetBitContext bits;
44     int size, rdb, ch, sr;
45
46     init_get_bits(&bits, hdr_info->inbuf, AAC_HEADER_SIZE * 8);
47
48     if(get_bits(&bits, 12) != 0xfff)
49         return 0;
50
51     skip_bits1(&bits);          /* id */
52     skip_bits(&bits, 2);        /* layer */
53     skip_bits1(&bits);          /* protection_absent */
54     skip_bits(&bits, 2);        /* profile_objecttype */
55     sr = get_bits(&bits, 4);    /* sample_frequency_index */
56     if(!aac_sample_rates[sr])
57         return 0;
58     skip_bits1(&bits);          /* private_bit */
59     ch = get_bits(&bits, 3);    /* channel_configuration */
60     if(!aac_channels[ch])
61         return 0;
62     skip_bits1(&bits);          /* original/copy */
63     skip_bits1(&bits);          /* home */
64
65     /* adts_variable_header */
66     skip_bits1(&bits);          /* copyright_identification_bit */
67     skip_bits1(&bits);          /* copyright_identification_start */
68     size = get_bits(&bits, 13); /* aac_frame_length */
69     if(size < AAC_HEADER_SIZE)
70         return 0;
71
72     skip_bits(&bits, 11);       /* adts_buffer_fullness */
73     rdb = get_bits(&bits, 2);   /* number_of_raw_data_blocks_in_frame */
74
75     hdr_info->channels = aac_channels[ch];
76     hdr_info->sample_rate = aac_sample_rates[sr];
77     hdr_info->samples = (rdb + 1) * 1024;
78     hdr_info->bit_rate = size * 8 * hdr_info->sample_rate / hdr_info->samples;
79
80     return size;
81 }
82
83 static av_cold int aac_parse_init(AVCodecParserContext *s1)
84 {
85     AACAC3ParseContext *s = s1->priv_data;
86     s->inbuf_ptr = s->inbuf;
87     s->header_size = AAC_HEADER_SIZE;
88     s->sync = aac_sync;
89     return 0;
90 }
91
92
93 AVCodecParser aac_parser = {
94     { CODEC_ID_AAC },
95     sizeof(AACAC3ParseContext),
96     aac_parse_init,
97     ff_aac_ac3_parse,
98     NULL,
99 };