annotate src/audacious/output.c @ 4237:8f6956130372

initial Replay Gain support
author Eugene Zagidullin <e.asphyx@gmail.com>
date Sat, 02 Feb 2008 01:53:15 +0300
parents 2d4b4f13d10d
children 75ea2083e744
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
1 /* Audacious - Cross-platform multimedia player
4234
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
2 * Copyright (C) 2005-2008 Audacious team
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
3 *
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
4 * Based on BMP:
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
5 * Copyright (C) 2003-2004 BMP development team.
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
6 *
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
7 * Based on XMMS:
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
8 * Copyright (C) 1998-2003 XMMS development team.
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
9 *
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
10 * This program is free software; you can redistribute it and/or modify
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
11 * it under the terms of the GNU General Public License as published by
3121
3b6d316f8b09 GPL3 relicensing.
William Pitcock <nenolod@atheme-project.org>
parents: 2813
diff changeset
12 * the Free Software Foundation; under version 3 of the License.
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
13 *
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
14 * This program is distributed in the hope that it will be useful,
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
17 * GNU General Public License for more details.
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
18 *
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
19 * You should have received a copy of the GNU General Public License
3121
3b6d316f8b09 GPL3 relicensing.
William Pitcock <nenolod@atheme-project.org>
parents: 2813
diff changeset
20 * along with this program. If not, see <http://www.gnu.org/licenses>.
3123
f1c756f39e6c Invoke "Plugins are not derived work" clause provided by GPL3.
William Pitcock <nenolod@atheme-project.org>
parents: 3121
diff changeset
21 *
f1c756f39e6c Invoke "Plugins are not derived work" clause provided by GPL3.
William Pitcock <nenolod@atheme-project.org>
parents: 3121
diff changeset
22 * The Audacious team does not consider modular code linking to
f1c756f39e6c Invoke "Plugins are not derived work" clause provided by GPL3.
William Pitcock <nenolod@atheme-project.org>
parents: 3121
diff changeset
23 * Audacious or using our public API to be a derived work.
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
24 */
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
25
4234
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
26 #define AUD_DEBUG
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
27
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
28 #ifdef HAVE_CONFIG_H
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
29 # include "config.h"
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
30 #endif
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
31
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
32 #include "output.h"
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
33 #include "iir.h"
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
34 #include "main.h"
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
35 #include "input.h"
2328
d88558b0de0a [svn] - Added script for migration to XDG basedir.
js
parents: 2313
diff changeset
36 #include "playback.h"
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
37
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
38 #include "playlist.h"
2717
6884a2144a01 [svn] - make audacious build again
nenolod
parents: 2673
diff changeset
39 #include "configdb.h"
2542
ef01234ae265 [svn] - ppc64 warning fixes for upsampling patch
nenolod
parents: 2538
diff changeset
40
3553
a140fadd741d software volumecontrol->flow manager API
William Pitcock <nenolod@atheme.org>
parents: 3549
diff changeset
41 #include "flow.h"
a140fadd741d software volumecontrol->flow manager API
William Pitcock <nenolod@atheme.org>
parents: 3549
diff changeset
42
2811
1c7ee5ed3a10 [svn] Move effect plugin handling into the main thread
ertzing
parents: 2717
diff changeset
43 #include "effect.h"
3546
fd4cd1945b91 Connect volumecontrol flow to the work pipeline.
William Pitcock <nenolod@atheme.org>
parents: 3486
diff changeset
44 #include "volumecontrol.h"
3559
0898b8139af8 Vis -> Flow API.
William Pitcock <nenolod@atheme.org>
parents: 3558
diff changeset
45 #include "visualization.h"
2811
1c7ee5ed3a10 [svn] Move effect plugin handling into the main thread
ertzing
parents: 2717
diff changeset
46
4234
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
47 #include "libSAD.h"
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
48
2542
ef01234ae265 [svn] - ppc64 warning fixes for upsampling patch
nenolod
parents: 2538
diff changeset
49 #include <math.h>
ef01234ae265 [svn] - ppc64 warning fixes for upsampling patch
nenolod
parents: 2538
diff changeset
50
2538
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
51 #ifdef USE_SRC
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
52 #include <samplerate.h>
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
53 #endif
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
54
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
55 OutputPluginData op_data = {
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
56 NULL,
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
57 NULL
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
58 };
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
59
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
60 OutputPluginState op_state = {
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
61 0,
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
62 0,
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
63 0
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
64 };
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
65
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
66 OutputPlugin psuedo_output_plugin = {
3549
a5b1084e7f38 C99 initialisers
William Pitcock <nenolod@atheme.org>
parents: 3546
diff changeset
67 .description = "XMMS reverse compatibility output plugin",
a5b1084e7f38 C99 initialisers
William Pitcock <nenolod@atheme.org>
parents: 3546
diff changeset
68 .get_volume = output_get_volume,
a5b1084e7f38 C99 initialisers
William Pitcock <nenolod@atheme.org>
parents: 3546
diff changeset
69 .set_volume = output_set_volume,
a5b1084e7f38 C99 initialisers
William Pitcock <nenolod@atheme.org>
parents: 3546
diff changeset
70
a5b1084e7f38 C99 initialisers
William Pitcock <nenolod@atheme.org>
parents: 3546
diff changeset
71 .open_audio = output_open_audio,
a5b1084e7f38 C99 initialisers
William Pitcock <nenolod@atheme.org>
parents: 3546
diff changeset
72 .write_audio = output_write_audio,
a5b1084e7f38 C99 initialisers
William Pitcock <nenolod@atheme.org>
parents: 3546
diff changeset
73 .close_audio = output_close_audio,
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
74
3549
a5b1084e7f38 C99 initialisers
William Pitcock <nenolod@atheme.org>
parents: 3546
diff changeset
75 .flush = output_flush,
a5b1084e7f38 C99 initialisers
William Pitcock <nenolod@atheme.org>
parents: 3546
diff changeset
76 .pause = output_pause,
a5b1084e7f38 C99 initialisers
William Pitcock <nenolod@atheme.org>
parents: 3546
diff changeset
77
a5b1084e7f38 C99 initialisers
William Pitcock <nenolod@atheme.org>
parents: 3546
diff changeset
78 .buffer_free = output_buffer_free,
a5b1084e7f38 C99 initialisers
William Pitcock <nenolod@atheme.org>
parents: 3546
diff changeset
79 .buffer_playing = output_buffer_playing,
a5b1084e7f38 C99 initialisers
William Pitcock <nenolod@atheme.org>
parents: 3546
diff changeset
80 .output_time = get_output_time,
a5b1084e7f38 C99 initialisers
William Pitcock <nenolod@atheme.org>
parents: 3546
diff changeset
81 .written_time = get_written_time,
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
82 };
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
83
4234
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
84 static const struct {
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
85 AFormat afmt;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
86 SAD_sample_format sadfmt;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
87 } format_table[] = {
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
88 {FMT_U8, SAD_SAMPLE_U8},
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
89 {FMT_S8, SAD_SAMPLE_S8},
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
90
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
91 {FMT_S16_LE, SAD_SAMPLE_S16_LE},
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
92 {FMT_S16_BE, SAD_SAMPLE_S16_BE},
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
93 {FMT_S16_NE, SAD_SAMPLE_S16},
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
94
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
95 {FMT_U16_LE, SAD_SAMPLE_U16_LE},
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
96 {FMT_U16_BE, SAD_SAMPLE_U16_BE},
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
97 {FMT_U16_NE, SAD_SAMPLE_U16},
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
98
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
99 {FMT_S24_LE, SAD_SAMPLE_S24_LE},
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
100 {FMT_S24_BE, SAD_SAMPLE_S24_BE},
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
101 {FMT_S24_NE, SAD_SAMPLE_S24},
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
102
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
103 {FMT_U24_LE, SAD_SAMPLE_U24_LE},
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
104 {FMT_U24_BE, SAD_SAMPLE_U24_BE},
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
105 {FMT_U24_NE, SAD_SAMPLE_U24},
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
106
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
107 {FMT_S32_LE, SAD_SAMPLE_S32_LE},
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
108 {FMT_S32_BE, SAD_SAMPLE_S32_BE},
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
109 {FMT_S32_NE, SAD_SAMPLE_S32},
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
110
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
111 {FMT_U32_LE, SAD_SAMPLE_U32_LE},
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
112 {FMT_U32_BE, SAD_SAMPLE_U32_BE},
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
113 {FMT_U32_NE, SAD_SAMPLE_U32},
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
114
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
115 {FMT_FLOAT, SAD_SAMPLE_FLOAT},
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
116 };
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
117
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
118 static inline unsigned sample_size(AFormat fmt) {
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
119 switch(fmt) {
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
120 case FMT_S8:
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
121 case FMT_U8: return sizeof(gint8);
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
122 case FMT_S16_NE:
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
123 case FMT_S16_LE:
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
124 case FMT_S16_BE:
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
125 case FMT_U16_NE:
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
126 case FMT_U16_LE:
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
127 case FMT_U16_BE: return sizeof(gint16);
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
128 case FMT_S24_NE:
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
129 case FMT_S24_LE:
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
130 case FMT_S24_BE:
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
131 case FMT_U24_NE:
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
132 case FMT_U24_LE:
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
133 case FMT_U24_BE:
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
134 case FMT_S32_NE:
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
135 case FMT_S32_LE:
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
136 case FMT_S32_BE:
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
137 case FMT_U32_NE:
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
138 case FMT_U32_LE:
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
139 case FMT_U32_BE: return sizeof(gint32);
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
140 case FMT_FLOAT: return sizeof(float);
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
141 default: return 0;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
142 }
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
143 }
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
144
4237
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
145 static void apply_replaygain_info (ReplayGainInfo *rg_info);
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
146
4234
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
147 static SAD_sample_format
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
148 sadfmt_from_afmt(AFormat fmt)
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
149 {
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
150 int i;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
151 for (i = 0; i < sizeof(format_table) / sizeof(format_table[0]); i++) {
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
152 if (format_table[i].afmt == fmt) return format_table[i].sadfmt;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
153 }
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
154
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
155 return -1;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
156 }
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
157
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
158 OutputPlugin *
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
159 get_current_output_plugin(void)
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
160 {
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
161 return op_data.current_output_plugin;
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
162 }
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
163
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
164 void
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
165 set_current_output_plugin(gint i)
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
166 {
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
167 gboolean playing;
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
168 OutputPlugin *op = get_current_output_plugin();
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
169
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
170 GList *node = g_list_nth(op_data.output_list, i);
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
171 if (!node) {
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
172 op_data.current_output_plugin = NULL;
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
173 return;
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
174 }
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
175
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
176 op_data.current_output_plugin = node->data;
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
177
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
178 playing = playback_get_playing();
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
179
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
180 if (playing == TRUE)
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
181 {
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
182 guint time, pos;
2373
ad1d7687814c [svn] made strings.h for existing strings.c, cleanups
mf0102
parents: 2328
diff changeset
183 PlaylistEntry *entry;
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
184
2373
ad1d7687814c [svn] made strings.h for existing strings.c, cleanups
mf0102
parents: 2328
diff changeset
185 /* don't stop yet, get the seek time and playlist position first */
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
186 pos = playlist_get_position(playlist_get_active());
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
187 time = op->output_time();
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
188
2373
ad1d7687814c [svn] made strings.h for existing strings.c, cleanups
mf0102
parents: 2328
diff changeset
189 /* reset the audio system */
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
190 mainwin_stop_pushed();
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
191 op->close_audio();
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
192
2373
ad1d7687814c [svn] made strings.h for existing strings.c, cleanups
mf0102
parents: 2328
diff changeset
193 g_usleep(300000);
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
194
2373
ad1d7687814c [svn] made strings.h for existing strings.c, cleanups
mf0102
parents: 2328
diff changeset
195 /* wait for the playback thread to come online */
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
196 while (playback_get_playing())
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
197 g_message("waiting for audio system shutdown...");
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
198
2373
ad1d7687814c [svn] made strings.h for existing strings.c, cleanups
mf0102
parents: 2328
diff changeset
199 /* wait for the playback thread to come online */
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
200 playlist_set_position(playlist_get_active(), pos);
2373
ad1d7687814c [svn] made strings.h for existing strings.c, cleanups
mf0102
parents: 2328
diff changeset
201 entry = playlist_get_entry_to_play(playlist_get_active());
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
202 playback_play_file(entry);
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
203
2373
ad1d7687814c [svn] made strings.h for existing strings.c, cleanups
mf0102
parents: 2328
diff changeset
204 while (!playback_get_playing())
ad1d7687814c [svn] made strings.h for existing strings.c, cleanups
mf0102
parents: 2328
diff changeset
205 {
ad1d7687814c [svn] made strings.h for existing strings.c, cleanups
mf0102
parents: 2328
diff changeset
206 gtk_main_iteration();
ad1d7687814c [svn] made strings.h for existing strings.c, cleanups
mf0102
parents: 2328
diff changeset
207 g_message("waiting for audio system startup...");
ad1d7687814c [svn] made strings.h for existing strings.c, cleanups
mf0102
parents: 2328
diff changeset
208 }
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
209
2373
ad1d7687814c [svn] made strings.h for existing strings.c, cleanups
mf0102
parents: 2328
diff changeset
210 /* and signal a reseek */
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
211 if (playlist_get_current_length(playlist_get_active()) > -1 &&
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
212 time <= (playlist_get_current_length(playlist_get_active())))
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
213 playback_seek(time / 1000);
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
214 }
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
215 }
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
216
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
217 GList *
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
218 get_output_list(void)
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
219 {
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
220 return op_data.output_list;
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
221 }
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
222
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
223 void
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
224 output_about(gint i)
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
225 {
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
226 OutputPlugin *out = g_list_nth(op_data.output_list, i)->data;
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
227 if (out && out->about)
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
228 out->about();
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
229 }
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
230
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
231 void
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
232 output_configure(gint i)
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
233 {
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
234 OutputPlugin *out = g_list_nth(op_data.output_list, i)->data;
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
235 if (out && out->configure)
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
236 out->configure();
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
237 }
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
238
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
239 void
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
240 output_get_volume(gint * l, gint * r)
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
241 {
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
242 *l = *r = -1;
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
243
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
244 if (!op_data.current_output_plugin)
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
245 return;
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
246
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
247 if (!op_data.current_output_plugin->get_volume)
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
248 return;
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
249
3546
fd4cd1945b91 Connect volumecontrol flow to the work pipeline.
William Pitcock <nenolod@atheme.org>
parents: 3486
diff changeset
250 if (cfg.software_volume_control)
fd4cd1945b91 Connect volumecontrol flow to the work pipeline.
William Pitcock <nenolod@atheme.org>
parents: 3486
diff changeset
251 volumecontrol_get_volume_state(l, r);
fd4cd1945b91 Connect volumecontrol flow to the work pipeline.
William Pitcock <nenolod@atheme.org>
parents: 3486
diff changeset
252 else
fd4cd1945b91 Connect volumecontrol flow to the work pipeline.
William Pitcock <nenolod@atheme.org>
parents: 3486
diff changeset
253 op_data.current_output_plugin->get_volume(l, r);
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
254 }
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
255
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
256 void
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
257 output_set_volume(gint l, gint r)
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
258 {
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
259 if (!op_data.current_output_plugin)
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
260 return;
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
261
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
262 if (!op_data.current_output_plugin->set_volume)
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
263 return;
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
264
3546
fd4cd1945b91 Connect volumecontrol flow to the work pipeline.
William Pitcock <nenolod@atheme.org>
parents: 3486
diff changeset
265 if (cfg.software_volume_control)
fd4cd1945b91 Connect volumecontrol flow to the work pipeline.
William Pitcock <nenolod@atheme.org>
parents: 3486
diff changeset
266 volumecontrol_set_volume_state(l, r);
fd4cd1945b91 Connect volumecontrol flow to the work pipeline.
William Pitcock <nenolod@atheme.org>
parents: 3486
diff changeset
267 else
fd4cd1945b91 Connect volumecontrol flow to the work pipeline.
William Pitcock <nenolod@atheme.org>
parents: 3486
diff changeset
268 op_data.current_output_plugin->set_volume(l, r);
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
269 }
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
270
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
271 void
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
272 output_set_eq(gboolean active, gfloat pre, gfloat * bands)
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
273 {
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
274 int i;
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
275 preamp[0] = 1.0 + 0.0932471 * pre + 0.00279033 * pre * pre;
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
276 preamp[1] = 1.0 + 0.0932471 * pre + 0.00279033 * pre * pre;
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
277
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
278 for (i = 0; i < 10; ++i)
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
279 {
2813
49f3d1b43518 [svn] - code cleanups involving SRC patch and indentation
nenolod
parents: 2811
diff changeset
280 set_gain(i, 0, 0.03 * bands[i] + 0.000999999 * bands[i] * bands[i]);
49f3d1b43518 [svn] - code cleanups involving SRC patch and indentation
nenolod
parents: 2811
diff changeset
281 set_gain(i, 1, 0.03 * bands[i] + 0.000999999 * bands[i] * bands[i]);
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
282 }
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
283 }
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
284
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
285 /* called by input plugin to peek at the output plugin's write progress */
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
286 gint
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
287 get_written_time(void)
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
288 {
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
289 OutputPlugin *op = get_current_output_plugin();
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
290
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
291 return op->written_time();
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
292 }
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
293
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
294 /* called by input plugin to peek at the output plugin's output progress */
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
295 gint
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
296 get_output_time(void)
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
297 {
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
298 OutputPlugin *op = get_current_output_plugin();
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
299
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
300 return op->output_time();
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
301 }
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
302
2538
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
303 #ifdef USE_SRC
2813
49f3d1b43518 [svn] - code cleanups involving SRC patch and indentation
nenolod
parents: 2811
diff changeset
304
2538
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
305 static SRC_STATE *src_state;
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
306 static SRC_DATA src_data;
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
307 static int overSamplingFs = 96000;
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
308 static int converter_type = SRC_SINC_BEST_QUALITY;
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
309 static int srcError = 0;
2648
51495131e4ae [svn] - synchronize SRC conversion patch with upstream
nenolod
parents: 2542
diff changeset
310
51495131e4ae [svn] - synchronize SRC conversion patch with upstream
nenolod
parents: 2542
diff changeset
311 static float *srcIn = NULL, *srcOut = NULL;
51495131e4ae [svn] - synchronize SRC conversion patch with upstream
nenolod
parents: 2542
diff changeset
312 static short int *wOut = NULL;
51495131e4ae [svn] - synchronize SRC conversion patch with upstream
nenolod
parents: 2542
diff changeset
313 static int lengthOfSrcIn = 0;
51495131e4ae [svn] - synchronize SRC conversion patch with upstream
nenolod
parents: 2542
diff changeset
314 static int lengthOfSrcOut = 0;
51495131e4ae [svn] - synchronize SRC conversion patch with upstream
nenolod
parents: 2542
diff changeset
315
2538
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
316 static void freeSRC()
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
317 {
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
318 if(src_state != NULL)
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
319 src_state = src_delete(src_state);
2648
51495131e4ae [svn] - synchronize SRC conversion patch with upstream
nenolod
parents: 2542
diff changeset
320 free(srcIn);
51495131e4ae [svn] - synchronize SRC conversion patch with upstream
nenolod
parents: 2542
diff changeset
321 free(srcOut);
51495131e4ae [svn] - synchronize SRC conversion patch with upstream
nenolod
parents: 2542
diff changeset
322 free(wOut);
51495131e4ae [svn] - synchronize SRC conversion patch with upstream
nenolod
parents: 2542
diff changeset
323 srcIn = NULL;
51495131e4ae [svn] - synchronize SRC conversion patch with upstream
nenolod
parents: 2542
diff changeset
324 srcOut = NULL;
51495131e4ae [svn] - synchronize SRC conversion patch with upstream
nenolod
parents: 2542
diff changeset
325 wOut = NULL;
51495131e4ae [svn] - synchronize SRC conversion patch with upstream
nenolod
parents: 2542
diff changeset
326 lengthOfSrcIn = 0;
51495131e4ae [svn] - synchronize SRC conversion patch with upstream
nenolod
parents: 2542
diff changeset
327 lengthOfSrcOut = 0;
2538
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
328 }
2813
49f3d1b43518 [svn] - code cleanups involving SRC patch and indentation
nenolod
parents: 2811
diff changeset
329
2538
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
330 #endif
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
331
4234
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
332 static SAD_dither_t *sad_state = NULL;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
333 static SAD_dither_t *sad_state_to_float = NULL;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
334 static SAD_dither_t *sad_state_from_float = NULL;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
335 static void *sad_out_buf = NULL;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
336 static int sad_out_buf_length = 0;
4237
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
337 static ReplayGainInfo replay_gain_info = {
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
338 .track_gain = 0.0,
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
339 .track_peak = 0.0,
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
340 .album_gain = 0.0,
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
341 .album_peak = 0.0,
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
342 };
4234
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
343
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
344 static void
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
345 freeSAD()
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
346 {
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
347 if (sad_state != NULL) {SAD_dither_free(sad_state); sad_state = NULL;}
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
348 if (sad_state_from_float != NULL) {SAD_dither_free(sad_state_from_float); sad_state_from_float = NULL;}
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
349 if (sad_state_to_float != NULL) {SAD_dither_free(sad_state_to_float); sad_state_to_float = NULL;}
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
350 if (sad_out_buf != NULL) {free(sad_out_buf); sad_out_buf = NULL; sad_out_buf_length = 0;}
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
351 }
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
352
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
353 gint
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
354 output_open_audio(AFormat fmt, gint rate, gint nch)
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
355 {
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
356 gint ret;
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
357 OutputPlugin *op;
4234
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
358 AUDDBG("\n");
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
359
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
360 AFormat output_fmt;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
361 int bit_depth;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
362 SAD_buffer_format input_sad_fmt;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
363 SAD_buffer_format output_sad_fmt;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
364
2538
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
365 #ifdef USE_SRC
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
366 gboolean src_enabled;
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
367 gint src_rate, src_type;
4237
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
368 ConfigDb *db;
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
369
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
370 db = cfg_db_open();
2538
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
371
3686
259b7d3e0976 sed s/bmp_cfg_db/cfg_db/.
William Pitcock <nenolod@atheme.org>
parents: 3681
diff changeset
372 if (cfg_db_get_bool(db, NULL, "enable_src", &src_enabled) == FALSE)
2538
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
373 src_enabled = FALSE;
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
374
3686
259b7d3e0976 sed s/bmp_cfg_db/cfg_db/.
William Pitcock <nenolod@atheme.org>
parents: 3681
diff changeset
375 if (cfg_db_get_int(db, NULL, "src_rate", &src_rate) == FALSE)
2538
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
376 overSamplingFs = 48000;
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
377 else
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
378 overSamplingFs = src_rate;
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
379
2649
153dc928115a [svn] - don't resample if source rate matches the internal clock rate. closes #881.
nenolod
parents: 2648
diff changeset
380 /* don't resample if sampling rates are the same --nenolod */
153dc928115a [svn] - don't resample if source rate matches the internal clock rate. closes #881.
nenolod
parents: 2648
diff changeset
381 if (rate == overSamplingFs)
153dc928115a [svn] - don't resample if source rate matches the internal clock rate. closes #881.
nenolod
parents: 2648
diff changeset
382 src_enabled = FALSE;
153dc928115a [svn] - don't resample if source rate matches the internal clock rate. closes #881.
nenolod
parents: 2648
diff changeset
383
3686
259b7d3e0976 sed s/bmp_cfg_db/cfg_db/.
William Pitcock <nenolod@atheme.org>
parents: 3681
diff changeset
384 if (cfg_db_get_int(db, NULL, "src_type", &src_type) == FALSE)
2538
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
385 converter_type = SRC_SINC_BEST_QUALITY;
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
386 else
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
387 converter_type = src_type;
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
388
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
389 freeSRC();
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
390
4234
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
391 if(src_enabled)
2538
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
392 {
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
393 src_state = src_new(converter_type, nch, &srcError);
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
394 if (src_state != NULL)
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
395 {
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
396 src_data.src_ratio = (float)overSamplingFs/(float)rate;
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
397 rate = overSamplingFs;
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
398 }
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
399 else
4234
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
400 {
2538
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
401 fprintf(stderr, "src_new(): %s\n\n", src_strerror(srcError));
4234
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
402 src_enabled = FALSE;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
403 }
2538
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
404 }
4237
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
405
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
406 cfg_db_close(db);
2538
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
407 #endif
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
408
4237
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
409 /*if (cfg_db_get_int(db, NULL, "output_bit_depth", &bit_depth) == FALSE) bit_depth = 16;*/
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
410 bit_depth = cfg.output_bit_depth;
4234
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
411
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
412 AUDDBG("bit depth: %d\n", bit_depth);
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
413 output_fmt = (bit_depth == 24) ? FMT_S24_NE : FMT_S16_NE; /* no reason to support other output formats --asphyx */
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
414
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
415 freeSAD();
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
416
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
417 #ifdef USE_SRC
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
418 if (src_enabled) {
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
419 AUDDBG("initializing dithering engine for 2 stage conversion\n");
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
420 input_sad_fmt.sample_format = sadfmt_from_afmt(fmt);
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
421 if (input_sad_fmt.sample_format < 0) return -1;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
422 input_sad_fmt.fracbits = 0;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
423 input_sad_fmt.channels = nch;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
424 input_sad_fmt.channels_order = SAD_CHORDER_INTERLEAVED;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
425 input_sad_fmt.samplerate = 0;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
426
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
427 output_sad_fmt.sample_format = SAD_SAMPLE_FLOAT;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
428 output_sad_fmt.fracbits = 0;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
429 output_sad_fmt.channels = nch;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
430 output_sad_fmt.channels_order = SAD_CHORDER_INTERLEAVED;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
431 output_sad_fmt.samplerate = 0;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
432
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
433 sad_state_to_float = SAD_dither_init(&input_sad_fmt, &output_sad_fmt, &ret);
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
434 if (sad_state_to_float == NULL) {
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
435 AUDDBG("ditherer init failed (decoder's native --> float)\n");
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
436 return -1;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
437 }
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
438 SAD_dither_set_dither (sad_state_to_float, FALSE);
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
439
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
440 input_sad_fmt.sample_format = SAD_SAMPLE_FLOAT;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
441 input_sad_fmt.fracbits = 0;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
442 input_sad_fmt.channels = nch;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
443 input_sad_fmt.channels_order = SAD_CHORDER_INTERLEAVED;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
444 input_sad_fmt.samplerate = 0;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
445
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
446 output_sad_fmt.sample_format = sadfmt_from_afmt(output_fmt);
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
447 if (output_sad_fmt.sample_format < 0) return -1;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
448 output_sad_fmt.fracbits = 0;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
449 output_sad_fmt.channels = nch;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
450 output_sad_fmt.channels_order = SAD_CHORDER_INTERLEAVED;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
451 output_sad_fmt.samplerate = 0;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
452
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
453 sad_state_from_float = SAD_dither_init(&input_sad_fmt, &output_sad_fmt, &ret);
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
454 if (sad_state_from_float == NULL) {
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
455 SAD_dither_free(sad_state_to_float);
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
456 AUDDBG("ditherer init failed (float --> output)\n");
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
457 return -1;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
458 }
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
459 SAD_dither_set_dither (sad_state_from_float, TRUE);
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
460
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
461 fmt = output_fmt;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
462 } else
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
463 #endif /* USE_SRC */
4237
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
464 { /* needed for RG processing !*/
4234
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
465 AUDDBG("initializing dithering engine for direct conversion\n");
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
466
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
467 input_sad_fmt.sample_format = sadfmt_from_afmt(fmt);
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
468 if (input_sad_fmt.sample_format < 0) return -1;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
469 input_sad_fmt.fracbits = 0;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
470 input_sad_fmt.channels = nch;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
471 input_sad_fmt.channels_order = SAD_CHORDER_INTERLEAVED;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
472 input_sad_fmt.samplerate = 0; /* resampling not implemented yet in libSAD */
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
473
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
474 output_sad_fmt.sample_format = sadfmt_from_afmt(output_fmt);
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
475 output_sad_fmt.fracbits = 0;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
476 output_sad_fmt.channels = nch;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
477 output_sad_fmt.channels_order = SAD_CHORDER_INTERLEAVED;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
478 output_sad_fmt.samplerate = 0;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
479
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
480 sad_state = SAD_dither_init(&input_sad_fmt, &output_sad_fmt, &ret);
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
481 if (sad_state == NULL) {
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
482 AUDDBG("ditherer init failed\n");
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
483 return -1;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
484 }
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
485 SAD_dither_set_dither (sad_state, TRUE);
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
486
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
487 fmt = output_fmt;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
488 }
4237
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
489
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
490 if(replay_gain_info.album_peak != 0.0 || replay_gain_info.track_peak != 0.0)
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
491 apply_replaygain_info(&replay_gain_info);
4234
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
492
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
493 op = get_current_output_plugin();
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
494
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
495 if (op == NULL)
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
496 return -1;
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
497
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
498 /* Is our output port already open? */
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
499 if ((op_state.rate != 0 && op_state.nch != 0) &&
2813
49f3d1b43518 [svn] - code cleanups involving SRC patch and indentation
nenolod
parents: 2811
diff changeset
500 (op_state.rate == rate && op_state.nch == nch && op_state.fmt == fmt))
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
501 {
2813
49f3d1b43518 [svn] - code cleanups involving SRC patch and indentation
nenolod
parents: 2811
diff changeset
502 /* Yes, and it's the correct sampling rate. Reset the counter and go. */
4235
2d4b4f13d10d set_replaygain_info added to PAPI
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4234
diff changeset
503 AUDDBG("flushing output instead of reopening\n");
2813
49f3d1b43518 [svn] - code cleanups involving SRC patch and indentation
nenolod
parents: 2811
diff changeset
504 op->flush(0);
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
505 return 1;
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
506 }
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
507 else if (op_state.rate != 0 && op_state.nch != 0)
2813
49f3d1b43518 [svn] - code cleanups involving SRC patch and indentation
nenolod
parents: 2811
diff changeset
508 op->close_audio();
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
509
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
510 ret = op->open_audio(fmt, rate, nch);
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
511
2373
ad1d7687814c [svn] made strings.h for existing strings.c, cleanups
mf0102
parents: 2328
diff changeset
512 if (ret == 1) /* Success? */
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
513 {
4234
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
514 AUDDBG("opened audio: fmt=%d, rate=%d, nch=%d\n", fmt, rate, nch);
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
515 op_state.fmt = fmt;
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
516 op_state.rate = rate;
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
517 op_state.nch = nch;
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
518 }
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
519
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
520 return ret;
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
521 }
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
522
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
523 void
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
524 output_write_audio(gpointer ptr, gint length)
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
525 {
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
526 OutputPlugin *op = get_current_output_plugin();
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
527
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
528 /* Sanity check. */
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
529 if (op == NULL)
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
530 return;
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
531
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
532 op->write_audio(ptr, length);
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
533 }
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
534
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
535 void
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
536 output_close_audio(void)
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
537 {
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
538 OutputPlugin *op = get_current_output_plugin();
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
539
4234
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
540 AUDDBG("\n");
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
541
2538
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
542 #ifdef USE_SRC
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
543 freeSRC();
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
544 #endif
4234
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
545 freeSAD();
4237
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
546
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
547 AUDDBG("clearing RG settings\n");
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
548 replay_gain_info.track_gain = 0.0;
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
549 replay_gain_info.track_peak = 0.0;
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
550 replay_gain_info.album_gain = 0.0;
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
551 replay_gain_info.album_peak = 0.0;
2538
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
552
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
553 /* Do not close if there are still songs to play and the user has
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
554 * not requested a stop. --nenolod
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
555 */
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
556 if (ip_data.stop == FALSE &&
2673
82e24035fdf8 [svn] - chase r4368.
nenolod
parents: 2649
diff changeset
557 (playlist_get_position_nolock(playlist_get_active()) <
82e24035fdf8 [svn] - chase r4368.
nenolod
parents: 2649
diff changeset
558 playlist_get_length(playlist_get_active()) - 1))
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
559 return;
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
560
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
561 /* Sanity check. */
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
562 if (op == NULL)
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
563 return;
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
564
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
565 op->close_audio();
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
566
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
567 /* Reset the op_state. */
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
568 op_state.fmt = op_state.rate = op_state.nch = 0;
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
569 }
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
570
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
571 void
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
572 output_flush(gint time)
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
573 {
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
574 OutputPlugin *op = get_current_output_plugin();
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
575
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
576 if (op == NULL)
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
577 return;
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
578
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
579 op->flush(time);
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
580 }
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
581
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
582 void
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
583 output_pause(gshort paused)
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
584 {
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
585 OutputPlugin *op = get_current_output_plugin();
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
586
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
587 if (op == NULL)
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
588 return;
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
589
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
590 op->pause(paused);
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
591 }
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
592
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
593 gint
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
594 output_buffer_free(void)
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
595 {
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
596 OutputPlugin *op = get_current_output_plugin();
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
597
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
598 if (op == NULL)
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
599 return 0;
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
600
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
601 return op->buffer_free();
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
602 }
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
603
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
604 gint
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
605 output_buffer_playing(void)
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
606 {
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
607 OutputPlugin *op = get_current_output_plugin();
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
608
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
609 if (op == NULL)
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
610 return 0;
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
611
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
612 return op->buffer_playing();
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
613 }
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
614
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
615 /* called by input plugin when data is ready */
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
616 void
3709
a89a12aa4f2c Add InputPlayback::pass_audio() which replaces produce_audio().
William Pitcock <nenolod@atheme.org>
parents: 3708
diff changeset
617 output_pass_audio(InputPlayback *playback,
3696
418ac922ce87 Use a mutex/condvar/timed wait to allow tickless operation in the output loop.
William Pitcock <nenolod@atheme.org>
parents: 3686
diff changeset
618 AFormat fmt, /* output format */
418ac922ce87 Use a mutex/condvar/timed wait to allow tickless operation in the output loop.
William Pitcock <nenolod@atheme.org>
parents: 3686
diff changeset
619 gint nch, /* channels */
418ac922ce87 Use a mutex/condvar/timed wait to allow tickless operation in the output loop.
William Pitcock <nenolod@atheme.org>
parents: 3686
diff changeset
620 gint length, /* length of sample */
418ac922ce87 Use a mutex/condvar/timed wait to allow tickless operation in the output loop.
William Pitcock <nenolod@atheme.org>
parents: 3686
diff changeset
621 gpointer ptr, /* data */
418ac922ce87 Use a mutex/condvar/timed wait to allow tickless operation in the output loop.
William Pitcock <nenolod@atheme.org>
parents: 3686
diff changeset
622 int *going /* 0 when time to stop */
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
623 )
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
624 {
3553
a140fadd741d software volumecontrol->flow manager API
William Pitcock <nenolod@atheme.org>
parents: 3549
diff changeset
625 static Flow *postproc_flow = NULL;
3696
418ac922ce87 Use a mutex/condvar/timed wait to allow tickless operation in the output loop.
William Pitcock <nenolod@atheme.org>
parents: 3686
diff changeset
626 OutputPlugin *op = playback->output;
418ac922ce87 Use a mutex/condvar/timed wait to allow tickless operation in the output loop.
William Pitcock <nenolod@atheme.org>
parents: 3686
diff changeset
627 gint writeoffs;
4234
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
628
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
629 if (length <= 0) return;
3696
418ac922ce87 Use a mutex/condvar/timed wait to allow tickless operation in the output loop.
William Pitcock <nenolod@atheme.org>
parents: 3686
diff changeset
630 gint time = playback->output->written_time();
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
631
3553
a140fadd741d software volumecontrol->flow manager API
William Pitcock <nenolod@atheme.org>
parents: 3549
diff changeset
632 if (postproc_flow == NULL)
a140fadd741d software volumecontrol->flow manager API
William Pitcock <nenolod@atheme.org>
parents: 3549
diff changeset
633 {
a140fadd741d software volumecontrol->flow manager API
William Pitcock <nenolod@atheme.org>
parents: 3549
diff changeset
634 postproc_flow = flow_new();
3560
154f21dcd61e equalizer -> flow API
William Pitcock <nenolod@atheme.org>
parents: 3559
diff changeset
635 flow_link_element(postproc_flow, iir_flow);
3555
a73951b8cd9f effect processing -> flow manager API / attached to postproc_flow.
William Pitcock <nenolod@atheme.org>
parents: 3553
diff changeset
636 flow_link_element(postproc_flow, effect_flow);
3559
0898b8139af8 Vis -> Flow API.
William Pitcock <nenolod@atheme.org>
parents: 3558
diff changeset
637 flow_link_element(postproc_flow, vis_flow);
3553
a140fadd741d software volumecontrol->flow manager API
William Pitcock <nenolod@atheme.org>
parents: 3549
diff changeset
638 flow_link_element(postproc_flow, volumecontrol_flow);
a140fadd741d software volumecontrol->flow manager API
William Pitcock <nenolod@atheme.org>
parents: 3549
diff changeset
639 }
a140fadd741d software volumecontrol->flow manager API
William Pitcock <nenolod@atheme.org>
parents: 3549
diff changeset
640
2538
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
641 #ifdef USE_SRC
4234
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
642 if(src_state != NULL)
2538
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
643 {
4234
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
644 /*int lrLength = length / nch;*/
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
645 int lrLength = length / sample_size(fmt);
2538
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
646 int overLrLength = (int)floor(lrLength*(src_data.src_ratio+1));
2648
51495131e4ae [svn] - synchronize SRC conversion patch with upstream
nenolod
parents: 2542
diff changeset
647 if(lengthOfSrcIn < lrLength)
51495131e4ae [svn] - synchronize SRC conversion patch with upstream
nenolod
parents: 2542
diff changeset
648 {
51495131e4ae [svn] - synchronize SRC conversion patch with upstream
nenolod
parents: 2542
diff changeset
649 lengthOfSrcIn = lrLength;
51495131e4ae [svn] - synchronize SRC conversion patch with upstream
nenolod
parents: 2542
diff changeset
650 free(srcIn);
51495131e4ae [svn] - synchronize SRC conversion patch with upstream
nenolod
parents: 2542
diff changeset
651 srcIn = (float*)malloc(sizeof(float)*lrLength);
51495131e4ae [svn] - synchronize SRC conversion patch with upstream
nenolod
parents: 2542
diff changeset
652 }
51495131e4ae [svn] - synchronize SRC conversion patch with upstream
nenolod
parents: 2542
diff changeset
653 if(lengthOfSrcOut < overLrLength)
51495131e4ae [svn] - synchronize SRC conversion patch with upstream
nenolod
parents: 2542
diff changeset
654 {
51495131e4ae [svn] - synchronize SRC conversion patch with upstream
nenolod
parents: 2542
diff changeset
655 lengthOfSrcOut = overLrLength;
51495131e4ae [svn] - synchronize SRC conversion patch with upstream
nenolod
parents: 2542
diff changeset
656 free(srcOut);
51495131e4ae [svn] - synchronize SRC conversion patch with upstream
nenolod
parents: 2542
diff changeset
657 free(wOut);
51495131e4ae [svn] - synchronize SRC conversion patch with upstream
nenolod
parents: 2542
diff changeset
658 srcOut = (float*)malloc(sizeof(float)*overLrLength);
4234
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
659 wOut = (short int*)malloc(sample_size(op_state.fmt) * overLrLength);
2648
51495131e4ae [svn] - synchronize SRC conversion patch with upstream
nenolod
parents: 2542
diff changeset
660 }
4234
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
661 /*src_short_to_float_array((short int*)ptr, srcIn, lrLength);*/
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
662 SAD_dither_process_buffer(sad_state_to_float, ptr, srcIn, lrLength / nch);
2538
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
663 src_data.data_in = srcIn;
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
664 src_data.data_out = srcOut;
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
665 src_data.end_of_input = 0;
4186
833e5faa5847 Make sample rate conversion work with mono files. (Bugzilla #88)
William Pitcock <nenolod@atheme.org>
parents: 3984
diff changeset
666 src_data.input_frames = lrLength / nch;
833e5faa5847 Make sample rate conversion work with mono files. (Bugzilla #88)
William Pitcock <nenolod@atheme.org>
parents: 3984
diff changeset
667 src_data.output_frames = overLrLength / nch;
2542
ef01234ae265 [svn] - ppc64 warning fixes for upsampling patch
nenolod
parents: 2538
diff changeset
668 if ((srcError = src_process(src_state, &src_data)) > 0)
2538
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
669 {
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
670 fprintf(stderr, "src_process(): %s\n", src_strerror(srcError));
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
671 }
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
672 else
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
673 {
4234
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
674 /*src_float_to_short_array(srcOut, wOut, src_data.output_frames_gen*2);*/
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
675 SAD_dither_process_buffer(sad_state_from_float, srcOut, wOut, src_data.output_frames_gen);
2538
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
676 ptr = wOut;
4234
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
677 length = src_data.output_frames_gen * op_state.nch * sample_size(op_state.fmt);
2538
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
678 }
4234
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
679 } else
2538
719e0898ff3c [svn] - Patch to use libsamplerate for high-quality interpolated upsampling,
nenolod
parents: 2373
diff changeset
680 #endif
4234
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
681 if(sad_state != NULL) {
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
682 int frames = length / nch / sample_size(fmt);
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
683 int len = frames * op_state.nch * sample_size(op_state.fmt);
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
684 if(sad_out_buf == NULL || sad_out_buf_length < len ) {
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
685 if(sad_out_buf != NULL) free (sad_out_buf);
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
686 sad_out_buf = malloc(len);
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
687 sad_out_buf_length = len;
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
688 }
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
689 SAD_dither_process_buffer(sad_state, ptr, sad_out_buf, frames);
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
690 ptr = sad_out_buf;
4235
2d4b4f13d10d set_replaygain_info added to PAPI
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4234
diff changeset
691 length = len;
4234
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
692 }
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
693
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
694 if (op_state.fmt == FMT_S16_NE || (op_state.fmt == FMT_S16_LE && G_BYTE_ORDER == G_LITTLE_ENDIAN) ||
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
695 (op_state.fmt == FMT_S16_BE && G_BYTE_ORDER == G_BIG_ENDIAN)) {
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
696 length = flow_execute(postproc_flow, time, &ptr, length, op_state.fmt, op_state.rate, op_state.nch);
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
697 } else {
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
698 AUDDBG("postproc_flow can deal only with S16_NE streams\n"); /*FIXME*/
b293ce14a01a partially works...
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4186
diff changeset
699 }
3546
fd4cd1945b91 Connect volumecontrol flow to the work pipeline.
William Pitcock <nenolod@atheme.org>
parents: 3486
diff changeset
700
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
701 writeoffs = 0;
2373
ad1d7687814c [svn] made strings.h for existing strings.c, cleanups
mf0102
parents: 2328
diff changeset
702 while (writeoffs < length)
ad1d7687814c [svn] made strings.h for existing strings.c, cleanups
mf0102
parents: 2328
diff changeset
703 {
ad1d7687814c [svn] made strings.h for existing strings.c, cleanups
mf0102
parents: 2328
diff changeset
704 int writable = length - writeoffs;
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
705
2373
ad1d7687814c [svn] made strings.h for existing strings.c, cleanups
mf0102
parents: 2328
diff changeset
706 if (writable > 2048)
ad1d7687814c [svn] made strings.h for existing strings.c, cleanups
mf0102
parents: 2328
diff changeset
707 writable = 2048;
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
708
2813
49f3d1b43518 [svn] - code cleanups involving SRC patch and indentation
nenolod
parents: 2811
diff changeset
709 if (writable == 0)
2373
ad1d7687814c [svn] made strings.h for existing strings.c, cleanups
mf0102
parents: 2328
diff changeset
710 return;
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
711
3486
96baf555b449 Get rid of "XMMS Multiple Effect Plugin support" hack. Effects processing is handled in produce_audio() now days.
William Pitcock <nenolod@atheme.org>
parents: 3437
diff changeset
712 while (op->buffer_free() < writable) /* wait output buf */
96baf555b449 Get rid of "XMMS Multiple Effect Plugin support" hack. Effects processing is handled in produce_audio() now days.
William Pitcock <nenolod@atheme.org>
parents: 3437
diff changeset
713 {
3696
418ac922ce87 Use a mutex/condvar/timed wait to allow tickless operation in the output loop.
William Pitcock <nenolod@atheme.org>
parents: 3686
diff changeset
714 GTimeVal pb_abs_time;
418ac922ce87 Use a mutex/condvar/timed wait to allow tickless operation in the output loop.
William Pitcock <nenolod@atheme.org>
parents: 3686
diff changeset
715
418ac922ce87 Use a mutex/condvar/timed wait to allow tickless operation in the output loop.
William Pitcock <nenolod@atheme.org>
parents: 3686
diff changeset
716 g_get_current_time(&pb_abs_time);
418ac922ce87 Use a mutex/condvar/timed wait to allow tickless operation in the output loop.
William Pitcock <nenolod@atheme.org>
parents: 3686
diff changeset
717 g_time_val_add(&pb_abs_time, (cfg.output_buffer_size / 2) * 1000);
418ac922ce87 Use a mutex/condvar/timed wait to allow tickless operation in the output loop.
William Pitcock <nenolod@atheme.org>
parents: 3686
diff changeset
718
2373
ad1d7687814c [svn] made strings.h for existing strings.c, cleanups
mf0102
parents: 2328
diff changeset
719 if (going && !*going) /* thread stopped? */
ad1d7687814c [svn] made strings.h for existing strings.c, cleanups
mf0102
parents: 2328
diff changeset
720 return; /* so finish */
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
721
3486
96baf555b449 Get rid of "XMMS Multiple Effect Plugin support" hack. Effects processing is handled in produce_audio() now days.
William Pitcock <nenolod@atheme.org>
parents: 3437
diff changeset
722 if (ip_data.stop) /* has a stop been requested? */
2373
ad1d7687814c [svn] made strings.h for existing strings.c, cleanups
mf0102
parents: 2328
diff changeset
723 return; /* yes, so finish */
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
724
3680
6615978ca88c Instead of waiting 10ms, wait half the time of the period buffer.
William Pitcock <nenolod@atheme.org>
parents: 3560
diff changeset
725 /* else sleep for retry */
3787
bce5ac1f368b don't use semaphore/condvar messaging on Darwin because mach threads are high latency
William Pitcock <nenolod@atheme.org>
parents: 3709
diff changeset
726 #ifndef GDK_WINDOWING_QUARTZ
3696
418ac922ce87 Use a mutex/condvar/timed wait to allow tickless operation in the output loop.
William Pitcock <nenolod@atheme.org>
parents: 3686
diff changeset
727 g_mutex_lock(playback->pb_change_mutex);
418ac922ce87 Use a mutex/condvar/timed wait to allow tickless operation in the output loop.
William Pitcock <nenolod@atheme.org>
parents: 3686
diff changeset
728 g_cond_timed_wait(playback->pb_change_cond, playback->pb_change_mutex, &pb_abs_time);
418ac922ce87 Use a mutex/condvar/timed wait to allow tickless operation in the output loop.
William Pitcock <nenolod@atheme.org>
parents: 3686
diff changeset
729 g_mutex_unlock(playback->pb_change_mutex);
3787
bce5ac1f368b don't use semaphore/condvar messaging on Darwin because mach threads are high latency
William Pitcock <nenolod@atheme.org>
parents: 3709
diff changeset
730 #else
bce5ac1f368b don't use semaphore/condvar messaging on Darwin because mach threads are high latency
William Pitcock <nenolod@atheme.org>
parents: 3709
diff changeset
731 /* Darwin threading sucks. */
bce5ac1f368b don't use semaphore/condvar messaging on Darwin because mach threads are high latency
William Pitcock <nenolod@atheme.org>
parents: 3709
diff changeset
732 g_usleep(10000);
bce5ac1f368b don't use semaphore/condvar messaging on Darwin because mach threads are high latency
William Pitcock <nenolod@atheme.org>
parents: 3709
diff changeset
733 #endif
2373
ad1d7687814c [svn] made strings.h for existing strings.c, cleanups
mf0102
parents: 2328
diff changeset
734 }
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
735
2373
ad1d7687814c [svn] made strings.h for existing strings.c, cleanups
mf0102
parents: 2328
diff changeset
736 if (ip_data.stop)
ad1d7687814c [svn] made strings.h for existing strings.c, cleanups
mf0102
parents: 2328
diff changeset
737 return;
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
738
2373
ad1d7687814c [svn] made strings.h for existing strings.c, cleanups
mf0102
parents: 2328
diff changeset
739 if (going && !*going) /* thread stopped? */
ad1d7687814c [svn] made strings.h for existing strings.c, cleanups
mf0102
parents: 2328
diff changeset
740 return; /* so finish */
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
741
2373
ad1d7687814c [svn] made strings.h for existing strings.c, cleanups
mf0102
parents: 2328
diff changeset
742 /* do output */
ad1d7687814c [svn] made strings.h for existing strings.c, cleanups
mf0102
parents: 2328
diff changeset
743 op->write_audio(((guint8 *) ptr) + writeoffs, writable);
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
744
2373
ad1d7687814c [svn] made strings.h for existing strings.c, cleanups
mf0102
parents: 2328
diff changeset
745 writeoffs += writable;
2313
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
746 }
3149d4b1a9a9 [svn] - objective-make autodepend fixes
nenolod
parents:
diff changeset
747 }
4235
2d4b4f13d10d set_replaygain_info added to PAPI
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4234
diff changeset
748
4237
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
749 /* called by input plugin when RG info available --asphyx */
4235
2d4b4f13d10d set_replaygain_info added to PAPI
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4234
diff changeset
750 void
2d4b4f13d10d set_replaygain_info added to PAPI
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4234
diff changeset
751 output_set_replaygain_info (InputPlayback *pb, ReplayGainInfo *rg_info)
2d4b4f13d10d set_replaygain_info added to PAPI
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4234
diff changeset
752 {
4237
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
753 replay_gain_info = *rg_info;
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
754 apply_replaygain_info(rg_info);
4235
2d4b4f13d10d set_replaygain_info added to PAPI
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4234
diff changeset
755 }
4237
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
756
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
757 static void
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
758 apply_replaygain_info (ReplayGainInfo *rg_info)
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
759 {
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
760 SAD_replaygain_mode mode;
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
761 SAD_replaygain_info info;
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
762 /*ConfigDb *db;*/
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
763 gboolean rg_enabled;
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
764 gboolean album_mode;
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
765 SAD_dither_t *active_state;
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
766
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
767
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
768 if(sad_state == NULL && sad_state_from_float == NULL) {
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
769 AUDDBG("SAD not initialized!\n");
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
770 return;
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
771 }
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
772
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
773 rg_enabled = cfg.enable_replay_gain;
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
774 album_mode = cfg.replay_gain_album;
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
775 mode.clipping_prevention = cfg.enable_clipping_prevention;
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
776 mode.hard_limit = cfg.enable_hard_limiter;
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
777
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
778 if(!rg_enabled) return;
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
779
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
780 mode.mode = album_mode ? SAD_RG_ALBUM : SAD_RG_TRACK;
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
781 mode.preamp = 0.0; /*FIXME*/
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
782
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
783 info.present = TRUE;
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
784 info.track_gain = rg_info->track_gain;
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
785 info.track_peak = rg_info->track_peak;
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
786 info.album_gain = rg_info->album_gain;
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
787 info.album_peak = rg_info->album_peak;
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
788
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
789 AUDDBG("Applying Replay Gain settings:\n");
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
790 AUDDBG("* mode: %s\n", mode.mode == SAD_RG_ALBUM ? "album" : "track");
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
791 AUDDBG("* clipping prevention: %s\n", mode.clipping_prevention ? "yes" : "no");
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
792 AUDDBG("* hard limit: %s\n", mode.hard_limit ? "yes" : "no");
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
793 AUDDBG("* preamp: %+f dB\n", mode.preamp);
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
794 AUDDBG("Replay Gain info for current track:\n");
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
795 AUDDBG("* track gain: %+f dB\n", info.track_gain);
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
796 AUDDBG("* track peak: %f\n", info.track_peak);
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
797 AUDDBG("* album gain: %+f dB\n", info.album_gain);
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
798 AUDDBG("* album peak: %f\n", info.album_peak);
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
799
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
800 active_state = sad_state != NULL ? sad_state : sad_state_from_float;
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
801 SAD_dither_apply_replaygain(active_state, &info, &mode);
8f6956130372 initial Replay Gain support
Eugene Zagidullin <e.asphyx@gmail.com>
parents: 4235
diff changeset
802 }