Mercurial > libavcodec.hg
annotate dtsdec.c @ 4478:ca8c6efd00d3 libavcodec
cosmetic: indent sensibly so code can be read at all
| author | mru |
|---|---|
| date | Mon, 05 Feb 2007 19:35:36 +0000 |
| parents | fad1bf082bf9 |
| children | f1057be02298 |
| rev | line source |
|---|---|
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
1 /* |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
2 * dtsdec.c : free DTS Coherent Acoustics stream decoder. |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
3 * Copyright (C) 2004 Benjamin Zores <ben@geexbox.org> |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
4 * |
|
3947
c8c591fe26f8
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
3267
diff
changeset
|
5 * This file is part of FFmpeg. |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
6 * |
|
3947
c8c591fe26f8
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
3267
diff
changeset
|
7 * FFmpeg is free software; you can redistribute it and/or modify |
| 2126 | 8 * it under the terms of the GNU General Public License as published by |
| 3965 | 9 * the Free Software Foundation; either version 2 of the License, or |
| 2126 | 10 * (at your option) any later version. |
| 2967 | 11 * |
|
3947
c8c591fe26f8
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
3267
diff
changeset
|
12 * FFmpeg is distributed in the hope that it will be useful, |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| 2126 | 14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| 15 * GNU General Public License for more details. | |
| 2967 | 16 * |
| 2126 | 17 * You should have received a copy of the GNU General Public License |
|
3947
c8c591fe26f8
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
3267
diff
changeset
|
18 * along with FFmpeg; if not, write to the Free Software |
| 4385 | 19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
20 */ |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
21 |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
22 #ifdef HAVE_AV_CONFIG_H |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
23 #undef HAVE_AV_CONFIG_H |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
24 #endif |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
25 |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
26 #include "avcodec.h" |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
27 #include <dts.h> |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
28 |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
29 #include <stdlib.h> |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
30 #include <string.h> |
| 2186 | 31 |
| 32 #ifdef HAVE_MALLOC_H | |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
33 #include <malloc.h> |
| 2186 | 34 #endif |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
35 |
|
3267
8072ed8993f6
dtsdec.c copies one input packet at a time to a (static) buffer of size
rtognimp
parents:
2979
diff
changeset
|
36 #define BUFFER_SIZE 18726 |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
37 #define HEADER_SIZE 14 |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
38 |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
39 #ifdef LIBDTS_FIXED |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
40 #define CONVERT_LEVEL (1 << 26) |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
41 #define CONVERT_BIAS 0 |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
42 #else |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
43 #define CONVERT_LEVEL 1 |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
44 #define CONVERT_BIAS 384 |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
45 #endif |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
46 |
| 4478 | 47 static inline int16_t |
| 48 convert(int32_t i) | |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
49 { |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
50 #ifdef LIBDTS_FIXED |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
51 i >>= 15; |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
52 #else |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
53 i -= 0x43c00000; |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
54 #endif |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
55 return (i > 32767) ? 32767 : ((i < -32768) ? -32768 : i); |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
56 } |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
57 |
| 4170 | 58 static void |
| 4478 | 59 convert2s16_2(sample_t * _f, int16_t * s16) |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
60 { |
| 4478 | 61 int i; |
| 62 int32_t *f = (int32_t *) _f; | |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
63 |
| 4478 | 64 for(i = 0; i < 256; i++) { |
| 65 s16[2 * i] = convert(f[i]); | |
| 66 s16[2 * i + 1] = convert(f[i + 256]); | |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
67 } |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
68 } |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
69 |
| 4170 | 70 static void |
| 4478 | 71 convert2s16_4(sample_t * _f, int16_t * s16) |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
72 { |
| 4478 | 73 int i; |
| 74 int32_t *f = (int32_t *) _f; | |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
75 |
| 4478 | 76 for(i = 0; i < 256; i++) { |
| 77 s16[4 * i] = convert(f[i]); | |
| 78 s16[4 * i + 1] = convert(f[i + 256]); | |
| 79 s16[4 * i + 2] = convert(f[i + 512]); | |
| 80 s16[4 * i + 3] = convert(f[i + 768]); | |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
81 } |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
82 } |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
83 |
| 4170 | 84 static void |
| 4478 | 85 convert2s16_5(sample_t * _f, int16_t * s16) |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
86 { |
| 4478 | 87 int i; |
| 88 int32_t *f = (int32_t *) _f; | |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
89 |
| 4478 | 90 for(i = 0; i < 256; i++) { |
| 91 s16[5 * i] = convert(f[i]); | |
| 92 s16[5 * i + 1] = convert(f[i + 256]); | |
| 93 s16[5 * i + 2] = convert(f[i + 512]); | |
| 94 s16[5 * i + 3] = convert(f[i + 768]); | |
| 95 s16[5 * i + 4] = convert(f[i + 1024]); | |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
96 } |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
97 } |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
98 |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
99 static void |
| 4478 | 100 convert2s16_multi(sample_t * _f, int16_t * s16, int flags) |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
101 { |
| 4478 | 102 int i; |
| 103 int32_t *f = (int32_t *) _f; | |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
104 |
| 4478 | 105 switch (flags) { |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
106 case DTS_MONO: |
| 4478 | 107 for(i = 0; i < 256; i++) { |
| 108 s16[5 * i] = s16[5 * i + 1] = s16[5 * i + 2] = s16[5 * i + 3] = | |
| 109 0; | |
| 110 s16[5 * i + 4] = convert(f[i]); | |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
111 } |
| 4478 | 112 break; |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
113 case DTS_CHANNEL: |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
114 case DTS_STEREO: |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
115 case DTS_DOLBY: |
| 4478 | 116 convert2s16_2(_f, s16); |
| 117 break; | |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
118 case DTS_3F: |
| 4478 | 119 for(i = 0; i < 256; i++) { |
| 120 s16[5 * i] = convert(f[i]); | |
| 121 s16[5 * i + 1] = convert(f[i + 512]); | |
| 122 s16[5 * i + 2] = s16[5 * i + 3] = 0; | |
| 123 s16[5 * i + 4] = convert(f[i + 256]); | |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
124 } |
| 4478 | 125 break; |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
126 case DTS_2F2R: |
| 4478 | 127 convert2s16_4(_f, s16); |
| 128 break; | |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
129 case DTS_3F2R: |
| 4478 | 130 convert2s16_5(_f, s16); |
| 131 break; | |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
132 case DTS_MONO | DTS_LFE: |
| 4478 | 133 for(i = 0; i < 256; i++) { |
| 134 s16[6 * i] = s16[6 * i + 1] = s16[6 * i + 2] = s16[6 * i + 3] = | |
| 135 0; | |
| 136 s16[6 * i + 4] = convert(f[i + 256]); | |
| 137 s16[6 * i + 5] = convert(f[i]); | |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
138 } |
| 4478 | 139 break; |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
140 case DTS_CHANNEL | DTS_LFE: |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
141 case DTS_STEREO | DTS_LFE: |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
142 case DTS_DOLBY | DTS_LFE: |
| 4478 | 143 for(i = 0; i < 256; i++) { |
| 144 s16[6 * i] = convert(f[i + 256]); | |
| 145 s16[6 * i + 1] = convert(f[i + 512]); | |
| 146 s16[6 * i + 2] = s16[6 * i + 3] = s16[6 * i + 4] = 0; | |
| 147 s16[6 * i + 5] = convert(f[i]); | |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
148 } |
| 4478 | 149 break; |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
150 case DTS_3F | DTS_LFE: |
| 4478 | 151 for(i = 0; i < 256; i++) { |
| 152 s16[6 * i] = convert(f[i + 256]); | |
| 153 s16[6 * i + 1] = convert(f[i + 768]); | |
| 154 s16[6 * i + 2] = s16[6 * i + 3] = 0; | |
| 155 s16[6 * i + 4] = convert(f[i + 512]); | |
| 156 s16[6 * i + 5] = convert(f[i]); | |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
157 } |
| 4478 | 158 break; |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
159 case DTS_2F2R | DTS_LFE: |
| 4478 | 160 for(i = 0; i < 256; i++) { |
| 161 s16[6 * i] = convert(f[i + 256]); | |
| 162 s16[6 * i + 1] = convert(f[i + 512]); | |
| 163 s16[6 * i + 2] = convert(f[i + 768]); | |
| 164 s16[6 * i + 3] = convert(f[i + 1024]); | |
| 165 s16[6 * i + 4] = 0; | |
| 166 s16[6 * i + 5] = convert(f[i]); | |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
167 } |
| 4478 | 168 break; |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
169 case DTS_3F2R | DTS_LFE: |
| 4478 | 170 for(i = 0; i < 256; i++) { |
| 171 s16[6 * i] = convert(f[i + 256]); | |
| 172 s16[6 * i + 1] = convert(f[i + 768]); | |
| 173 s16[6 * i + 2] = convert(f[i + 1024]); | |
| 174 s16[6 * i + 3] = convert(f[i + 1280]); | |
| 175 s16[6 * i + 4] = convert(f[i + 512]); | |
| 176 s16[6 * i + 5] = convert(f[i]); | |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
177 } |
| 4478 | 178 break; |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
179 } |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
180 } |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
181 |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
182 static int |
| 4478 | 183 channels_multi(int flags) |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
184 { |
| 4478 | 185 if(flags & DTS_LFE) |
| 186 return 6; | |
| 187 else if(flags & 1) /* center channel */ | |
| 188 return 5; | |
| 189 else if((flags & DTS_CHANNEL_MASK) == DTS_2F2R) | |
| 190 return 4; | |
| 191 else | |
| 192 return 2; | |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
193 } |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
194 |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
195 static int |
| 4478 | 196 dts_decode_frame(AVCodecContext * avctx, void *data, int *data_size, |
| 197 uint8_t * buff, int buff_size) | |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
198 { |
| 4478 | 199 uint8_t *start = buff; |
| 200 uint8_t *end = buff + buff_size; | |
| 201 static uint8_t buf[BUFFER_SIZE]; | |
| 202 static uint8_t *bufptr = buf; | |
| 203 static uint8_t *bufpos = buf + HEADER_SIZE; | |
| 204 int16_t *out_samples = data; | |
| 205 static int sample_rate; | |
| 206 static int frame_length; | |
| 207 static int flags; | |
| 208 int bit_rate; | |
| 209 int len; | |
| 210 dts_state_t *state = avctx->priv_data; | |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
211 |
| 4478 | 212 *data_size = 0; |
| 2222 | 213 |
| 4478 | 214 while(1) { |
| 215 len = end - start; | |
| 216 if(!len) | |
| 217 break; | |
| 218 if(len > bufpos - bufptr) | |
| 219 len = bufpos - bufptr; | |
| 220 memcpy(bufptr, start, len); | |
| 221 bufptr += len; | |
| 222 start += len; | |
| 223 if(bufptr != bufpos) | |
| 224 return start - buff; | |
| 225 if(bufpos != buf + HEADER_SIZE) | |
| 226 break; | |
|
3267
8072ed8993f6
dtsdec.c copies one input packet at a time to a (static) buffer of size
rtognimp
parents:
2979
diff
changeset
|
227 |
| 4478 | 228 { |
| 229 int length; | |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
230 |
| 4478 | 231 length = |
| 232 dts_syncinfo(state, buf, &flags, &sample_rate, &bit_rate, | |
| 233 &frame_length); | |
| 234 if(!length) { | |
| 235 av_log(NULL, AV_LOG_INFO, "skip\n"); | |
| 236 for(bufptr = buf; bufptr < buf + HEADER_SIZE - 1; bufptr++) | |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
237 bufptr[0] = bufptr[1]; |
| 4478 | 238 continue; |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
239 } |
| 4478 | 240 bufpos = buf + length; |
| 241 } | |
|
3267
8072ed8993f6
dtsdec.c copies one input packet at a time to a (static) buffer of size
rtognimp
parents:
2979
diff
changeset
|
242 } |
|
8072ed8993f6
dtsdec.c copies one input packet at a time to a (static) buffer of size
rtognimp
parents:
2979
diff
changeset
|
243 |
| 4478 | 244 { |
| 245 level_t level; | |
| 246 sample_t bias; | |
| 247 int i; | |
| 248 | |
| 249 flags = 2; /* ???????????? */ | |
| 250 level = CONVERT_LEVEL; | |
| 251 bias = CONVERT_BIAS; | |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
252 |
| 4478 | 253 flags |= DTS_ADJUST_LEVEL; |
| 254 if(dts_frame(state, buf, &flags, &level, bias)) | |
| 255 goto error; | |
| 256 avctx->sample_rate = sample_rate; | |
| 257 avctx->channels = channels_multi(flags); | |
| 258 avctx->bit_rate = bit_rate; | |
| 259 for(i = 0; i < dts_blocks_num(state); i++) { | |
| 260 if(dts_block(state)) | |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
261 goto error; |
| 4478 | 262 { |
| 263 int chans; | |
| 264 | |
| 265 chans = channels_multi(flags); | |
| 266 convert2s16_multi(dts_samples(state), out_samples, | |
| 267 flags & (DTS_CHANNEL_MASK | DTS_LFE)); | |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
268 |
| 4478 | 269 out_samples += 256 * chans; |
| 270 *data_size += 256 * sizeof(int16_t) * chans; | |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
271 } |
| 4478 | 272 } |
| 273 bufptr = buf; | |
| 274 bufpos = buf + HEADER_SIZE; | |
| 275 return start - buff; | |
| 276 error: | |
| 277 av_log(NULL, AV_LOG_ERROR, "error\n"); | |
| 278 bufptr = buf; | |
| 279 bufpos = buf + HEADER_SIZE; | |
| 280 } | |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
281 |
| 4478 | 282 return start - buff; |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
283 } |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
284 |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
285 static int |
| 4478 | 286 dts_decode_init(AVCodecContext * avctx) |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
287 { |
| 4478 | 288 avctx->priv_data = dts_init(0); |
| 289 if(avctx->priv_data == NULL) | |
| 290 return -1; | |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
291 |
| 4478 | 292 return 0; |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
293 } |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
294 |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
295 static int |
| 4478 | 296 dts_decode_end(AVCodecContext * s) |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
297 { |
| 4478 | 298 return 0; |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
299 } |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
300 |
|
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
301 AVCodec dts_decoder = { |
| 4478 | 302 "dts", |
| 303 CODEC_TYPE_AUDIO, | |
| 304 CODEC_ID_DTS, | |
| 305 sizeof(dts_state_t *), | |
| 306 dts_decode_init, | |
| 307 NULL, | |
| 308 dts_decode_end, | |
| 309 dts_decode_frame, | |
|
2123
ef54decf5624
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
diff
changeset
|
310 }; |
