annotate mpc.c @ 8790:1045a26cb90d libavcodec

Fix crash when encoding using libschroedinger. Currently only pixel and half-pixel motion vector precisions are supported in libschroedinger. Setting the mv_precision field to 2 (i.e. quarter pixel) causes a crash in the libschroedinger encoder calls. By not setting this parameter, we fall back to the default value used in libschroedinger. patch by Anuradha Suraparaju, anuradha rd.bbc.co uk
author diego
date Tue, 10 Feb 2009 14:27:16 +0000
parents e9d9d946f213
children 4e91d96dd045
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 /**
8718
e9d9d946f213 Use full internal pathname in doxygen @file directives.
diego
parents: 8693
diff changeset
23 * @file libavcodec/mpc.c Musepack decoder core
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
24 * MPEG Audio Layer 1/2 -like codec with frames of 1152 samples
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
25 * divided into 32 subbands.
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
26 */
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
27
6763
f7cbb7733146 Use full path for #includes from another directory.
diego
parents: 5868
diff changeset
28 #include "libavutil/random.h"
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
29 #include "avcodec.h"
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
30 #include "bitstream.h"
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
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
37 static DECLARE_ALIGNED_16(MPA_INT, mpa_window[512]);
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
38
8693
18737839ed27 Add missing void keyword to parameterless function declarations.
diego
parents: 8592
diff changeset
39 void ff_mpc_init(void)
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
40 {
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
41 ff_mpa_synth_init(mpa_window);
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
42 }
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
43
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
44 /**
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
45 * Process decoded Musepack data and produce PCM
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
46 */
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
47 static void mpc_synth(MPCContext *c, int16_t *out)
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
48 {
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
49 int dither_state = 0;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
50 int i, ch;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
51 OUT_INT samples[MPA_MAX_CHANNELS * MPA_FRAME_SIZE], *samples_ptr;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
52
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
53 for(ch = 0; ch < 2; ch++){
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
54 samples_ptr = samples + ch;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
55 for(i = 0; i < SAMPLES_PER_BAND; i++) {
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
56 ff_mpa_synth_filter(c->synth_buf[ch], &(c->synth_buf_offset[ch]),
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
57 mpa_window, &dither_state,
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
58 samples_ptr, 2,
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
59 c->sb_samples[ch][i]);
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
60 samples_ptr += 64;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
61 }
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
62 }
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
63 for(i = 0; i < MPC_FRAME_SIZE*2; i++)
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
64 *out++=samples[i];
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
65 }
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 void ff_mpc_dequantize_and_synth(MPCContext * c, int maxband, void *data)
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
68 {
5868
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
69 int i, j, ch;
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
70 Band *bands = c->bands;
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
71 int off;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
72 float mul;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
73
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
74 /* dequantize */
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
75 memset(c->sb_samples, 0, sizeof(c->sb_samples));
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
76 off = 0;
5868
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
77 for(i = 0; i <= maxband; i++, off += SAMPLES_PER_BAND){
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
78 for(ch = 0; ch < 2; ch++){
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
79 if(bands[i].res[ch]){
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
80 j = 0;
5868
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
81 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
82 for(; j < 12; j++)
5868
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
83 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
84 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
85 for(; j < 24; j++)
5868
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
86 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
87 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
88 for(; j < 36; j++)
5868
2cc044ac80d4 Split Musepack decoder into SV7 decoder and synth core
kostya
parents: 5215
diff changeset
89 c->sb_samples[ch][j][i] = mul * c->Q[ch][j + off];
4328
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
90 }
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
91 }
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
92 if(bands[i].msf){
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
93 int t1, t2;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
94 for(j = 0; j < SAMPLES_PER_BAND; j++){
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
95 t1 = c->sb_samples[0][j][i];
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
96 t2 = c->sb_samples[1][j][i];
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
97 c->sb_samples[0][j][i] = t1 + t2;
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
98 c->sb_samples[1][j][i] = t1 - t2;
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 }
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
102
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
103 mpc_synth(c, data);
a0cfbd6679c0 Musepack SV7 decoding support
kostya
parents:
diff changeset
104 }