blob: 3d8c5600227678b2c6486a7d8f327f409c108e7e [file] [log] [blame]
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -07001/* arch/arm/mach-msm/qdsp5/audmgr.h
2 *
3 * Copyright (C) 2008 Google, Inc.
Sidipotu Ashok3144aa22012-03-16 10:55:24 +05304 * Copyright (c) 2008-2009, 2012 Code Aurora Forum. All rights reserved.
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -07005 *
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 _AUDIO_RPC_H_
18#define _AUDIO_RPC_H_
19
20#include <mach/qdsp5/qdsp5audppcmdi.h>
21
22enum rpc_aud_def_sample_rate_type {
23 RPC_AUD_DEF_SAMPLE_RATE_NONE,
24 RPC_AUD_DEF_SAMPLE_RATE_8000,
25 RPC_AUD_DEF_SAMPLE_RATE_11025,
26 RPC_AUD_DEF_SAMPLE_RATE_12000,
27 RPC_AUD_DEF_SAMPLE_RATE_16000,
28 RPC_AUD_DEF_SAMPLE_RATE_22050,
29 RPC_AUD_DEF_SAMPLE_RATE_24000,
30 RPC_AUD_DEF_SAMPLE_RATE_32000,
31 RPC_AUD_DEF_SAMPLE_RATE_44100,
32 RPC_AUD_DEF_SAMPLE_RATE_48000,
33 RPC_AUD_DEF_SAMPLE_RATE_MAX,
34};
35
36enum rpc_aud_def_method_type {
37 RPC_AUD_DEF_METHOD_NONE,
38 RPC_AUD_DEF_METHOD_KEY_BEEP,
39 RPC_AUD_DEF_METHOD_PLAYBACK,
40 RPC_AUD_DEF_METHOD_VOICE,
41 RPC_AUD_DEF_METHOD_RECORD,
42 RPC_AUD_DEF_METHOD_HOST_PCM,
43 RPC_AUD_DEF_METHOD_MIDI_OUT,
44 RPC_AUD_DEF_METHOD_RECORD_SBC,
45 RPC_AUD_DEF_METHOD_DTMF_RINGER,
46 RPC_AUD_DEF_METHOD_MAX,
47};
48
49enum rpc_aud_def_codec_type {
50 RPC_AUD_DEF_CODEC_NONE,
51 RPC_AUD_DEF_CODEC_DTMF,
52 RPC_AUD_DEF_CODEC_MIDI,
53 RPC_AUD_DEF_CODEC_MP3,
54 RPC_AUD_DEF_CODEC_PCM,
55 RPC_AUD_DEF_CODEC_AAC,
56 RPC_AUD_DEF_CODEC_WMA,
57 RPC_AUD_DEF_CODEC_RA,
58 RPC_AUD_DEF_CODEC_ADPCM,
59 RPC_AUD_DEF_CODEC_GAUDIO,
60 RPC_AUD_DEF_CODEC_VOC_EVRC,
61 RPC_AUD_DEF_CODEC_VOC_13K,
62 RPC_AUD_DEF_CODEC_VOC_4GV_NB,
63 RPC_AUD_DEF_CODEC_VOC_AMR,
64 RPC_AUD_DEF_CODEC_VOC_EFR,
65 RPC_AUD_DEF_CODEC_VOC_FR,
66 RPC_AUD_DEF_CODEC_VOC_HR,
67 RPC_AUD_DEF_CODEC_VOC_CDMA,
68 RPC_AUD_DEF_CODEC_VOC_CDMA_WB,
69 RPC_AUD_DEF_CODEC_VOC_UMTS,
70 RPC_AUD_DEF_CODEC_VOC_UMTS_WB,
71 RPC_AUD_DEF_CODEC_SBC,
72 RPC_AUD_DEF_CODEC_VOC_PCM,
73 RPC_AUD_DEF_CODEC_AMR_WB,
74 RPC_AUD_DEF_CODEC_AMR_WB_PLUS,
75 RPC_AUD_DEF_CODEC_AAC_BSAC,
76 RPC_AUD_DEF_CODEC_MAX,
77 RPC_AUD_DEF_CODEC_AMR_NB,
78 RPC_AUD_DEF_CODEC_13K,
79 RPC_AUD_DEF_CODEC_EVRC,
Chaithanya Krishna Bacharaju8e838cc2012-08-16 11:32:46 +053080 RPC_AUD_DEF_CODEC_AC3,
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070081 RPC_AUD_DEF_CODEC_MAX_002,
82};
83
84enum rpc_snd_method_type {
85 RPC_SND_METHOD_VOICE = 0,
86 RPC_SND_METHOD_KEY_BEEP,
87 RPC_SND_METHOD_MESSAGE,
88 RPC_SND_METHOD_RING,
89 RPC_SND_METHOD_MIDI,
90 RPC_SND_METHOD_AUX,
91 RPC_SND_METHOD_MAX,
92};
93
94enum rpc_voc_codec_type {
95 RPC_VOC_CODEC_DEFAULT,
96 RPC_VOC_CODEC_ON_CHIP_0 = RPC_VOC_CODEC_DEFAULT,
97 RPC_VOC_CODEC_ON_CHIP_1,
98 RPC_VOC_CODEC_STEREO_HEADSET,
99 RPC_VOC_CODEC_ON_CHIP_AUX,
100 RPC_VOC_CODEC_BT_OFF_BOARD,
101 RPC_VOC_CODEC_BT_A2DP,
102 RPC_VOC_CODEC_OFF_BOARD,
103 RPC_VOC_CODEC_SDAC,
104 RPC_VOC_CODEC_RX_EXT_SDAC_TX_INTERNAL,
105 RPC_VOC_CODEC_IN_STEREO_SADC_OUT_MONO_HANDSET,
106 RPC_VOC_CODEC_IN_STEREO_SADC_OUT_STEREO_HEADSET,
107 RPC_VOC_CODEC_TX_INT_SADC_RX_EXT_AUXPCM,
108 RPC_VOC_CODEC_EXT_STEREO_SADC_OUT_MONO_HANDSET,
109 RPC_VOC_CODEC_EXT_STEREO_SADC_OUT_STEREO_HEADSET,
110 RPC_VOC_CODEC_TTY_ON_CHIP_1,
111 RPC_VOC_CODEC_TTY_OFF_BOARD,
112 RPC_VOC_CODEC_TTY_VCO,
113 RPC_VOC_CODEC_TTY_HCO,
114 RPC_VOC_CODEC_ON_CHIP_0_DUAL_MIC,
115 RPC_VOC_CODEC_MAX,
116 RPC_VOC_CODEC_NONE,
117};
118
119enum rpc_audmgr_status_type {
120 RPC_AUDMGR_STATUS_READY,
121 RPC_AUDMGR_STATUS_CODEC_CONFIG,
122 RPC_AUDMGR_STATUS_PENDING,
123 RPC_AUDMGR_STATUS_SUSPEND,
124 RPC_AUDMGR_STATUS_FAILURE,
125 RPC_AUDMGR_STATUS_VOLUME_CHANGE,
126 RPC_AUDMGR_STATUS_DISABLED,
127 RPC_AUDMGR_STATUS_ERROR,
128};
129
130struct rpc_audmgr_enable_client_args {
131 uint32_t set_to_one;
132 uint32_t tx_sample_rate;
133 uint32_t rx_sample_rate;
134 uint32_t def_method;
135 uint32_t codec_type;
136 uint32_t snd_method;
137
138 uint32_t cb_func;
139 uint32_t client_data;
140};
141
142#define AUDMGR_ENABLE_CLIENT 2
143#define AUDMGR_DISABLE_CLIENT 3
144#define AUDMGR_SUSPEND_EVENT_RSP 4
145#define AUDMGR_REGISTER_OPERATION_LISTENER 5
146#define AUDMGR_UNREGISTER_OPERATION_LISTENER 6
147#define AUDMGR_REGISTER_CODEC_LISTENER 7
148#define AUDMGR_GET_RX_SAMPLE_RATE 8
149#define AUDMGR_GET_TX_SAMPLE_RATE 9
150#define AUDMGR_SET_DEVICE_MODE 10
151
152#define AUDMGR_PROG_VERS "rs30000013:0x7feccbff"
153#define AUDMGR_PROG 0x30000013
154#define AUDMGR_VERS 0x7feccbff
155#define AUDMGR_VERS_COMP 0x00010001
156#define AUDMGR_VERS_COMP_VER2 0x00020001
157#define AUDMGR_VERS_COMP_VER3 0x00030001
158
159struct rpc_audmgr_cb_func_ptr {
160 uint32_t cb_id; /* cb_func */
161 uint32_t status; /* Audmgr status */
162 uint32_t set_to_one; /* Pointer status (1 = valid, 0 = invalid) */
163 uint32_t disc;
164 /* disc = AUDMGR_STATUS_READY => data=handle
165 disc = AUDMGR_STATUS_CODEC_CONFIG => data = volume
166 disc = AUDMGR_STATUS_DISABLED => data =status_disabled
167 disc = AUDMGR_STATUS_VOLUME_CHANGE => data = volume_change */
168 union {
169 uint32_t handle;
170 uint32_t volume;
171 uint32_t status_disabled;
172 uint32_t volume_change;
173 } u;
174 uint32_t client_data;
175};
176
177#define AUDMGR_CB_FUNC_PTR 1
178#define AUDMGR_OPR_LSTNR_CB_FUNC_PTR 2
179#define AUDMGR_CODEC_LSTR_FUNC_PTR 3
180
181#define AUDMGR_CB_PROG_VERS "rs31000013:0xf8e3e2d9"
182#define AUDMGR_CB_PROG 0x31000013
183#define AUDMGR_CB_VERS 0xf8e3e2d9
184
185struct audmgr {
186 wait_queue_head_t wait;
187 uint32_t handle;
188 int state;
189};
190
191struct audmgr_config {
192 uint32_t tx_rate;
193 uint32_t rx_rate;
194 uint32_t def_method;
195 uint32_t codec;
196 uint32_t snd_method;
197};
198
199int audmgr_open(struct audmgr *am);
200int audmgr_close(struct audmgr *am);
201int audmgr_enable(struct audmgr *am, struct audmgr_config *cfg);
202int audmgr_disable(struct audmgr *am);
203
204typedef void (*audpp_event_func)(void *private, unsigned id, uint16_t *msg);
205typedef void (*audrec_event_func)(void *private, unsigned id, uint16_t *msg);
206
207/* worst case delay of 1sec for response */
208#define MSM_AUD_DECODER_WAIT_MS 1000
209#define MSM_AUD_MODE_TUNNEL 0x00000100
210#define MSM_AUD_MODE_NONTUNNEL 0x00000200
211#define MSM_AUD_DECODER_MASK 0x0000FFFF
212#define MSM_AUD_OP_MASK 0xFFFF0000
213
214/*Playback mode*/
215#define NON_TUNNEL_MODE_PLAYBACK 1
216#define TUNNEL_MODE_PLAYBACK 0
217
218enum msm_aud_decoder_state {
219 MSM_AUD_DECODER_STATE_NONE = 0,
220 MSM_AUD_DECODER_STATE_FAILURE = 1,
221 MSM_AUD_DECODER_STATE_SUCCESS = 2,
222 MSM_AUD_DECODER_STATE_CLOSE = 3,
223};
224
225int audpp_adec_alloc(unsigned dec_attrb, const char **module_name,
226 unsigned *queueid);
227void audpp_adec_free(int decid);
228
229struct audpp_event_callback {
230 audpp_event_func fn;
231 void *private;
232};
233
234int audpp_register_event_callback(struct audpp_event_callback *eh);
235int audpp_unregister_event_callback(struct audpp_event_callback *eh);
236int is_audpp_enable(void);
237
238int audpp_enable(int id, audpp_event_func func, void *private);
239void audpp_disable(int id, void *private);
240
241int audpp_send_queue1(void *cmd, unsigned len);
242int audpp_send_queue2(void *cmd, unsigned len);
243int audpp_send_queue3(void *cmd, unsigned len);
244
245int audpp_set_volume_and_pan(unsigned id, unsigned volume, int pan);
246int audpp_pause(unsigned id, int pause);
247int audpp_flush(unsigned id);
248void audpp_avsync(int id, unsigned rate);
249unsigned audpp_avsync_sample_count(int id);
250unsigned audpp_avsync_byte_count(int id);
251int audpp_dsp_set_mbadrc(unsigned id, unsigned enable,
252 audpp_cmd_cfg_object_params_mbadrc *mbadrc);
253int audpp_dsp_set_eq(unsigned id, unsigned enable,
254 audpp_cmd_cfg_object_params_eqalizer *eq);
255int audpp_dsp_set_rx_iir(unsigned id, unsigned enable,
256 audpp_cmd_cfg_object_params_pcm *iir);
Sidipotu Ashok3144aa22012-03-16 10:55:24 +0530257
258int audpp_dsp_set_rx_srs_trumedia_g
259 (struct audpp_cmd_cfg_object_params_srstm_g *srstm);
260int audpp_dsp_set_rx_srs_trumedia_w
261 (struct audpp_cmd_cfg_object_params_srstm_w *srstm);
262int audpp_dsp_set_rx_srs_trumedia_c
263 (struct audpp_cmd_cfg_object_params_srstm_c *srstm);
264int audpp_dsp_set_rx_srs_trumedia_h
265 (struct audpp_cmd_cfg_object_params_srstm_h *srstm);
266int audpp_dsp_set_rx_srs_trumedia_p
267 (struct audpp_cmd_cfg_object_params_srstm_p *srstm);
268int audpp_dsp_set_rx_srs_trumedia_l
269 (struct audpp_cmd_cfg_object_params_srstm_l *srstm);
270
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700271int audpp_dsp_set_vol_pan(unsigned id,
272 audpp_cmd_cfg_object_params_volume *vol_pan);
273int audpp_dsp_set_qconcert_plus(unsigned id, unsigned enable,
274 audpp_cmd_cfg_object_params_qconcert *qconcert_plus);
275int audrectask_enable(unsigned enc_type, audrec_event_func func, void *private);
276void audrectask_disable(unsigned enc_type, void *private);
277
278int audrectask_send_cmdqueue(void *cmd, unsigned len);
279int audrectask_send_bitstreamqueue(void *cmd, unsigned len);
280
281#endif