]> code.delx.au - pulseaudio/blob - src/pulsecore/resampler.h
merge glitch-free branch back into trunk
[pulseaudio] / src / pulsecore / resampler.h
1 #ifndef fooresamplerhfoo
2 #define fooresamplerhfoo
3
4 /* $Id$ */
5
6 /***
7 This file is part of PulseAudio.
8
9 Copyright 2004-2006 Lennart Poettering
10
11 PulseAudio is free software; you can redistribute it and/or modify
12 it under the terms of the GNU Lesser General Public License as published
13 by the Free Software Foundation; either version 2 of the License,
14 or (at your option) any later version.
15
16 PulseAudio is distributed in the hope that it will be useful, but
17 WITHOUT ANY WARRANTY; without even the implied warranty of
18 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
19 General Public License for more details.
20
21 You should have received a copy of the GNU Lesser General Public License
22 along with PulseAudio; if not, write to the Free Software
23 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
24 USA.
25 ***/
26
27 #include <pulse/sample.h>
28 #include <pulse/channelmap.h>
29 #include <pulsecore/memblock.h>
30 #include <pulsecore/memchunk.h>
31
32 typedef struct pa_resampler pa_resampler;
33
34 typedef enum pa_resample_method {
35 PA_RESAMPLER_INVALID = -1,
36 PA_RESAMPLER_SRC_SINC_BEST_QUALITY = 0, /* = SRC_SINC_BEST_QUALITY */
37 PA_RESAMPLER_SRC_SINC_MEDIUM_QUALITY = 1, /* = SRC_SINC_MEDIUM_QUALITY */
38 PA_RESAMPLER_SRC_SINC_FASTEST = 2, /* = SRC_SINC_FASTEST */
39 PA_RESAMPLER_SRC_ZERO_ORDER_HOLD = 3, /* = SRC_ZERO_ORDER_HOLD */
40 PA_RESAMPLER_SRC_LINEAR = 4, /* = SRC_LINEAR */
41 PA_RESAMPLER_TRIVIAL,
42 PA_RESAMPLER_SPEEX_FLOAT_BASE,
43 PA_RESAMPLER_SPEEX_FLOAT_MAX = PA_RESAMPLER_SPEEX_FLOAT_BASE + 10,
44 PA_RESAMPLER_SPEEX_FIXED_BASE,
45 PA_RESAMPLER_SPEEX_FIXED_MAX = PA_RESAMPLER_SPEEX_FIXED_BASE + 10,
46 PA_RESAMPLER_FFMPEG,
47 PA_RESAMPLER_AUTO, /* automatic select based on sample format */
48 PA_RESAMPLER_COPY,
49 PA_RESAMPLER_PEAKS,
50 PA_RESAMPLER_MAX
51 } pa_resample_method_t;
52
53 typedef enum pa_resample_flags {
54 PA_RESAMPLER_VARIABLE_RATE = 1,
55 PA_RESAMPLER_NO_REMAP = 2, /* implies NO_REMIX */
56 PA_RESAMPLER_NO_REMIX = 4
57 } pa_resample_flags_t;
58
59 pa_resampler* pa_resampler_new(
60 pa_mempool *pool,
61 const pa_sample_spec *a,
62 const pa_channel_map *am,
63 const pa_sample_spec *b,
64 const pa_channel_map *bm,
65 pa_resample_method_t resample_method,
66 pa_resample_flags_t flags);
67
68 void pa_resampler_free(pa_resampler *r);
69
70 /* Returns the size of an input memory block which is required to return the specified amount of output data */
71 size_t pa_resampler_request(pa_resampler *r, size_t out_length);
72
73 /* Inverse of pa_resampler_request() */
74 size_t pa_resampler_result(pa_resampler *r, size_t in_length);
75
76 /* Returns the maximum size of input blocks we can process without needing bounce buffers larger than the mempool tile size. */
77 size_t pa_resampler_max_block_size(pa_resampler *r);
78
79 /* Pass the specified memory chunk to the resampler and return the newly resampled data */
80 void pa_resampler_run(pa_resampler *r, const pa_memchunk *in, pa_memchunk *out);
81
82 /* Change the input rate of the resampler object */
83 void pa_resampler_set_input_rate(pa_resampler *r, uint32_t rate);
84
85 /* Change the output rate of the resampler object */
86 void pa_resampler_set_output_rate(pa_resampler *r, uint32_t rate);
87
88 /* Reinitialize state of the resampler, possibly due to seeking or other discontinuities */
89 void pa_resampler_reset(pa_resampler *r);
90
91 /* Return the resampling method of the resampler object */
92 pa_resample_method_t pa_resampler_get_method(pa_resampler *r);
93
94 /* Try to parse the resampler method */
95 pa_resample_method_t pa_parse_resample_method(const char *string);
96
97 /* return a human readable string for the specified resampling method. Inverse of pa_parse_resample_method() */
98 const char *pa_resample_method_to_string(pa_resample_method_t m);
99
100 /* Return 1 when the specified resampling method is supported */
101 int pa_resample_method_supported(pa_resample_method_t m);
102
103
104 #endif