annotate a52dec.c @ 787:4914252c963a libavcodec

postprocessing cleanup: remove opendivx #ifdefs remove rk1 filter remove unused / obsolete stuff add -1,4,2,4,-1 deinterlacing filter (ffmpeg uses that) threadsafe / no more non-const globals some optimizations different strides for Y,U,V possible remove ebx usage (someone really should fix gcc, this is really lame) change the dering filter slightly (tell me if its worse for any files)
author michael
date Mon, 28 Oct 2002 19:30:58 +0000
parents 718a22dc121f
children e113a950c074
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
332
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
1 /*
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
2 * A52 decoder
429
718a22dc121f license/copyright change
glantau
parents: 368
diff changeset
3 * Copyright (c) 2001 Fabrice Bellard.
332
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
4 *
429
718a22dc121f license/copyright change
glantau
parents: 368
diff changeset
5 * This library is free software; you can redistribute it and/or
718a22dc121f license/copyright change
glantau
parents: 368
diff changeset
6 * modify it under the terms of the GNU Lesser General Public
718a22dc121f license/copyright change
glantau
parents: 368
diff changeset
7 * License as published by the Free Software Foundation; either
718a22dc121f license/copyright change
glantau
parents: 368
diff changeset
8 * version 2 of the License, or (at your option) any later version.
332
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
9 *
429
718a22dc121f license/copyright change
glantau
parents: 368
diff changeset
10 * This library is distributed in the hope that it will be useful,
332
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
429
718a22dc121f license/copyright change
glantau
parents: 368
diff changeset
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
718a22dc121f license/copyright change
glantau
parents: 368
diff changeset
13 * Lesser General Public License for more details.
332
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
14 *
429
718a22dc121f license/copyright change
glantau
parents: 368
diff changeset
15 * You should have received a copy of the GNU Lesser General Public
718a22dc121f license/copyright change
glantau
parents: 368
diff changeset
16 * License along with this library; if not, write to the Free Software
718a22dc121f license/copyright change
glantau
parents: 368
diff changeset
17 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
332
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
18 */
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
19 #include "avcodec.h"
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
20 #include "liba52/a52.h"
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
21
338
1a38b3b4ea28 * using liba52
kabi
parents: 332
diff changeset
22 #ifdef CONFIG_A52BIN
332
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
23 #include <dlfcn.h>
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
24 static const char* liba52name = "liba52.so.0";
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
25 #endif
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
26
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
27 /**
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
28 * liba52 - Copyright (C) Aaron Holtzman
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
29 * released under the GPL license.
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
30 */
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
31 typedef struct AC3DecodeState {
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
32 UINT8 inbuf[4096]; /* input buffer */
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
33 UINT8 *inbuf_ptr;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
34 int frame_size;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
35 int flags;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
36 int channels;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
37 a52_state_t* state;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
38 sample_t* samples;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
39
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
40 /*
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
41 * virtual method table
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
42 *
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
43 * using this function table so the liba52 doesn't
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
44 * have to be really linked together with ffmpeg
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
45 * and might be linked in runtime - this allows binary
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
46 * distribution of ffmpeg library which doens't depend
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
47 * on liba52 library - but if user has it installed
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
48 * it will be used - user might install such library
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
49 * separately
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
50 */
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
51 void* handle;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
52 a52_state_t* (*a52_init)(uint32_t mm_accel);
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
53 sample_t* (*a52_samples)(a52_state_t * state);
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
54 int (*a52_syncinfo)(uint8_t * buf, int * flags,
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
55 int * sample_rate, int * bit_rate);
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
56 int (*a52_frame)(a52_state_t * state, uint8_t * buf, int * flags,
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
57 sample_t * level, sample_t bias);
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
58 void (*a52_dynrng)(a52_state_t * state,
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
59 sample_t (* call) (sample_t, void *), void * data);
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
60 int (*a52_block)(a52_state_t * state);
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
61 void (*a52_free)(a52_state_t * state);
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
62
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
63 } AC3DecodeState;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
64
338
1a38b3b4ea28 * using liba52
kabi
parents: 332
diff changeset
65 #ifdef CONFIG_A52BIN
332
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
66 static void* dlsymm(void* handle, const char* symbol)
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
67 {
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
68 void* f = dlsym(handle, symbol);
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
69 if (!f)
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
70 fprintf(stderr, "A52 Decoder - function '%s' can't be resolved\n", symbol);
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
71 return f;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
72 }
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
73 #endif
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
74
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
75 static int a52_decode_init(AVCodecContext *avctx)
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
76 {
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
77 AC3DecodeState *s = avctx->priv_data;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
78
338
1a38b3b4ea28 * using liba52
kabi
parents: 332
diff changeset
79 #ifdef CONFIG_A52BIN
332
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
80 s->handle = dlopen(liba52name, RTLD_LAZY);
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
81 if (!s->handle)
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
82 {
368
1db6950d81ea - Segfault fixed when liba52 dynamic library isn't found.
pulento
parents: 338
diff changeset
83 fprintf(stderr, "A52 library %s could not be opened! \n%s\n", liba52name, dlerror());
332
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
84 return -1;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
85 }
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
86 s->a52_init = (a52_state_t* (*)(uint32_t)) dlsymm(s->handle, "a52_init");
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
87 s->a52_samples = (sample_t* (*)(a52_state_t*)) dlsymm(s->handle, "a52_samples");
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
88 s->a52_syncinfo = (int (*)(uint8_t*, int*, int*, int*)) dlsymm(s->handle, "a52_syncinfo");
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
89 s->a52_frame = (int (*)(a52_state_t*, uint8_t*, int*, sample_t*, sample_t)) dlsymm(s->handle, "a52_frame");
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
90 s->a52_block = (int (*)(a52_state_t*)) dlsymm(s->handle, "a52_block");
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
91 s->a52_free = (void (*)(a52_state_t*)) dlsymm(s->handle, "a52_free");
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
92 if (!s->a52_init || !s->a52_samples || !s->a52_syncinfo
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
93 || !s->a52_frame || !s->a52_block || !s->a52_free)
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
94 {
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
95 dlclose(s->handle);
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
96 return -1;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
97 }
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
98 #else
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
99 /* static linked version */
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
100 s->handle = 0;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
101 s->a52_init = a52_init;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
102 s->a52_samples = a52_samples;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
103 s->a52_syncinfo = a52_syncinfo;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
104 s->a52_frame = a52_frame;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
105 s->a52_block = a52_block;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
106 s->a52_free = a52_free;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
107 #endif
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
108 s->state = s->a52_init(0); /* later use CPU flags */
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
109 s->samples = s->a52_samples(s->state);
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
110 s->inbuf_ptr = s->inbuf;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
111 s->frame_size = 0;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
112
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
113 return 0;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
114 }
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
115
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
116 /**** the following two functions comes from a52dec */
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
117 static inline int blah (int32_t i)
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
118 {
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
119 if (i > 0x43c07fff)
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
120 return 32767;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
121 else if (i < 0x43bf8000)
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
122 return -32768;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
123 return i - 0x43c00000;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
124 }
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
125
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
126 static inline void float_to_int (float * _f, INT16 * s16, int nchannels)
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
127 {
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
128 int i, j, c;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
129 int32_t * f = (int32_t *) _f; // XXX assumes IEEE float format
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
130
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
131 j = 0;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
132 nchannels *= 256;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
133 for (i = 0; i < 256; i++) {
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
134 for (c = 0; c < nchannels; c += 256)
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
135 s16[j++] = blah (f[i + c]);
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
136 }
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
137 }
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
138
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
139 /**** end */
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
140
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
141 #define HEADER_SIZE 7
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
142
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
143 static int a52_decode_frame(AVCodecContext *avctx,
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
144 void *data, int *data_size,
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
145 UINT8 *buf, int buf_size)
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
146 {
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
147 AC3DecodeState *s = avctx->priv_data;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
148 UINT8 *buf_ptr;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
149 int flags, i, len;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
150 int sample_rate, bit_rate;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
151 short *out_samples = data;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
152 float level;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
153 static const int ac3_channels[8] = {
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
154 2, 1, 2, 3, 3, 4, 4, 5
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
155 };
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
156
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
157 *data_size = 0;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
158 buf_ptr = buf;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
159 while (buf_size > 0) {
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
160 len = s->inbuf_ptr - s->inbuf;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
161 if (s->frame_size == 0) {
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
162 /* no header seen : find one. We need at least 7 bytes to parse it */
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
163 len = HEADER_SIZE - len;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
164 if (len > buf_size)
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
165 len = buf_size;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
166 memcpy(s->inbuf_ptr, buf_ptr, len);
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
167 buf_ptr += len;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
168 s->inbuf_ptr += len;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
169 buf_size -= len;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
170 if ((s->inbuf_ptr - s->inbuf) == HEADER_SIZE) {
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
171 len = s->a52_syncinfo(s->inbuf, &s->flags, &sample_rate, &bit_rate);
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
172 if (len == 0) {
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
173 /* no sync found : move by one byte (inefficient, but simple!) */
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
174 memcpy(s->inbuf, s->inbuf + 1, HEADER_SIZE - 1);
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
175 s->inbuf_ptr--;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
176 } else {
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
177 s->frame_size = len;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
178 /* update codec info */
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
179 avctx->sample_rate = sample_rate;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
180 s->channels = ac3_channels[s->flags & 7];
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
181 if (s->flags & A52_LFE)
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
182 s->channels++;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
183 if (avctx->channels == 0)
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
184 /* No specific number of channel requested */
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
185 avctx->channels = s->channels;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
186 else if (s->channels < avctx->channels) {
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
187 fprintf(stderr, "ac3dec: AC3 Source channels are less than specified: output to %d channels.. (frmsize: %d)\n", s->channels, len);
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
188 avctx->channels = s->channels;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
189 }
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
190 avctx->bit_rate = bit_rate;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
191 }
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
192 }
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
193 } else if (len < s->frame_size) {
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
194 len = s->frame_size - len;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
195 if (len > buf_size)
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
196 len = buf_size;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
197
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
198 memcpy(s->inbuf_ptr, buf_ptr, len);
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
199 buf_ptr += len;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
200 s->inbuf_ptr += len;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
201 buf_size -= len;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
202 } else {
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
203 flags = s->flags;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
204 if (avctx->channels == 1)
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
205 flags = A52_MONO;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
206 else if (avctx->channels == 2)
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
207 flags = A52_STEREO;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
208 else
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
209 flags |= A52_ADJUST_LEVEL;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
210 level = 1;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
211 if (s->a52_frame(s->state, s->inbuf, &flags, &level, 384)) {
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
212 fail:
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
213 s->inbuf_ptr = s->inbuf;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
214 s->frame_size = 0;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
215 continue;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
216 }
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
217 for (i = 0; i < 6; i++) {
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
218 if (s->a52_block(s->state))
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
219 goto fail;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
220 float_to_int(s->samples, out_samples + i * 256 * avctx->channels, avctx->channels);
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
221 }
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
222 s->inbuf_ptr = s->inbuf;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
223 s->frame_size = 0;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
224 *data_size = 6 * avctx->channels * 256 * sizeof(INT16);
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
225 break;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
226 }
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
227 }
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
228 return buf_ptr - buf;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
229 }
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
230
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
231 static int a52_decode_end(AVCodecContext *avctx)
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
232 {
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
233 AC3DecodeState *s = avctx->priv_data;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
234 s->a52_free(s->state);
338
1a38b3b4ea28 * using liba52
kabi
parents: 332
diff changeset
235 #ifdef CONFIG_A52BIN
332
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
236 dlclose(s->handle);
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
237 #endif
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
238 return 0;
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
239 }
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
240
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
241 AVCodec ac3_decoder = {
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
242 "ac3",
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
243 CODEC_TYPE_AUDIO,
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
244 CODEC_ID_AC3,
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
245 sizeof(AC3DecodeState),
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
246 a52_decode_init,
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
247 NULL,
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
248 a52_decode_end,
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
249 a52_decode_frame,
207cc56d18f8 * add support for liba52
kabi
parents:
diff changeset
250 };