blob: 0ab7134884d2cb890a878017c6301ddb2a4683bd [file] [log] [blame]
Eric Laurentc902d7f2013-03-08 14:50:45 -08001/*
2 * BSD LICENSE
3 *
4 * Copyright (c) 2011-2012, Intel Corporation
5 * All rights reserved.
6 *
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions are met:
9 *
10 * Redistributions of source code must retain the above copyright notice,
11 * this list of conditions and the following disclaimer.
12 * Redistributions in binary form must reproduce the above copyright notice,
13 * this list of conditions and the following disclaimer in the documentation
14 * and/or other materials provided with the distribution.
15 * Neither the name of Intel Corporation nor the names of its contributors
16 * may be used to endorse or promote products derived from this software
17 * without specific prior written permission.
18 *
19 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
20 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
23 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
29 * THE POSSIBILITY OF SUCH DAMAGE.
30 *
31 * LGPL LICENSE
32 *
33 * tinycompress library for compress audio offload in alsa
34 * Copyright (c) 2011-2012, Intel Corporation.
35 *
36 *
37 * This program is free software; you can redistribute it and/or modify it
38 * under the terms and conditions of the GNU Lesser General Public License,
39 * version 2.1, as published by the Free Software Foundation.
40 *
41 * This program is distributed in the hope it will be useful, but WITHOUT
42 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
43 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
44 * License for more details.
45 *
46 * You should have received a copy of the GNU Lesser General Public License
47 * along with this program; if not, write to
48 * the Free Software Foundation, Inc.,
49 * 51 Franklin St - Fifth Floor, Boston, MA 02110-1301 USA.
50 */
51
52
53#ifndef __TINYCOMPRESS_H
54#define __TINYCOMPRESS_H
55
56#if defined(__cplusplus)
57extern "C" {
58#endif
59/*
60 * struct compr_config: config structure, needs to be filled by app
61 * If fragment_size or fragments are zero, this means "don't care"
62 * and tinycompress will choose values that the driver supports
63 *
64 * @fragment_size: size of fragment requested, in bytes
65 * @fragments: number of fragments
66 * @codec: codec type and parameters requested
67 */
68struct compr_config {
69 __u32 fragment_size;
70 __u32 fragments;
71 struct snd_codec *codec;
72};
73
74struct compr_gapless_mdata {
75 __u32 encoder_delay;
76 __u32 encoder_padding;
77};
78
Eric Laurentf0c40782013-05-02 18:10:20 -070079#define COMPRESS_OUT 0x20000000
Eric Laurentc902d7f2013-03-08 14:50:45 -080080#define COMPRESS_IN 0x10000000
81
82struct compress;
83struct snd_compr_tstamp;
84
Aniket Kumar Lata8751cec2019-01-18 16:45:01 -080085#ifdef ENABLE_EXTENDED_COMPRESS_FORMAT
86union snd_codec_options;
87struct snd_compr_metadata;
88#endif
Eric Laurentc902d7f2013-03-08 14:50:45 -080089/*
90 * compress_open: open a new compress stream
91 * returns the valid struct compress on success, NULL on failure
92 * If config does not specify a requested fragment size, on return
93 * it will be updated with the size and number of fragments that
94 * were configured
95 *
96 * @card: sound card number
97 * @device: device number
98 * @flags: device flags can be COMPRESS_OUT or COMPRESS_IN
99 * @config: stream config requested. Returns actual fragment config
100 */
101struct compress *compress_open(unsigned int card, unsigned int device,
102 unsigned int flags, struct compr_config *config);
103
104/*
105 * compress_close: close the compress stream
106 *
107 * @compress: compress stream to be closed
108 */
109void compress_close(struct compress *compress);
110
111/*
112 * compress_get_hpointer: get the hw timestamp
113 * return 0 on success, negative on error
114 *
115 * @compress: compress stream on which query is made
116 * @avail: buffer availble for write/read, in bytes
117 * @tstamp: hw time
118 */
119int compress_get_hpointer(struct compress *compress,
120 unsigned int *avail, struct timespec *tstamp);
121
122
123/*
124 * compress_get_tstamp: get the raw hw timestamp
125 * return 0 on success, negative on error
126 *
127 * @compress: compress stream on which query is made
128 * @samples: number of decoded samples played
129 * @sampling_rate: sampling rate of decoded samples
130 */
131int compress_get_tstamp(struct compress *compress,
132 unsigned long *samples, unsigned int *sampling_rate);
133
134/*
135 * compress_write: write data to the compress stream
136 * return bytes written on success, negative on error
Eric Laurent79c37072013-06-07 10:50:05 -0700137 * By default this is a blocking call and will not return
138 * until all bytes have been written or there was a
139 * write error.
140 * If non-blocking mode has been enabled with compress_nonblock(),
141 * this function will write all bytes that can be written without
142 * blocking and will then return the number of bytes successfully
143 * written. If the return value is not an error and is < size
144 * the caller can use compress_wait() to block until the driver
145 * is ready for more data.
Eric Laurentc902d7f2013-03-08 14:50:45 -0800146 *
147 * @compress: compress stream to be written to
148 * @buf: pointer to data
149 * @size: number of bytes to be written
150 */
151int compress_write(struct compress *compress, const void *buf, unsigned int size);
152
153/*
154 * compress_read: read data from the compress stream
155 * return bytes read on success, negative on error
Eric Laurent79c37072013-06-07 10:50:05 -0700156 * By default this is a blocking call and will block until
157 * size bytes have been written or there was a read error.
158 * If non-blocking mode was enabled using compress_nonblock()
159 * the behaviour will change to read only as many bytes as
160 * are currently available (if no bytes are available it
161 * will return immediately). The caller can then use
162 * compress_wait() to block until more bytes are available.
Eric Laurentc902d7f2013-03-08 14:50:45 -0800163 *
164 * @compress: compress stream from where data is to be read
165 * @buf: pointer to data buffer
166 * @size: size of given buffer
167 */
168int compress_read(struct compress *compress, void *buf, unsigned int size);
169
170/*
171 * compress_start: start the compress stream
172 * return 0 on success, negative on error
173 *
174 * @compress: compress stream to be started
175 */
176int compress_start(struct compress *compress);
177
178/*
179 * compress_stop: stop the compress stream
180 * return 0 on success, negative on error
181 *
182 * @compress: compress stream to be stopped
183 */
184int compress_stop(struct compress *compress);
185
186/*
187 * compress_pause: pause the compress stream
188 * return 0 on success, negative on error
189 *
190 * @compress: compress stream to be paused
191 */
192int compress_pause(struct compress *compress);
193
194/*
195 * compress_resume: resume the compress stream
196 * return 0 on success, negative on error
197 *
198 * @compress: compress stream to be resumed
199 */
200int compress_resume(struct compress *compress);
201
202/*
203 * compress_drain: drain the compress stream
204 * return 0 on success, negative on error
205 *
206 * @compress: compress stream to be drain
207 */
208int compress_drain(struct compress *compress);
209
210/*
211 * compress_next_track: set the next track for stream
212 *
213 * return 0 on success, negative on error
214 *
215 * @compress: compress stream to be transistioned to next track
216 */
217int compress_next_track(struct compress *compress);
218
219/*
220 * compress_partial_drain: drain will return after the last frame is decoded
221 * by DSP and will play the , All the data written into compressed
222 * ring buffer is decoded
223 *
224 * return 0 on success, negative on error
225 *
226 * @compress: compress stream to be drain
227 */
228int compress_partial_drain(struct compress *compress);
229
230/*
231 * compress_set_gapless_metadata: set gapless metadata of a compress strem
232 *
233 * return 0 on success, negative on error
234 *
235 * @compress: compress stream for which metadata has to set
236 * @mdata: metadata encoder delay and padding
237 */
238
239int compress_set_gapless_metadata(struct compress *compress,
240 struct compr_gapless_mdata *mdata);
241
Aniket Kumar Lata8751cec2019-01-18 16:45:01 -0800242#ifdef ENABLE_EXTENDED_COMPRESS_FORMAT
243/*
244 * compress_set_next_track_param: set params of next compress stream in gapless
245 *
246 * return 0 on success, negative on error
247 *
248 * @compress: compress stream for which codec options has to be set
249 * @codec_options: codec options of compress stream based on codec type
250 */
251
252int compress_set_next_track_param(struct compress *compress,
253 union snd_codec_options *codec_options);
254#endif
255
Eric Laurentc902d7f2013-03-08 14:50:45 -0800256/*
257 * is_codec_supported:check if the given codec is supported
258 * returns true when supported, false if not
259 *
260 * @card: sound card number
261 * @device: device number
262 * @flags: stream flags
263 * @codec: codec type and parameters to be checked
264 */
265bool is_codec_supported(unsigned int card, unsigned int device,
266 unsigned int flags, struct snd_codec *codec);
267
268/*
269 * compress_set_max_poll_wait: set the maximum time tinycompress
270 * will wait for driver to signal a poll(). Interval is in
271 * milliseconds.
272 * Pass interval of -1 to disable timeout and make poll() wait
273 * until driver signals.
274 * If this function is not used the timeout defaults to 20 seconds.
275 */
276void compress_set_max_poll_wait(struct compress *compress, int milliseconds);
277
Eric Laurent79c37072013-06-07 10:50:05 -0700278/* Enable or disable non-blocking mode for write and read */
279void compress_nonblock(struct compress *compress, int nonblock);
280
281/* Wait for ring buffer to ready for next read or write */
282int compress_wait(struct compress *compress, int timeout_ms);
283
Eric Laurentc902d7f2013-03-08 14:50:45 -0800284int is_compress_running(struct compress *compress);
285
286int is_compress_ready(struct compress *compress);
287
288/* Returns a human readable reason for the last error */
289const char *compress_get_error(struct compress *compress);
290/*
291 * since the SNDRV_PCM_RATE_* is not availble anywhere in userspace
292 * and we have used these to define the sampling rate, we need to define
293 * then here
294 */
295#define SNDRV_PCM_RATE_5512 (1<<0) /* 5512Hz */
296#define SNDRV_PCM_RATE_8000 (1<<1) /* 8000Hz */
297#define SNDRV_PCM_RATE_11025 (1<<2) /* 11025Hz */
298#define SNDRV_PCM_RATE_16000 (1<<3) /* 16000Hz */
299#define SNDRV_PCM_RATE_22050 (1<<4) /* 22050Hz */
300#define SNDRV_PCM_RATE_32000 (1<<5) /* 32000Hz */
301#define SNDRV_PCM_RATE_44100 (1<<6) /* 44100Hz */
302#define SNDRV_PCM_RATE_48000 (1<<7) /* 48000Hz */
303#define SNDRV_PCM_RATE_64000 (1<<8) /* 64000Hz */
304#define SNDRV_PCM_RATE_88200 (1<<9) /* 88200Hz */
305#define SNDRV_PCM_RATE_96000 (1<<10) /* 96000Hz */
306#define SNDRV_PCM_RATE_176400 (1<<11) /* 176400Hz */
307#define SNDRV_PCM_RATE_192000 (1<<12) /* 192000Hz */
308
Eric Laurent79c37072013-06-07 10:50:05 -0700309/* utility functions */
310unsigned int compress_get_alsa_rate(unsigned int rate);
Haynes Mathew George25a4b4b2014-09-25 10:24:40 -0700311
Aniket Kumar Lata8751cec2019-01-18 16:45:01 -0800312#ifdef ENABLE_EXTENDED_COMPRESS_FORMAT
313/* set metadata */
314int compress_set_metadata(struct compress *compress,
315 struct snd_compr_metadata *mdata);
316
317/* get metadata */
318int compress_get_metadata(struct compress *compress,
319 struct snd_compr_metadata *mdata);
320#endif
Haynes Mathew George25a4b4b2014-09-25 10:24:40 -0700321
322#if defined(__cplusplus)
323}
324#endif
325
Eric Laurentc902d7f2013-03-08 14:50:45 -0800326#endif