1 /* include/linux/msm_audio.h 2 * 3 * Copyright (C) 2008 Google, Inc. 4 * Copyright (c) 2012, 2014, 2017 The Linux Foundation. All rights reserved. 5 * 6 * This software is licensed under the terms of the GNU General Public 7 * License version 2, as published by the Free Software Foundation, and 8 * may be copied, distributed, and modified under those terms. 9 * 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. 14 * 15 */ 16 17 #ifndef _LINUX_MSM_AUDIO_H 18 #define _LINUX_MSM_AUDIO_H 19 20 #include <linux/types.h> 21 #include <linux/ioctl.h> 22 23 /* PCM Audio */ 24 25 #define AUDIO_IOCTL_MAGIC 'a' 26 27 #define AUDIO_START _IOW(AUDIO_IOCTL_MAGIC, 0, unsigned int) 28 #define AUDIO_STOP _IOW(AUDIO_IOCTL_MAGIC, 1, unsigned int) 29 #define AUDIO_FLUSH _IOW(AUDIO_IOCTL_MAGIC, 2, unsigned int) 30 #define AUDIO_GET_CONFIG _IOR(AUDIO_IOCTL_MAGIC, 3, \ 31 struct msm_audio_config) 32 #define AUDIO_SET_CONFIG _IOW(AUDIO_IOCTL_MAGIC, 4, \ 33 struct msm_audio_config) 34 #define AUDIO_GET_STATS _IOR(AUDIO_IOCTL_MAGIC, 5, \ 35 struct msm_audio_stats) 36 #define AUDIO_ENABLE_AUDPP _IOW(AUDIO_IOCTL_MAGIC, 6, unsigned int) 37 #define AUDIO_SET_ADRC _IOW(AUDIO_IOCTL_MAGIC, 7, unsigned int) 38 #define AUDIO_SET_EQ _IOW(AUDIO_IOCTL_MAGIC, 8, unsigned int) 39 #define AUDIO_SET_RX_IIR _IOW(AUDIO_IOCTL_MAGIC, 9, unsigned int) 40 #define AUDIO_SET_VOLUME _IOW(AUDIO_IOCTL_MAGIC, 10, unsigned int) 41 #define AUDIO_PAUSE _IOW(AUDIO_IOCTL_MAGIC, 11, unsigned int) 42 #define AUDIO_PLAY_DTMF _IOW(AUDIO_IOCTL_MAGIC, 12, unsigned int) 43 #define AUDIO_GET_EVENT _IOR(AUDIO_IOCTL_MAGIC, 13, \ 44 struct msm_audio_event) 45 #define AUDIO_ABORT_GET_EVENT _IOW(AUDIO_IOCTL_MAGIC, 14, unsigned int) 46 #define AUDIO_REGISTER_PMEM _IOW(AUDIO_IOCTL_MAGIC, 15, unsigned int) 47 #define AUDIO_DEREGISTER_PMEM _IOW(AUDIO_IOCTL_MAGIC, 16, unsigned int) 48 #define AUDIO_ASYNC_WRITE _IOW(AUDIO_IOCTL_MAGIC, 17, \ 49 struct msm_audio_aio_buf) 50 #define AUDIO_ASYNC_READ _IOW(AUDIO_IOCTL_MAGIC, 18, \ 51 struct msm_audio_aio_buf) 52 #define AUDIO_SET_INCALL _IOW(AUDIO_IOCTL_MAGIC, 19, struct msm_voicerec_mode) 53 #define AUDIO_GET_NUM_SND_DEVICE _IOR(AUDIO_IOCTL_MAGIC, 20, unsigned int) 54 #define AUDIO_GET_SND_DEVICES _IOWR(AUDIO_IOCTL_MAGIC, 21, \ 55 struct msm_snd_device_list) 56 #define AUDIO_ENABLE_SND_DEVICE _IOW(AUDIO_IOCTL_MAGIC, 22, unsigned int) 57 #define AUDIO_DISABLE_SND_DEVICE _IOW(AUDIO_IOCTL_MAGIC, 23, unsigned int) 58 #define AUDIO_ROUTE_STREAM _IOW(AUDIO_IOCTL_MAGIC, 24, \ 59 struct msm_audio_route_config) 60 #define AUDIO_GET_PCM_CONFIG _IOR(AUDIO_IOCTL_MAGIC, 30, unsigned int) 61 #define AUDIO_SET_PCM_CONFIG _IOW(AUDIO_IOCTL_MAGIC, 31, unsigned int) 62 #define AUDIO_SWITCH_DEVICE _IOW(AUDIO_IOCTL_MAGIC, 32, unsigned int) 63 #define AUDIO_SET_MUTE _IOW(AUDIO_IOCTL_MAGIC, 33, unsigned int) 64 #define AUDIO_UPDATE_ACDB _IOW(AUDIO_IOCTL_MAGIC, 34, unsigned int) 65 #define AUDIO_START_VOICE _IOW(AUDIO_IOCTL_MAGIC, 35, unsigned int) 66 #define AUDIO_STOP_VOICE _IOW(AUDIO_IOCTL_MAGIC, 36, unsigned int) 67 #define AUDIO_REINIT_ACDB _IOW(AUDIO_IOCTL_MAGIC, 39, unsigned int) 68 #define AUDIO_OUTPORT_FLUSH _IOW(AUDIO_IOCTL_MAGIC, 40, unsigned short) 69 #define AUDIO_SET_ERR_THRESHOLD_VALUE _IOW(AUDIO_IOCTL_MAGIC, 41, \ 70 unsigned short) 71 #define AUDIO_GET_BITSTREAM_ERROR_INFO _IOR(AUDIO_IOCTL_MAGIC, 42, \ 72 struct msm_audio_bitstream_error_info) 73 74 #define AUDIO_SET_SRS_TRUMEDIA_PARAM _IOW(AUDIO_IOCTL_MAGIC, 43, unsigned int) 75 76 /* Qualcomm technologies inc extensions */ 77 #define AUDIO_SET_STREAM_CONFIG _IOW(AUDIO_IOCTL_MAGIC, 80, \ 78 struct msm_audio_stream_config) 79 #define AUDIO_GET_STREAM_CONFIG _IOR(AUDIO_IOCTL_MAGIC, 81, \ 80 struct msm_audio_stream_config) 81 #define AUDIO_GET_SESSION_ID _IOR(AUDIO_IOCTL_MAGIC, 82, unsigned short) 82 #define AUDIO_GET_STREAM_INFO _IOR(AUDIO_IOCTL_MAGIC, 83, \ 83 struct msm_audio_bitstream_info) 84 #define AUDIO_SET_PAN _IOW(AUDIO_IOCTL_MAGIC, 84, unsigned int) 85 #define AUDIO_SET_QCONCERT_PLUS _IOW(AUDIO_IOCTL_MAGIC, 85, unsigned int) 86 #define AUDIO_SET_MBADRC _IOW(AUDIO_IOCTL_MAGIC, 86, unsigned int) 87 #define AUDIO_SET_VOLUME_PATH _IOW(AUDIO_IOCTL_MAGIC, 87, \ 88 struct msm_vol_info) 89 #define AUDIO_SET_MAX_VOL_ALL _IOW(AUDIO_IOCTL_MAGIC, 88, unsigned int) 90 #define AUDIO_ENABLE_AUDPRE _IOW(AUDIO_IOCTL_MAGIC, 89, unsigned int) 91 #define AUDIO_SET_AGC _IOW(AUDIO_IOCTL_MAGIC, 90, unsigned int) 92 #define AUDIO_SET_NS _IOW(AUDIO_IOCTL_MAGIC, 91, unsigned int) 93 #define AUDIO_SET_TX_IIR _IOW(AUDIO_IOCTL_MAGIC, 92, unsigned int) 94 #define AUDIO_GET_BUF_CFG _IOW(AUDIO_IOCTL_MAGIC, 93, \ 95 struct msm_audio_buf_cfg) 96 #define AUDIO_SET_BUF_CFG _IOW(AUDIO_IOCTL_MAGIC, 94, \ 97 struct msm_audio_buf_cfg) 98 #define AUDIO_SET_ACDB_BLK _IOW(AUDIO_IOCTL_MAGIC, 95, \ 99 struct msm_acdb_cmd_device) 100 #define AUDIO_GET_ACDB_BLK _IOW(AUDIO_IOCTL_MAGIC, 96, \ 101 struct msm_acdb_cmd_device) 102 103 #define AUDIO_REGISTER_ION _IOW(AUDIO_IOCTL_MAGIC, 97, \ 104 struct msm_audio_ion_info) 105 #define AUDIO_DEREGISTER_ION _IOW(AUDIO_IOCTL_MAGIC, 98, \ 106 struct msm_audio_ion_info) 107 #define AUDIO_SET_EFFECTS_CONFIG _IOW(AUDIO_IOCTL_MAGIC, 99, \ 108 struct msm_hwacc_effects_config) 109 #define AUDIO_EFFECTS_SET_BUF_LEN _IOW(AUDIO_IOCTL_MAGIC, 100, \ 110 struct msm_hwacc_buf_cfg) 111 #define AUDIO_EFFECTS_GET_BUF_AVAIL _IOW(AUDIO_IOCTL_MAGIC, 101, \ 112 struct msm_hwacc_buf_avail) 113 #define AUDIO_EFFECTS_WRITE _IOW(AUDIO_IOCTL_MAGIC, 102, void *) 114 #define AUDIO_EFFECTS_READ _IOWR(AUDIO_IOCTL_MAGIC, 103, void *) 115 #define AUDIO_EFFECTS_SET_PP_PARAMS _IOW(AUDIO_IOCTL_MAGIC, 104, void *) 116 117 #define AUDIO_PM_AWAKE _IOW(AUDIO_IOCTL_MAGIC, 105, unsigned int) 118 #define AUDIO_PM_RELAX _IOW(AUDIO_IOCTL_MAGIC, 106, unsigned int) 119 120 #define AUDIO_MAX_COMMON_IOCTL_NUM 107 121 122 123 #define HANDSET_MIC 0x01 124 #define HANDSET_SPKR 0x02 125 #define HEADSET_MIC 0x03 126 #define HEADSET_SPKR_MONO 0x04 127 #define HEADSET_SPKR_STEREO 0x05 128 #define SPKR_PHONE_MIC 0x06 129 #define SPKR_PHONE_MONO 0x07 130 #define SPKR_PHONE_STEREO 0x08 131 #define BT_SCO_MIC 0x09 132 #define BT_SCO_SPKR 0x0A 133 #define BT_A2DP_SPKR 0x0B 134 #define TTY_HEADSET_MIC 0x0C 135 #define TTY_HEADSET_SPKR 0x0D 136 137 /* Default devices are not supported in a */ 138 /* device switching context. Only supported */ 139 /* for stream devices. */ 140 /* DO NOT USE */ 141 #define DEFAULT_TX 0x0E 142 #define DEFAULT_RX 0x0F 143 144 #define BT_A2DP_TX 0x10 145 146 #define HEADSET_MONO_PLUS_SPKR_MONO_RX 0x11 147 #define HEADSET_MONO_PLUS_SPKR_STEREO_RX 0x12 148 #define HEADSET_STEREO_PLUS_SPKR_MONO_RX 0x13 149 #define HEADSET_STEREO_PLUS_SPKR_STEREO_RX 0x14 150 151 #define I2S_RX 0x20 152 #define I2S_TX 0x21 153 154 #define ADRC_ENABLE 0x0001 155 #define EQUALIZER_ENABLE 0x0002 156 #define IIR_ENABLE 0x0004 157 #define QCONCERT_PLUS_ENABLE 0x0008 158 #define MBADRC_ENABLE 0x0010 159 #define SRS_ENABLE 0x0020 160 #define SRS_DISABLE 0x0040 161 162 #define AGC_ENABLE 0x0001 163 #define NS_ENABLE 0x0002 164 #define TX_IIR_ENABLE 0x0004 165 #define FLUENCE_ENABLE 0x0008 166 167 #define VOC_REC_UPLINK 0x00 168 #define VOC_REC_DOWNLINK 0x01 169 #define VOC_REC_BOTH 0x02 170 171 struct msm_audio_config { 172 uint32_t buffer_size; 173 uint32_t buffer_count; 174 uint32_t channel_count; 175 uint32_t sample_rate; 176 uint32_t type; 177 uint32_t meta_field; 178 uint32_t bits; 179 uint32_t unused[3]; 180 }; 181 182 struct msm_audio_stream_config { 183 uint32_t buffer_size; 184 uint32_t buffer_count; 185 }; 186 187 struct msm_audio_buf_cfg { 188 uint32_t meta_info_enable; 189 uint32_t frames_per_buf; 190 }; 191 192 struct msm_audio_stats { 193 uint32_t byte_count; 194 uint32_t sample_count; 195 uint32_t unused[2]; 196 }; 197 198 struct msm_audio_ion_info { 199 int fd; 200 void *vaddr; 201 }; 202 203 struct msm_audio_pmem_info { 204 int fd; 205 void *vaddr; 206 }; 207 208 struct msm_audio_aio_buf { 209 void *buf_addr; 210 uint32_t buf_len; 211 uint32_t data_len; 212 void *private_data; 213 unsigned short mfield_sz; /*only useful for data has meta field */ 214 }; 215 216 /* Audio routing */ 217 218 #define SND_IOCTL_MAGIC 's' 219 220 #define SND_MUTE_UNMUTED 0 221 #define SND_MUTE_MUTED 1 222 223 struct msm_mute_info { 224 uint32_t mute; 225 uint32_t path; 226 }; 227 228 struct msm_vol_info { 229 uint32_t vol; 230 uint32_t path; 231 }; 232 233 struct msm_voicerec_mode { 234 uint32_t rec_mode; 235 }; 236 237 struct msm_snd_device_config { 238 uint32_t device; 239 uint32_t ear_mute; 240 uint32_t mic_mute; 241 }; 242 243 #define SND_SET_DEVICE _IOW(SND_IOCTL_MAGIC, 2, struct msm_device_config *) 244 245 enum cad_device_path_type { 246 CAD_DEVICE_PATH_RX, /*For Decoding session*/ 247 CAD_DEVICE_PATH_TX, /* For Encoding session*/ 248 CAD_DEVICE_PATH_RX_TX, /* For Voice call */ 249 CAD_DEVICE_PATH_LB, /* For loopback (FM Analog)*/ 250 CAD_DEVICE_PATH_MAX 251 }; 252 253 struct cad_devices_type { 254 uint32_t rx_device; 255 uint32_t tx_device; 256 enum cad_device_path_type pathtype; 257 }; 258 259 struct msm_cad_device_config { 260 struct cad_devices_type device; 261 uint32_t ear_mute; 262 uint32_t mic_mute; 263 }; 264 265 #define CAD_SET_DEVICE _IOW(SND_IOCTL_MAGIC, 2, struct msm_cad_device_config *) 266 267 #define SND_METHOD_VOICE 0 268 #define SND_METHOD_MIDI 4 269 270 struct msm_snd_volume_config { 271 uint32_t device; 272 uint32_t method; 273 uint32_t volume; 274 }; 275 276 #define SND_SET_VOLUME _IOW(SND_IOCTL_MAGIC, 3, struct msm_snd_volume_config *) 277 278 struct msm_cad_volume_config { 279 struct cad_devices_type device; 280 uint32_t method; 281 uint32_t volume; 282 }; 283 284 #define CAD_SET_VOLUME _IOW(SND_IOCTL_MAGIC, 3, struct msm_cad_volume_config *) 285 286 /* Returns the number of SND endpoints supported. */ 287 288 #define SND_GET_NUM_ENDPOINTS _IOR(SND_IOCTL_MAGIC, 4, unsigned int *) 289 290 struct msm_snd_endpoint { 291 int id; /* input and output */ 292 char name[64]; /* output only */ 293 }; 294 295 /* Takes an index between 0 and one less than the number returned by 296 * SND_GET_NUM_ENDPOINTS, and returns the SND index and name of a 297 * SND endpoint. On input, the .id field contains the number of the 298 * endpoint, and on exit it contains the SND index, while .name contains 299 * the description of the endpoint. 300 */ 301 302 #define SND_GET_ENDPOINT _IOWR(SND_IOCTL_MAGIC, 5, struct msm_snd_endpoint *) 303 304 305 #define SND_AVC_CTL _IOW(SND_IOCTL_MAGIC, 6, unsigned int *) 306 #define SND_AGC_CTL _IOW(SND_IOCTL_MAGIC, 7, unsigned int *) 307 308 /*return the number of CAD endpoints supported. */ 309 310 #define CAD_GET_NUM_ENDPOINTS _IOR(SND_IOCTL_MAGIC, 4, unsigned int *) 311 312 struct msm_cad_endpoint { 313 int id; /* input and output */ 314 char name[64]; /* output only */ 315 }; 316 317 /* Takes an index between 0 and one less than the number returned by 318 * SND_GET_NUM_ENDPOINTS, and returns the CAD index and name of a 319 * CAD endpoint. On input, the .id field contains the number of the 320 * endpoint, and on exit it contains the SND index, while .name contains 321 * the description of the endpoint. 322 */ 323 324 #define CAD_GET_ENDPOINT _IOWR(SND_IOCTL_MAGIC, 5, struct msm_cad_endpoint *) 325 326 struct msm_audio_pcm_config { 327 uint32_t pcm_feedback; /* 0 - disable > 0 - enable */ 328 uint32_t buffer_count; /* Number of buffers to allocate */ 329 uint32_t buffer_size; /* Size of buffer for capturing of 330 * PCM samples 331 */ 332 }; 333 334 #define AUDIO_EVENT_SUSPEND 0 335 #define AUDIO_EVENT_RESUME 1 336 #define AUDIO_EVENT_WRITE_DONE 2 337 #define AUDIO_EVENT_READ_DONE 3 338 #define AUDIO_EVENT_STREAM_INFO 4 339 #define AUDIO_EVENT_BITSTREAM_ERROR_INFO 5 340 341 #define AUDIO_CODEC_TYPE_MP3 0 342 #define AUDIO_CODEC_TYPE_AAC 1 343 344 struct msm_audio_bitstream_info { 345 uint32_t codec_type; 346 uint32_t chan_info; 347 uint32_t sample_rate; 348 uint32_t bit_stream_info; 349 uint32_t bit_rate; 350 uint32_t unused[3]; 351 }; 352 353 struct msm_audio_bitstream_error_info { 354 uint32_t dec_id; 355 uint32_t err_msg_indicator; 356 uint32_t err_type; 357 }; 358 359 union msm_audio_event_payload { 360 struct msm_audio_aio_buf aio_buf; 361 struct msm_audio_bitstream_info stream_info; 362 struct msm_audio_bitstream_error_info error_info; 363 int reserved; 364 }; 365 366 struct msm_audio_event { 367 int event_type; 368 int timeout_ms; 369 union msm_audio_event_payload event_payload; 370 }; 371 372 #define MSM_SNDDEV_CAP_RX 0x1 373 #define MSM_SNDDEV_CAP_TX 0x2 374 #define MSM_SNDDEV_CAP_VOICE 0x4 375 376 struct msm_snd_device_info { 377 uint32_t dev_id; 378 uint32_t dev_cap; /* bitmask describe capability of device */ 379 char dev_name[64]; 380 }; 381 382 struct msm_snd_device_list { 383 uint32_t num_dev; /* Indicate number of device info to be retrieved */ 384 struct msm_snd_device_info *list; 385 }; 386 387 struct msm_dtmf_config { 388 uint16_t path; 389 uint16_t dtmf_hi; 390 uint16_t dtmf_low; 391 uint16_t duration; 392 uint16_t tx_gain; 393 uint16_t rx_gain; 394 uint16_t mixing; 395 }; 396 397 #define AUDIO_ROUTE_STREAM_VOICE_RX 0 398 #define AUDIO_ROUTE_STREAM_VOICE_TX 1 399 #define AUDIO_ROUTE_STREAM_PLAYBACK 2 400 #define AUDIO_ROUTE_STREAM_REC 3 401 402 struct msm_audio_route_config { 403 uint32_t stream_type; 404 uint32_t stream_id; 405 uint32_t dev_id; 406 }; 407 408 #define AUDIO_MAX_EQ_BANDS 12 409 410 struct msm_audio_eq_band { 411 uint16_t band_idx; /* The band index, 0 .. 11 */ 412 uint32_t filter_type; /* Filter band type */ 413 uint32_t center_freq_hz; /* Filter band center frequency */ 414 uint32_t filter_gain; /* Filter band initial gain (dB) */ 415 /* Range is +12 dB to -12 dB with 1dB increments. */ 416 uint32_t q_factor; 417 } __attribute__ ((packed)); 418 419 struct msm_audio_eq_stream_config { 420 uint32_t enable; /* Number of consequtive bands specified */ 421 uint32_t num_bands; 422 struct msm_audio_eq_band eq_bands[AUDIO_MAX_EQ_BANDS]; 423 } __attribute__ ((packed)); 424 425 struct msm_acdb_cmd_device { 426 uint32_t command_id; 427 uint32_t device_id; 428 uint32_t network_id; 429 uint32_t sample_rate_id; /* Actual sample rate value */ 430 uint32_t interface_id; /* See interface id's above */ 431 uint32_t algorithm_block_id; /* See enumerations above */ 432 uint32_t total_bytes; /* Length in bytes used by buffer */ 433 uint32_t *phys_buf; /* Physical Address of data */ 434 }; 435 436 struct msm_hwacc_data_config { 437 __u32 buf_size; 438 __u32 num_buf; 439 __u32 num_channels; 440 __u8 channel_map[8]; 441 __u32 sample_rate; 442 __u32 bits_per_sample; 443 }; 444 445 struct msm_hwacc_buf_cfg { 446 __u32 input_len; 447 __u32 output_len; 448 }; 449 450 struct msm_hwacc_buf_avail { 451 __u32 input_num_avail; 452 __u32 output_num_avail; 453 }; 454 455 struct msm_hwacc_effects_config { 456 struct msm_hwacc_data_config input; 457 struct msm_hwacc_data_config output; 458 struct msm_hwacc_buf_cfg buf_cfg; 459 __u32 meta_mode_enabled; 460 __u32 overwrite_topology; 461 __s32 topology; 462 }; 463 464 #define ADSP_STREAM_PP_EVENT 0 465 #define ADSP_STREAM_ENCDEC_EVENT 1 466 #define ADSP_STREAM_IEC_61937_FMT_UPDATE_EVENT 2 467 #define ADSP_STREAM_EVENT_MAX 3 468 469 struct msm_adsp_event_data { 470 __u32 event_type; 471 __u32 payload_len; 472 __u8 payload[0]; 473 }; 474 475 #if defined(CONFIG_CIRRUS_SPKR_PROTECTION) 476 struct msm_pcm_drv_data { 477 const char *config_name; 478 }; 479 #endif 480 #endif 481