annotate mpc.c @ 12530:63edd10ad4bc libavcodec tip

Try to fix crashes introduced by r25218 r25218 made assumptions about the existence of past reference frames that weren't necessarily true.
author darkshikari
date Tue, 28 Sep 2010 09:06:22 +0000
parents 7dd2a45249a9
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
1 /*
5868
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
2 * Musepack decoder core
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
3 * Copyright (c) 2006 Konstantin Shishkov
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
4 *
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
5 * This file is part of FFmpeg.
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
6 *
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
7 * FFmpeg is free software; you can redistribute it and/or
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
8 * modify it under the terms of the GNU Lesser General Public
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
9 * License as published by the Free Software Foundation; either
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
10 * version 2.1 of the License, or (at your option) any later version.
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
11 *
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
12 * FFmpeg is distributed in the hope that it will be useful,
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
15 * Lesser General Public License for more details.
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
16 *
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
17 * You should have received a copy of the GNU Lesser General Public
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
18 * License along with FFmpeg; if not, write to the Free Software
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
20 */
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
21
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
22 /**
11644
7dd2a45249a9 Remove explicit filename from Doxygen @file commands.
diego
parents: 10440
diff changeset
23 * @file
7dd2a45249a9 Remove explicit filename from Doxygen @file commands.
diego
parents: 10440
diff changeset
24 * Musepack decoder core
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
25 * MPEG Audio Layer 1/2 -like codec with frames of 1152 samples
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
26 * divided into 32 subbands.
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
27 */
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
28
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
29 #include "avcodec.h"
9428
0dce4fe6e6f3 Rename bitstream.h to get_bits.h.
stefano
parents: 9153
diff changeset
30 #include "get_bits.h"
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
31 #include "dsputil.h"
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
32 #include "mpegaudio.h"
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
33
5868
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
34 #include "mpc.h"
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
35 #include "mpcdata.h"
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
36
8693
18737839ed27 Add missing void keyword to parameterless function declarations.
diego
parents: 8592
diff changeset
37 void ff_mpc_init(void)
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
38 {
10440
899237b1961f mpegaudiodec, mpc and qdm2 all use the same mpa_synth window, so make
reimar
parents: 9428
diff changeset
39 ff_mpa_synth_init(ff_mpa_synth_window);
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
40 }
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
41
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
42 /**
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
43 * Process decoded Musepack data and produce PCM
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
44 */
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
45 static void mpc_synth(MPCContext *c, int16_t *out)
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
46 {
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
47 int dither_state = 0;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
48 int i, ch;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
49 OUT_INT samples[MPA_MAX_CHANNELS * MPA_FRAME_SIZE], *samples_ptr;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
50
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
51 for(ch = 0; ch < 2; ch++){
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
52 samples_ptr = samples + ch;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
53 for(i = 0; i < SAMPLES_PER_BAND; i++) {
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
54 ff_mpa_synth_filter(c->synth_buf[ch], &(c->synth_buf_offset[ch]),
10440
899237b1961f mpegaudiodec, mpc and qdm2 all use the same mpa_synth window, so make
reimar
parents: 9428
diff changeset
55 ff_mpa_synth_window, &dither_state,
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
56 samples_ptr, 2,
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
57 c->sb_samples[ch][i]);
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
58 samples_ptr += 64;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
59 }
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
60 }
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
61 for(i = 0; i < MPC_FRAME_SIZE*2; i++)
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
62 *out++=samples[i];
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
63 }
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
64
5868
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
65 void ff_mpc_dequantize_and_synth(MPCContext * c, int maxband, void *data)
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
66 {
5868
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
67 int i, j, ch;
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
68 Band *bands = c->bands;
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
69 int off;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
70 float mul;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
71
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
72 /* dequantize */
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
73 memset(c->sb_samples, 0, sizeof(c->sb_samples));
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
74 off = 0;
5868
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
75 for(i = 0; i <= maxband; i++, off += SAMPLES_PER_BAND){
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
76 for(ch = 0; ch < 2; ch++){
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
77 if(bands[i].res[ch]){
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
78 j = 0;
5868
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
79 mul = mpc_CC[bands[i].res[ch]] * mpc_SCF[bands[i].scf_idx[ch][0]];
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
80 for(; j < 12; j++)
5868
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
81 c->sb_samples[ch][j][i] = mul * c->Q[ch][j + off];
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
82 mul = mpc_CC[bands[i].res[ch]] * mpc_SCF[bands[i].scf_idx[ch][1]];
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
83 for(; j < 24; j++)
5868
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
84 c->sb_samples[ch][j][i] = mul * c->Q[ch][j + off];
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
85 mul = mpc_CC[bands[i].res[ch]] * mpc_SCF[bands[i].scf_idx[ch][2]];
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
86 for(; j < 36; j++)
5868
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
87 c->sb_samples[ch][j][i] = mul * c->Q[ch][j + off];
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
88 }
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
89 }
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
90 if(bands[i].msf){
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
91 int t1, t2;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
92 for(j = 0; j < SAMPLES_PER_BAND; j++){
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
93 t1 = c->sb_samples[0][j][i];
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
94 t2 = c->sb_samples[1][j][i];
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
95 c->sb_samples[0][j][i] = t1 + t2;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
96 c->sb_samples[1][j][i] = t1 - t2;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
97 }
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
98 }
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
99 }
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
100
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
101 mpc_synth(c, data);
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
102 }