2
* Copyright (C) 2003-2011 The Music Player Daemon Project
3
* http://www.musicpd.org
5
* This program is free software; you can redistribute it and/or modify
6
* it under the terms of the GNU General Public License as published by
7
* the Free Software Foundation; either version 2 of the License, or
8
* (at your option) any later version.
10
* This program is distributed in the hope that it will be useful,
11
* but WITHOUT ANY WARRANTY; without even the implied warranty of
12
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13
* GNU General Public License for more details.
15
* You should have received a copy of the GNU General Public License along
16
* with this program; if not, write to the Free Software Foundation, Inc.,
17
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
24
#include "pcm_resample.h"
25
#include "pcm_dither.h"
26
#include "pcm_buffer.h"
31
* This object is statically allocated (within another struct), and
32
* holds buffer allocations and the state for all kinds of PCM
35
struct pcm_convert_state {
38
struct pcm_resample_state resample;
40
struct pcm_dither dither;
42
/** the buffer for converting the sample format */
43
struct pcm_buffer format_buffer;
45
/** the buffer for converting the channel count */
46
struct pcm_buffer channels_buffer;
50
pcm_convert_quark(void)
52
return g_quark_from_static_string("pcm_convert");
56
* Initializes a pcm_convert_state object.
58
void pcm_convert_init(struct pcm_convert_state *state);
61
* Deinitializes a pcm_convert_state object and frees allocated
64
void pcm_convert_deinit(struct pcm_convert_state *state);
67
* Reset the pcm_convert_state object. Use this at the boundary
68
* between two distinct songs and each time the format changes.
71
pcm_convert_reset(struct pcm_convert_state *state);
74
* Converts PCM data between two audio formats.
76
* @param state an initialized pcm_convert_state object
77
* @param src_format the source audio format
78
* @param src the source PCM buffer
79
* @param src_size the size of #src in bytes
80
* @param dest_format the requested destination audio format
81
* @param dest_size_r returns the number of bytes of the destination buffer
82
* @param error_r location to store the error occurring, or NULL to
84
* @return the destination buffer, or NULL on error
87
pcm_convert(struct pcm_convert_state *state,
88
const struct audio_format *src_format,
89
const void *src, size_t src_size,
90
const struct audio_format *dest_format,