1 /* Copyright (c) 2012 The Chromium OS Authors. All rights reserved.
2  * Use of this source code is governed by a BSD-style license that can be
3  * found in the LICENSE file.
4  */
5 
6 /*
7  * Used to convert from one audio format to another.  Currently only supports
8  * sample rate conversion with the speex backend.
9  */
10 #ifndef CRAS_FMT_CONV_H_
11 #define CRAS_FMT_CONV_H_
12 
13 #include <stdint.h>
14 #include <stdlib.h>
15 
16 #include "cras_types.h"
17 
18 struct cras_audio_format;
19 struct cras_fmt_conv;
20 
21 /* Create and destroy format converters. */
22 struct cras_fmt_conv *cras_fmt_conv_create(const struct cras_audio_format *in,
23 					   const struct cras_audio_format *out,
24 					   size_t max_frames,
25 					   size_t pre_linear_resample);
26 void cras_fmt_conv_destroy(struct cras_fmt_conv **conv);
27 
28 /* Creates the format converter for channel remixing. The conversion takes
29  * a N by N float matrix, to multiply each N-channels sample.
30  * Args:
31  *    num_channels - Number of channels of PCM data.
32  *    coefficient - Float array of length N * N representing the conversion
33  *        matrix, where matrix[i][j] corresponds to coefficient[i * N + j]
34  */
35 struct cras_fmt_conv *cras_channel_remix_conv_create(
36 		unsigned int num_channels,
37 		const float *coefficient);
38 
39 /* Converts nframes of sample from in_buf, using given remix converter.
40  * Args:
41  *    conv - The format converter.
42  *    fmt - The format of the buffer to convert.
43  *    in_buf - The buffer to convert.
44  *    nframes - The number of frames to convert.
45  */
46 void cras_channel_remix_convert(struct cras_fmt_conv *conv,
47 				const struct cras_audio_format *fmt,
48 				uint8_t *in_buf,
49 				size_t nframes);
50 
51 /* Get the input format of the converter. */
52 const struct cras_audio_format *cras_fmt_conv_in_format(
53 		const struct cras_fmt_conv *conv);
54 
55 /* Get the output format of the converter. */
56 const struct cras_audio_format *cras_fmt_conv_out_format(
57 		const struct cras_fmt_conv *conv);
58 
59 /* Get the number of output frames that will result from converting in_frames */
60 size_t cras_fmt_conv_in_frames_to_out(struct cras_fmt_conv *conv,
61 				      size_t in_frames);
62 /* Get the number of input frames that will result from converting out_frames */
63 size_t cras_fmt_conv_out_frames_to_in(struct cras_fmt_conv *conv,
64 				      size_t out_frames);
65 /* Sets the input and output rate to the linear resampler. */
66 void cras_fmt_conv_set_linear_resample_rates(struct cras_fmt_conv *conv,
67 					     float from,
68 					     float to);
69 /* Converts in_frames samples from in_buf, storing the results in out_buf.
70  * Args:
71  *    conv - The format converter returned from cras_fmt_conv_create().
72  *    in_buf - Samples to convert.
73  *    out_buf - Converted samples are placed here.
74  *    in_frames - Number of frames from in_buf to convert.
75  *    out_frames - Maximum number of frames to store in out_buf.  If there isn't
76  *      any format conversion, out_frames must be >= in_frames.  When doing
77  *      format conversion out_frames should be able to hold all the converted
78  *      frames, this can be checked with cras_fmt_conv_in_frames_to_out().
79  * Return number of frames put in out_buf. */
80 size_t cras_fmt_conv_convert_frames(struct cras_fmt_conv *conv,
81 				    const uint8_t *in_buf,
82 				    uint8_t *out_buf,
83 				    unsigned int *in_frames,
84 				    size_t out_frames);
85 
86 /* Checks if format conversion is needed for a fmt converter.
87  * Args:
88  *    conv - The format convert to check.
89  *  Returns:
90  *    Non-zero if a format conversion is needed.
91  */
92 int cras_fmt_conversion_needed(const struct cras_fmt_conv *conv);
93 
94 /* If the server cannot provide the requested format, configures an audio format
95  * converter that handles transforming the input format to the format used by
96  * the server.
97  * Args:
98  *    conv - filled with the new converter if needed.
99  *    dir - the stream direction the new converter used for.
100  *    from - Format to convert from.
101  *    to - Format to convert to.
102  *    frames - size of buffer.
103  */
104 int config_format_converter(struct cras_fmt_conv **conv,
105 			    enum CRAS_STREAM_DIRECTION dir,
106 			    const struct cras_audio_format *from,
107 			    const struct cras_audio_format *to,
108 			    unsigned int frames);
109 
110 #endif /* CRAS_FMT_CONV_H_ */
111