Eric Laurent | c902d7f | 2013-03-08 14:50:45 -0800 | [diff] [blame] | 1 | /* |
| 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) |
| 57 | extern "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 | */ |
| 68 | struct compr_config { |
| 69 | __u32 fragment_size; |
| 70 | __u32 fragments; |
| 71 | struct snd_codec *codec; |
| 72 | }; |
| 73 | |
| 74 | struct compr_gapless_mdata { |
| 75 | __u32 encoder_delay; |
| 76 | __u32 encoder_padding; |
| 77 | }; |
| 78 | |
Eric Laurent | f0c4078 | 2013-05-02 18:10:20 -0700 | [diff] [blame] | 79 | #define COMPRESS_OUT 0x20000000 |
Eric Laurent | c902d7f | 2013-03-08 14:50:45 -0800 | [diff] [blame] | 80 | #define COMPRESS_IN 0x10000000 |
| 81 | |
| 82 | struct compress; |
| 83 | struct snd_compr_tstamp; |
| 84 | |
Aniket Kumar Lata | 8751cec | 2019-01-18 16:45:01 -0800 | [diff] [blame] | 85 | #ifdef ENABLE_EXTENDED_COMPRESS_FORMAT |
| 86 | union snd_codec_options; |
| 87 | struct snd_compr_metadata; |
| 88 | #endif |
Eric Laurent | c902d7f | 2013-03-08 14:50:45 -0800 | [diff] [blame] | 89 | /* |
| 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 | */ |
| 101 | struct 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 | */ |
| 109 | void 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 | */ |
| 119 | int 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 | */ |
| 131 | int 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 Laurent | 79c3707 | 2013-06-07 10:50:05 -0700 | [diff] [blame] | 137 | * 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 Laurent | c902d7f | 2013-03-08 14:50:45 -0800 | [diff] [blame] | 146 | * |
| 147 | * @compress: compress stream to be written to |
| 148 | * @buf: pointer to data |
| 149 | * @size: number of bytes to be written |
| 150 | */ |
| 151 | int 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 Laurent | 79c3707 | 2013-06-07 10:50:05 -0700 | [diff] [blame] | 156 | * 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 Laurent | c902d7f | 2013-03-08 14:50:45 -0800 | [diff] [blame] | 163 | * |
| 164 | * @compress: compress stream from where data is to be read |
| 165 | * @buf: pointer to data buffer |
| 166 | * @size: size of given buffer |
| 167 | */ |
| 168 | int 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 | */ |
| 176 | int 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 | */ |
| 184 | int 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 | */ |
| 192 | int 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 | */ |
| 200 | int 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 | */ |
| 208 | int 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 | */ |
| 217 | int 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 | */ |
| 228 | int 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 | |
| 239 | int compress_set_gapless_metadata(struct compress *compress, |
| 240 | struct compr_gapless_mdata *mdata); |
| 241 | |
Aniket Kumar Lata | 8751cec | 2019-01-18 16:45:01 -0800 | [diff] [blame] | 242 | #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 | |
| 252 | int compress_set_next_track_param(struct compress *compress, |
| 253 | union snd_codec_options *codec_options); |
| 254 | #endif |
| 255 | |
Eric Laurent | c902d7f | 2013-03-08 14:50:45 -0800 | [diff] [blame] | 256 | /* |
| 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 | */ |
| 265 | bool 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 | */ |
| 276 | void compress_set_max_poll_wait(struct compress *compress, int milliseconds); |
| 277 | |
Eric Laurent | 79c3707 | 2013-06-07 10:50:05 -0700 | [diff] [blame] | 278 | /* Enable or disable non-blocking mode for write and read */ |
| 279 | void compress_nonblock(struct compress *compress, int nonblock); |
| 280 | |
| 281 | /* Wait for ring buffer to ready for next read or write */ |
| 282 | int compress_wait(struct compress *compress, int timeout_ms); |
| 283 | |
Eric Laurent | c902d7f | 2013-03-08 14:50:45 -0800 | [diff] [blame] | 284 | int is_compress_running(struct compress *compress); |
| 285 | |
| 286 | int is_compress_ready(struct compress *compress); |
| 287 | |
| 288 | /* Returns a human readable reason for the last error */ |
| 289 | const 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 Laurent | 79c3707 | 2013-06-07 10:50:05 -0700 | [diff] [blame] | 309 | /* utility functions */ |
| 310 | unsigned int compress_get_alsa_rate(unsigned int rate); |
Haynes Mathew George | 25a4b4b | 2014-09-25 10:24:40 -0700 | [diff] [blame] | 311 | |
Ritu Sharma | bf91290 | 2021-08-18 18:41:14 +0530 | [diff] [blame] | 312 | /* |
| 313 | * compress_set_codec_params: set codec config intended for next track |
| 314 | * if DSP has support to switch CODEC config during gapless playback |
| 315 | * This API is expected to be called after compress_next_track is called |
| 316 | * return 0 on success, negative on error |
| 317 | * |
| 318 | * @compress: compress stream for which metadata has to set |
| 319 | * @codec: codec configuration for next track |
| 320 | */ |
| 321 | int compress_set_codec_params(struct compress *compress, struct snd_codec *codec); |
| 322 | |
Aniket Kumar Lata | 8751cec | 2019-01-18 16:45:01 -0800 | [diff] [blame] | 323 | #ifdef ENABLE_EXTENDED_COMPRESS_FORMAT |
| 324 | /* set metadata */ |
| 325 | int compress_set_metadata(struct compress *compress, |
| 326 | struct snd_compr_metadata *mdata); |
| 327 | |
| 328 | /* get metadata */ |
| 329 | int compress_get_metadata(struct compress *compress, |
| 330 | struct snd_compr_metadata *mdata); |
| 331 | #endif |
Haynes Mathew George | 25a4b4b | 2014-09-25 10:24:40 -0700 | [diff] [blame] | 332 | |
| 333 | #if defined(__cplusplus) |
| 334 | } |
| 335 | #endif |
| 336 | |
Eric Laurent | c902d7f | 2013-03-08 14:50:45 -0800 | [diff] [blame] | 337 | #endif |