2 This file is part of PulseAudio.
4 PulseAudio is free software; you can redistribute it and/or modify
5 it under the terms of the GNU Lesser General Public License as published
6 by the Free Software Foundation; either version 2.1 of the License,
7 or (at your option) any later version.
9 PulseAudio is distributed in the hope that it will be useful, but
10 WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 General Public License for more details.
14 You should have received a copy of the GNU Lesser General Public License
15 along with PulseAudio; if not, write to the Free Software
16 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
27 #include <pulse/sample.h>
28 #include <pulse/volume.h>
29 #include <pulse/timeval.h>
31 #include <pulsecore/envelope.h>
32 #include <pulsecore/macro.h>
33 #include <pulsecore/endianmacros.h>
34 #include <pulsecore/memblock.h>
35 #include <pulsecore/sample-util.h>
37 const pa_envelope_def ramp_down
= {
39 .points_x
= { 100*PA_USEC_PER_MSEC
, 300*PA_USEC_PER_MSEC
},
42 .i
= { 0x10000, 0x10000/5 }
46 const pa_envelope_def ramp_up
= {
48 .points_x
= { 100*PA_USEC_PER_MSEC
, 300*PA_USEC_PER_MSEC
},
51 .i
= { 0x10000/5, 0x10000 }
55 const pa_envelope_def ramp_down2
= {
57 .points_x
= { 50*PA_USEC_PER_MSEC
, 900*PA_USEC_PER_MSEC
},
60 .i
= { 0x10000*4/5, 0x10000*7/10 }
64 const pa_envelope_def ramp_up2
= {
66 .points_x
= { 50*PA_USEC_PER_MSEC
, 900*PA_USEC_PER_MSEC
},
69 .i
= { 0x10000*7/10, 0x10000*9/10 }
73 static void dump_block(const pa_sample_spec
*ss
, const pa_memchunk
*chunk
) {
77 static unsigned j
= 0;
79 d
= pa_memblock_acquire(chunk
->memblock
);
85 case PA_SAMPLE_ALAW
: {
88 for (i
= 0; i
< chunk
->length
/ pa_frame_size(ss
); i
++)
89 printf("0x%02x ", *(u
++));
95 case PA_SAMPLE_S16RE
: {
98 for (i
= 0; i
< chunk
->length
/ pa_frame_size(ss
); i
++)
99 printf("%i\t%i\n", j
++, *(u
++));
104 case PA_SAMPLE_S32NE
:
105 case PA_SAMPLE_S32RE
: {
108 for (i
= 0; i
< chunk
->length
/ pa_frame_size(ss
); i
++)
109 printf("%i\t%i\n", j
++, *(u
++));
114 case PA_SAMPLE_FLOAT32NE
:
115 case PA_SAMPLE_FLOAT32RE
: {
118 for (i
= 0; i
< chunk
->length
/ pa_frame_size(ss
); i
++) {
119 printf("%i\t%1.3g\n", j
++, PA_MAYBE_FLOAT32_SWAP(ss
->format
== PA_SAMPLE_FLOAT32RE
, *u
));
127 pa_assert_not_reached();
132 pa_memblock_release(chunk
->memblock
);
135 static pa_memblock
* generate_block(pa_mempool
*pool
, const pa_sample_spec
*ss
) {
140 block
= pa_memblock_new(pool
, pa_bytes_per_second(ss
));
141 n_samples
= (unsigned) (pa_memblock_get_length(block
) / pa_sample_size(ss
));
143 d
= pa_memblock_acquire(block
);
145 switch (ss
->format
) {
147 case PA_SAMPLE_S16NE
:
148 case PA_SAMPLE_S16RE
: {
151 for (i
= d
; n_samples
> 0; n_samples
--, i
++)
157 case PA_SAMPLE_S32NE
:
158 case PA_SAMPLE_S32RE
: {
161 for (i
= d
; n_samples
> 0; n_samples
--, i
++)
167 case PA_SAMPLE_FLOAT32RE
:
168 case PA_SAMPLE_FLOAT32NE
: {
171 for (f
= d
; n_samples
> 0; n_samples
--, f
++)
172 *f
= PA_MAYBE_FLOAT32_SWAP(ss
->format
== PA_SAMPLE_FLOAT32RE
, 1.0f
);
178 pa_assert_not_reached();
181 pa_memblock_release(block
);
185 int main(int argc
, char *argv
[]) {
189 pa_envelope
*envelope
;
190 pa_envelope_item
*item1
, *item2
;
192 const pa_sample_spec ss
= {
193 .format
= PA_SAMPLE_S16NE
,
198 const pa_cvolume v
= {
200 .values
= { PA_VOLUME_NORM
, PA_VOLUME_NORM
/2 }
203 pa_log_set_level(PA_LOG_DEBUG
);
205 pa_assert_se(pool
= pa_mempool_new(FALSE
, 0));
206 pa_assert_se(envelope
= pa_envelope_new(&ss
));
208 block
= generate_block(pool
, &ss
);
210 chunk
.memblock
= pa_memblock_ref(block
);
211 chunk
.length
= pa_memblock_get_length(block
);
214 pa_volume_memchunk(&chunk
, &ss
, &v
);
216 item1
= pa_envelope_add(envelope
, &ramp_down
);
217 item2
= pa_envelope_add(envelope
, &ramp_down2
);
218 pa_envelope_apply(envelope
, &chunk
);
219 dump_block(&ss
, &chunk
);
221 pa_memblock_unref(chunk
.memblock
);
223 chunk
.memblock
= pa_memblock_ref(block
);
224 chunk
.length
= pa_memblock_get_length(block
);
227 item1
= pa_envelope_replace(envelope
, item1
, &ramp_up
);
228 item2
= pa_envelope_replace(envelope
, item2
, &ramp_up2
);
229 pa_envelope_apply(envelope
, &chunk
);
230 dump_block(&ss
, &chunk
);
232 pa_memblock_unref(chunk
.memblock
);
234 pa_envelope_remove(envelope
, item1
);
235 pa_envelope_remove(envelope
, item2
);
236 pa_envelope_free(envelope
);
238 pa_memblock_unref(block
);
240 pa_mempool_free(pool
);