blob: 25f52d699b5f816ec3907468be21f8f050070c81 [file] [log] [blame]
Eric Laurentb23d5282013-05-14 15:27:20 -07001/*
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -07002 * Copyright (c) 2013, The Linux Foundation. All rights reserved.
3 * Not a Contribution.
4 *
Eric Laurentb23d5282013-05-14 15:27:20 -07005 * Copyright (C) 2013 The Android Open Source Project
6 *
7 * Licensed under the Apache License, Version 2.0 (the "License");
8 * you may not use this file except in compliance with the License.
9 * You may obtain a copy of the License at
10 *
11 * http://www.apache.org/licenses/LICENSE-2.0
12 *
13 * Unless required by applicable law or agreed to in writing, software
14 * distributed under the License is distributed on an "AS IS" BASIS,
15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 * See the License for the specific language governing permissions and
17 * limitations under the License.
18 */
19
20#define LOG_TAG "msm8974_platform"
21/*#define LOG_NDEBUG 0*/
22#define LOG_NDDEBUG 0
23
24#include <stdlib.h>
25#include <dlfcn.h>
26#include <cutils/log.h>
27#include <cutils/properties.h>
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -070028#include <cutils/str_parms.h>
Eric Laurentb23d5282013-05-14 15:27:20 -070029#include <audio_hw.h>
30#include <platform_api.h>
31#include "platform.h"
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -070032#include "audio_extn.h"
Narsinga Rao Chella05573b72013-11-15 15:21:40 -080033#include "voice_extn.h"
Eric Laurentb23d5282013-05-14 15:27:20 -070034
Haynes Mathew George47cd4cb2013-07-19 11:58:50 -070035#define MIXER_XML_PATH "/system/etc/mixer_paths.xml"
Damir Didjustof1d46c72013-11-06 17:59:04 -080036#define MIXER_XML_PATH_AUXPCM "/system/etc/mixer_paths_auxpcm.xml"
Eric Laurentb23d5282013-05-14 15:27:20 -070037#define LIB_ACDB_LOADER "libacdbloader.so"
Haynes Mathew George47cd4cb2013-07-19 11:58:50 -070038#define AUDIO_DATA_BLOCK_MIXER_CTL "HDMI EDID"
Eric Laurentb23d5282013-05-14 15:27:20 -070039
Eric Laurentb23d5282013-05-14 15:27:20 -070040/*
Eric Laurentb23d5282013-05-14 15:27:20 -070041 * This file will have a maximum of 38 bytes:
42 *
43 * 4 bytes: number of audio blocks
44 * 4 bytes: total length of Short Audio Descriptor (SAD) blocks
45 * Maximum 10 * 3 bytes: SAD blocks
46 */
47#define MAX_SAD_BLOCKS 10
48#define SAD_BLOCK_SIZE 3
49
50/* EDID format ID for LPCM audio */
51#define EDID_FORMAT_LPCM 1
52
sangwoo1b9f4b32013-06-21 18:22:55 -070053/* Retry for delay in FW loading*/
54#define RETRY_NUMBER 10
55#define RETRY_US 500000
56
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -070057#define SAMPLE_RATE_8KHZ 8000
58#define SAMPLE_RATE_16KHZ 16000
59
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -070060#define AUDIO_PARAMETER_KEY_FLUENCE_TYPE "fluence"
61#define AUDIO_PARAMETER_KEY_BTSCO "bt_samplerate"
62#define AUDIO_PARAMETER_KEY_SLOWTALK "st_enable"
sangwoo53b2cf02013-07-25 19:18:44 -070063
Eric Laurentb23d5282013-05-14 15:27:20 -070064struct audio_block_header
65{
66 int reserved;
67 int length;
68};
69
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -080070/* Audio calibration related functions */
Eric Laurentb23d5282013-05-14 15:27:20 -070071typedef void (*acdb_deallocate_t)();
72typedef int (*acdb_init_t)();
73typedef void (*acdb_send_audio_cal_t)(int, int);
74typedef void (*acdb_send_voice_cal_t)(int, int);
75
Eric Laurentb23d5282013-05-14 15:27:20 -070076struct platform_data {
77 struct audio_device *adev;
78 bool fluence_in_spkr_mode;
79 bool fluence_in_voice_call;
80 bool fluence_in_voice_rec;
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -080081 bool fluence_in_audio_rec;
Mingming Yin8e5a4f62013-10-07 15:23:41 -070082 int fluence_type;
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -070083 int btsco_sample_rate;
84 bool slowtalk;
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -070085 /* Audio calibration related functions */
Eric Laurentb23d5282013-05-14 15:27:20 -070086 void *acdb_handle;
87 acdb_init_t acdb_init;
88 acdb_deallocate_t acdb_deallocate;
89 acdb_send_audio_cal_t acdb_send_audio_cal;
90 acdb_send_voice_cal_t acdb_send_voice_cal;
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -070091
92 void *hw_info;
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -080093 struct csd_data *csd;
Eric Laurentb23d5282013-05-14 15:27:20 -070094};
95
96static const int pcm_device_table[AUDIO_USECASE_MAX][2] = {
Mingming Yin8e5a4f62013-10-07 15:23:41 -070097 [USECASE_AUDIO_PLAYBACK_DEEP_BUFFER] = {DEEP_BUFFER_PCM_DEVICE,
98 DEEP_BUFFER_PCM_DEVICE},
99 [USECASE_AUDIO_PLAYBACK_LOW_LATENCY] = {LOWLATENCY_PCM_DEVICE,
Preetam Singh Ranawatde84f1a2013-11-01 14:58:16 -0700100 LOWLATENCY_PCM_DEVICE},
101 [USECASE_AUDIO_PLAYBACK_MULTI_CH] = {MULTIMEDIA2_PCM_DEVICE,
102 MULTIMEDIA2_PCM_DEVICE},
Krishnankutty Kolathappillya43f96e2013-11-01 12:17:53 -0700103 [USECASE_AUDIO_PLAYBACK_OFFLOAD] =
104 {PLAYBACK_OFFLOAD_DEVICE, PLAYBACK_OFFLOAD_DEVICE},
Shiv Maliyappanahallida107642013-10-17 11:16:13 -0700105 [USECASE_AUDIO_RECORD] = {AUDIO_RECORD_PCM_DEVICE, AUDIO_RECORD_PCM_DEVICE},
Mingming Yine62d7842013-10-25 16:26:03 -0700106 [USECASE_AUDIO_RECORD_COMPRESS] = {COMPRESS_CAPTURE_DEVICE, COMPRESS_CAPTURE_DEVICE},
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700107 [USECASE_AUDIO_RECORD_LOW_LATENCY] = {LOWLATENCY_PCM_DEVICE,
108 LOWLATENCY_PCM_DEVICE},
Preetam Singh Ranawatde84f1a2013-11-01 14:58:16 -0700109 [USECASE_AUDIO_RECORD_FM_VIRTUAL] = {MULTIMEDIA2_PCM_DEVICE,
110 MULTIMEDIA2_PCM_DEVICE},
Apoorv Raghuvanshi6e262842013-10-06 14:39:35 -0700111 [USECASE_AUDIO_PLAYBACK_FM] = {FM_PLAYBACK_PCM_DEVICE, FM_CAPTURE_PCM_DEVICE},
Vimal Puthanveed5b4d3f12013-11-05 15:57:39 -0800112 [USECASE_AUDIO_HFP_SCO] = {HFP_PCM_RX, HFP_SCO_RX},
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700113 [USECASE_VOICE_CALL] = {VOICE_CALL_PCM_DEVICE, VOICE_CALL_PCM_DEVICE},
114 [USECASE_VOICE2_CALL] = {VOICE2_CALL_PCM_DEVICE, VOICE2_CALL_PCM_DEVICE},
115 [USECASE_VOLTE_CALL] = {VOLTE_CALL_PCM_DEVICE, VOLTE_CALL_PCM_DEVICE},
116 [USECASE_QCHAT_CALL] = {QCHAT_CALL_PCM_DEVICE, QCHAT_CALL_PCM_DEVICE},
Narsinga Rao Chella05573b72013-11-15 15:21:40 -0800117 [USECASE_COMPRESS_VOIP_CALL] = {COMPRESS_VOIP_CALL_PCM_DEVICE, COMPRESS_VOIP_CALL_PCM_DEVICE},
Shiv Maliyappanahallida107642013-10-17 11:16:13 -0700118 [USECASE_INCALL_REC_UPLINK] = {AUDIO_RECORD_PCM_DEVICE,
119 AUDIO_RECORD_PCM_DEVICE},
120 [USECASE_INCALL_REC_DOWNLINK] = {AUDIO_RECORD_PCM_DEVICE,
121 AUDIO_RECORD_PCM_DEVICE},
122 [USECASE_INCALL_REC_UPLINK_AND_DOWNLINK] = {AUDIO_RECORD_PCM_DEVICE,
123 AUDIO_RECORD_PCM_DEVICE},
Shiv Maliyappanahallif3b9a422013-10-22 16:38:08 -0700124 [USECASE_INCALL_MUSIC_UPLINK] = {INCALL_MUSIC_UPLINK_PCM_DEVICE,
125 INCALL_MUSIC_UPLINK_PCM_DEVICE},
126 [USECASE_INCALL_MUSIC_UPLINK2] = {INCALL_MUSIC_UPLINK2_PCM_DEVICE,
127 INCALL_MUSIC_UPLINK2_PCM_DEVICE},
Gopikrishnaiah Anandanf538cef2013-10-28 14:06:03 -0700128 [USECASE_AUDIO_SPKR_CALIB_RX] = {SPKR_PROT_CALIB_RX_PCM_DEVICE, -1},
129 [USECASE_AUDIO_SPKR_CALIB_TX] = {-1, SPKR_PROT_CALIB_TX_PCM_DEVICE},
Eric Laurentb23d5282013-05-14 15:27:20 -0700130};
131
132/* Array to store sound devices */
133static const char * const device_table[SND_DEVICE_MAX] = {
134 [SND_DEVICE_NONE] = "none",
135 /* Playback sound devices */
136 [SND_DEVICE_OUT_HANDSET] = "handset",
137 [SND_DEVICE_OUT_SPEAKER] = "speaker",
138 [SND_DEVICE_OUT_SPEAKER_REVERSE] = "speaker-reverse",
139 [SND_DEVICE_OUT_HEADPHONES] = "headphones",
140 [SND_DEVICE_OUT_SPEAKER_AND_HEADPHONES] = "speaker-and-headphones",
141 [SND_DEVICE_OUT_VOICE_HANDSET] = "voice-handset",
142 [SND_DEVICE_OUT_VOICE_SPEAKER] = "voice-speaker",
143 [SND_DEVICE_OUT_VOICE_HEADPHONES] = "voice-headphones",
144 [SND_DEVICE_OUT_HDMI] = "hdmi",
145 [SND_DEVICE_OUT_SPEAKER_AND_HDMI] = "speaker-and-hdmi",
146 [SND_DEVICE_OUT_BT_SCO] = "bt-sco-headset",
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700147 [SND_DEVICE_OUT_BT_SCO_WB] = "bt-sco-headset-wb",
Eric Laurentb23d5282013-05-14 15:27:20 -0700148 [SND_DEVICE_OUT_VOICE_TTY_FULL_HEADPHONES] = "voice-tty-full-headphones",
149 [SND_DEVICE_OUT_VOICE_TTY_VCO_HEADPHONES] = "voice-tty-vco-headphones",
150 [SND_DEVICE_OUT_VOICE_TTY_HCO_HANDSET] = "voice-tty-hco-handset",
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -0700151 [SND_DEVICE_OUT_AFE_PROXY] = "afe-proxy",
152 [SND_DEVICE_OUT_USB_HEADSET] = "usb-headphones",
153 [SND_DEVICE_OUT_SPEAKER_AND_USB_HEADSET] = "speaker-and-usb-headphones",
Apoorv Raghuvanshi6e262842013-10-06 14:39:35 -0700154 [SND_DEVICE_OUT_TRANSMISSION_FM] = "transmission-fm",
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -0700155 [SND_DEVICE_OUT_ANC_HEADSET] = "anc-headphones",
156 [SND_DEVICE_OUT_ANC_FB_HEADSET] = "anc-fb-headphones",
157 [SND_DEVICE_OUT_VOICE_ANC_HEADSET] = "voice-anc-headphones",
158 [SND_DEVICE_OUT_VOICE_ANC_FB_HEADSET] = "voice-anc-fb-headphones",
159 [SND_DEVICE_OUT_SPEAKER_AND_ANC_HEADSET] = "speaker-and-anc-headphones",
160 [SND_DEVICE_OUT_ANC_HANDSET] = "anc-handset",
Gopikrishnaiah Anandanf538cef2013-10-28 14:06:03 -0700161 [SND_DEVICE_OUT_SPEAKER_PROTECTED] = "speaker-protected",
Eric Laurentb23d5282013-05-14 15:27:20 -0700162
163 /* Capture sound devices */
164 [SND_DEVICE_IN_HANDSET_MIC] = "handset-mic",
Eric Laurentb23d5282013-05-14 15:27:20 -0700165 [SND_DEVICE_IN_HANDSET_MIC_AEC] = "handset-mic",
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -0800166 [SND_DEVICE_IN_HANDSET_MIC_NS] = "handset-mic",
167 [SND_DEVICE_IN_HANDSET_MIC_AEC_NS] = "handset-mic",
168 [SND_DEVICE_IN_HANDSET_DMIC] = "dmic-endfire",
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800169 [SND_DEVICE_IN_HANDSET_DMIC_AEC] = "dmic-endfire",
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -0800170 [SND_DEVICE_IN_HANDSET_DMIC_NS] = "dmic-endfire",
171 [SND_DEVICE_IN_HANDSET_DMIC_AEC_NS] = "dmic-endfire",
172 [SND_DEVICE_IN_SPEAKER_MIC] = "speaker-mic",
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800173 [SND_DEVICE_IN_SPEAKER_MIC_AEC] = "speaker-mic",
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -0800174 [SND_DEVICE_IN_SPEAKER_MIC_NS] = "speaker-mic",
175 [SND_DEVICE_IN_SPEAKER_MIC_AEC_NS] = "speaker-mic",
176 [SND_DEVICE_IN_SPEAKER_DMIC] = "speaker-dmic-endfire",
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800177 [SND_DEVICE_IN_SPEAKER_DMIC_AEC] = "speaker-dmic-endfire",
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -0800178 [SND_DEVICE_IN_SPEAKER_DMIC_NS] = "speaker-dmic-endfire",
179 [SND_DEVICE_IN_SPEAKER_DMIC_AEC_NS] = "speaker-dmic-endfire",
180 [SND_DEVICE_IN_HEADSET_MIC] = "headset-mic",
181 [SND_DEVICE_IN_HEADSET_MIC_FLUENCE] = "headset-mic",
Eric Laurentb23d5282013-05-14 15:27:20 -0700182 [SND_DEVICE_IN_VOICE_SPEAKER_MIC] = "voice-speaker-mic",
183 [SND_DEVICE_IN_VOICE_HEADSET_MIC] = "voice-headset-mic",
184 [SND_DEVICE_IN_HDMI_MIC] = "hdmi-mic",
185 [SND_DEVICE_IN_BT_SCO_MIC] = "bt-sco-mic",
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700186 [SND_DEVICE_IN_BT_SCO_MIC_WB] = "bt-sco-mic-wb",
Eric Laurentb23d5282013-05-14 15:27:20 -0700187 [SND_DEVICE_IN_CAMCORDER_MIC] = "camcorder-mic",
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700188 [SND_DEVICE_IN_VOICE_DMIC] = "voice-dmic-ef",
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700189 [SND_DEVICE_IN_VOICE_SPEAKER_DMIC] = "voice-speaker-dmic-ef",
Eric Laurentb23d5282013-05-14 15:27:20 -0700190 [SND_DEVICE_IN_VOICE_TTY_FULL_HEADSET_MIC] = "voice-tty-full-headset-mic",
191 [SND_DEVICE_IN_VOICE_TTY_VCO_HANDSET_MIC] = "voice-tty-vco-handset-mic",
192 [SND_DEVICE_IN_VOICE_TTY_HCO_HEADSET_MIC] = "voice-tty-hco-headset-mic",
193 [SND_DEVICE_IN_VOICE_REC_MIC] = "voice-rec-mic",
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -0800194 [SND_DEVICE_IN_VOICE_REC_MIC_NS] = "voice-rec-mic",
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800195 [SND_DEVICE_IN_VOICE_REC_DMIC_STEREO] = "voice-rec-dmic-ef",
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700196 [SND_DEVICE_IN_VOICE_REC_DMIC_FLUENCE] = "voice-rec-dmic-ef-fluence",
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -0700197 [SND_DEVICE_IN_USB_HEADSET_MIC] = "usb-headset-mic",
Apoorv Raghuvanshi6e262842013-10-06 14:39:35 -0700198 [SND_DEVICE_IN_CAPTURE_FM] = "capture-fm",
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -0700199 [SND_DEVICE_IN_AANC_HANDSET_MIC] = "aanc-handset-mic",
Apoorv Raghuvanshi6178a3f2013-10-19 12:38:54 -0700200 [SND_DEVICE_IN_QUAD_MIC] = "quad-mic",
Apoorv Raghuvanshi6bd8dbf2013-10-19 18:37:52 -0700201 [SND_DEVICE_IN_HANDSET_STEREO_DMIC] = "handset-stereo-dmic-ef",
202 [SND_DEVICE_IN_SPEAKER_STEREO_DMIC] = "speaker-stereo-dmic-ef",
Gopikrishnaiah Anandanf538cef2013-10-28 14:06:03 -0700203 [SND_DEVICE_IN_CAPTURE_VI_FEEDBACK] = "vi-feedback",
Eric Laurentb23d5282013-05-14 15:27:20 -0700204};
205
206/* ACDB IDs (audio DSP path configuration IDs) for each sound device */
207static const int acdb_device_table[SND_DEVICE_MAX] = {
208 [SND_DEVICE_NONE] = -1,
209 [SND_DEVICE_OUT_HANDSET] = 7,
Vidyakumar Athotac29d4ab2013-11-14 16:58:02 -0800210 [SND_DEVICE_OUT_SPEAKER] = 14,
211 [SND_DEVICE_OUT_SPEAKER_REVERSE] = 14,
Eric Laurentb23d5282013-05-14 15:27:20 -0700212 [SND_DEVICE_OUT_HEADPHONES] = 10,
213 [SND_DEVICE_OUT_SPEAKER_AND_HEADPHONES] = 10,
214 [SND_DEVICE_OUT_VOICE_HANDSET] = 7,
Vidyakumar Athotac29d4ab2013-11-14 16:58:02 -0800215 [SND_DEVICE_OUT_VOICE_SPEAKER] = 14,
Eric Laurentb23d5282013-05-14 15:27:20 -0700216 [SND_DEVICE_OUT_VOICE_HEADPHONES] = 10,
217 [SND_DEVICE_OUT_HDMI] = 18,
Vidyakumar Athotac29d4ab2013-11-14 16:58:02 -0800218 [SND_DEVICE_OUT_SPEAKER_AND_HDMI] = 14,
Eric Laurentb23d5282013-05-14 15:27:20 -0700219 [SND_DEVICE_OUT_BT_SCO] = 22,
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700220 [SND_DEVICE_OUT_BT_SCO_WB] = 39,
Eric Laurentb23d5282013-05-14 15:27:20 -0700221 [SND_DEVICE_OUT_VOICE_TTY_FULL_HEADPHONES] = 17,
222 [SND_DEVICE_OUT_VOICE_TTY_VCO_HEADPHONES] = 17,
223 [SND_DEVICE_OUT_VOICE_TTY_HCO_HANDSET] = 37,
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -0700224 [SND_DEVICE_OUT_AFE_PROXY] = 0,
225 [SND_DEVICE_OUT_USB_HEADSET] = 0,
226 [SND_DEVICE_OUT_SPEAKER_AND_USB_HEADSET] = 14,
Apoorv Raghuvanshi6e262842013-10-06 14:39:35 -0700227 [SND_DEVICE_OUT_TRANSMISSION_FM] = 0,
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -0700228 [SND_DEVICE_OUT_ANC_HEADSET] = 26,
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700229 [SND_DEVICE_OUT_ANC_FB_HEADSET] = 27,
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -0700230 [SND_DEVICE_OUT_VOICE_ANC_HEADSET] = 26,
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700231 [SND_DEVICE_OUT_VOICE_ANC_FB_HEADSET] = 27,
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -0700232 [SND_DEVICE_OUT_SPEAKER_AND_ANC_HEADSET] = 26,
233 [SND_DEVICE_OUT_ANC_HANDSET] = 103,
Gopikrishnaiah Anandanf538cef2013-10-28 14:06:03 -0700234 [SND_DEVICE_OUT_SPEAKER_PROTECTED] = 101,
Eric Laurentb23d5282013-05-14 15:27:20 -0700235
236 [SND_DEVICE_IN_HANDSET_MIC] = 4,
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -0800237 [SND_DEVICE_IN_HANDSET_MIC_AEC] = 106,
238 [SND_DEVICE_IN_HANDSET_MIC_NS] = 107,
239 [SND_DEVICE_IN_HANDSET_MIC_AEC_NS] = 108,
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800240 [SND_DEVICE_IN_HANDSET_DMIC] = 41,
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -0800241 [SND_DEVICE_IN_HANDSET_DMIC_AEC] = 109,
242 [SND_DEVICE_IN_HANDSET_DMIC_NS] = 110,
243 [SND_DEVICE_IN_HANDSET_DMIC_AEC_NS] = 111,
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800244 [SND_DEVICE_IN_SPEAKER_MIC] = 11,
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -0800245 [SND_DEVICE_IN_SPEAKER_MIC_AEC] = 112,
246 [SND_DEVICE_IN_SPEAKER_MIC_NS] = 113,
247 [SND_DEVICE_IN_SPEAKER_MIC_AEC_NS] = 114,
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800248 [SND_DEVICE_IN_SPEAKER_DMIC] = 43,
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -0800249 [SND_DEVICE_IN_SPEAKER_DMIC_AEC] = 115,
250 [SND_DEVICE_IN_SPEAKER_DMIC_NS] = 116,
251 [SND_DEVICE_IN_SPEAKER_DMIC_AEC_NS] = 117,
Eric Laurentb23d5282013-05-14 15:27:20 -0700252 [SND_DEVICE_IN_HEADSET_MIC] = 8,
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -0800253 [SND_DEVICE_IN_HEADSET_MIC_FLUENCE] = 47,
Eric Laurentb23d5282013-05-14 15:27:20 -0700254 [SND_DEVICE_IN_VOICE_SPEAKER_MIC] = 11,
255 [SND_DEVICE_IN_VOICE_HEADSET_MIC] = 8,
256 [SND_DEVICE_IN_HDMI_MIC] = 4,
257 [SND_DEVICE_IN_BT_SCO_MIC] = 21,
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700258 [SND_DEVICE_IN_BT_SCO_MIC_WB] = 38,
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800259 [SND_DEVICE_IN_CAMCORDER_MIC] = 4,
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700260 [SND_DEVICE_IN_VOICE_DMIC] = 41,
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700261 [SND_DEVICE_IN_VOICE_SPEAKER_DMIC] = 43,
Eric Laurentb23d5282013-05-14 15:27:20 -0700262 [SND_DEVICE_IN_VOICE_TTY_FULL_HEADSET_MIC] = 16,
263 [SND_DEVICE_IN_VOICE_TTY_VCO_HANDSET_MIC] = 36,
264 [SND_DEVICE_IN_VOICE_TTY_HCO_HEADSET_MIC] = 16,
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800265 [SND_DEVICE_IN_VOICE_REC_MIC] = 4,
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -0800266 [SND_DEVICE_IN_VOICE_REC_MIC_NS] = 107,
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800267 [SND_DEVICE_IN_VOICE_REC_DMIC_STEREO] = 34,
268 [SND_DEVICE_IN_VOICE_REC_DMIC_FLUENCE] = 41,
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -0700269 [SND_DEVICE_IN_USB_HEADSET_MIC] = 44,
Apoorv Raghuvanshi6e262842013-10-06 14:39:35 -0700270 [SND_DEVICE_IN_CAPTURE_FM] = 0,
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -0700271 [SND_DEVICE_IN_AANC_HANDSET_MIC] = 104,
Apoorv Raghuvanshi6178a3f2013-10-19 12:38:54 -0700272 [SND_DEVICE_IN_QUAD_MIC] = 46,
Apoorv Raghuvanshi6bd8dbf2013-10-19 18:37:52 -0700273 [SND_DEVICE_IN_HANDSET_STEREO_DMIC] = 34,
274 [SND_DEVICE_IN_SPEAKER_STEREO_DMIC] = 35,
Gopikrishnaiah Anandanf538cef2013-10-28 14:06:03 -0700275 [SND_DEVICE_IN_CAPTURE_VI_FEEDBACK] = 102,
Eric Laurentb23d5282013-05-14 15:27:20 -0700276};
277
Haynes Mathew George7ff216f2013-09-11 19:51:41 -0700278#define DEEP_BUFFER_PLATFORM_DELAY (29*1000LL)
279#define LOW_LATENCY_PLATFORM_DELAY (13*1000LL)
280
Eric Laurentb23d5282013-05-14 15:27:20 -0700281static int set_echo_reference(struct mixer *mixer, const char* ec_ref)
282{
283 struct mixer_ctl *ctl;
284 const char *mixer_ctl_name = "EC_REF_RX";
285
286 ctl = mixer_get_ctl_by_name(mixer, mixer_ctl_name);
287 if (!ctl) {
288 ALOGE("%s: Could not get ctl for mixer cmd - %s",
289 __func__, mixer_ctl_name);
290 return -EINVAL;
291 }
292 ALOGV("Setting EC Reference: %s", ec_ref);
293 mixer_ctl_set_enum_by_string(ctl, ec_ref);
294 return 0;
295}
296
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800297static struct csd_data *open_csd_client()
298{
299 struct csd_data *csd = calloc(1, sizeof(struct csd_data));
300
301 csd->csd_client = dlopen(LIB_CSD_CLIENT, RTLD_NOW);
302 if (csd->csd_client == NULL) {
303 ALOGE("%s: DLOPEN failed for %s", __func__, LIB_CSD_CLIENT);
304 goto error;
305 } else {
306 ALOGV("%s: DLOPEN successful for %s", __func__, LIB_CSD_CLIENT);
307
308 csd->deinit = (deinit_t)dlsym(csd->csd_client,
309 "csd_client_deinit");
310 if (csd->deinit == NULL) {
311 ALOGE("%s: dlsym error %s for csd_client_deinit", __func__,
312 dlerror());
313 goto error;
314 }
315 csd->disable_device = (disable_device_t)dlsym(csd->csd_client,
316 "csd_client_disable_device");
317 if (csd->disable_device == NULL) {
318 ALOGE("%s: dlsym error %s for csd_client_disable_device",
319 __func__, dlerror());
320 goto error;
321 }
322 csd->enable_device = (enable_device_t)dlsym(csd->csd_client,
323 "csd_client_enable_device");
324 if (csd->enable_device == NULL) {
325 ALOGE("%s: dlsym error %s for csd_client_enable_device",
326 __func__, dlerror());
327 goto error;
328 }
329 csd->start_voice = (start_voice_t)dlsym(csd->csd_client,
330 "csd_client_start_voice");
331 if (csd->start_voice == NULL) {
332 ALOGE("%s: dlsym error %s for csd_client_start_voice",
333 __func__, dlerror());
334 goto error;
335 }
336 csd->stop_voice = (stop_voice_t)dlsym(csd->csd_client,
337 "csd_client_stop_voice");
338 if (csd->stop_voice == NULL) {
339 ALOGE("%s: dlsym error %s for csd_client_stop_voice",
340 __func__, dlerror());
341 goto error;
342 }
343 csd->volume = (volume_t)dlsym(csd->csd_client,
344 "csd_client_volume");
345 if (csd->volume == NULL) {
346 ALOGE("%s: dlsym error %s for csd_client_volume",
347 __func__, dlerror());
348 goto error;
349 }
350 csd->mic_mute = (mic_mute_t)dlsym(csd->csd_client,
351 "csd_client_mic_mute");
352 if (csd->mic_mute == NULL) {
353 ALOGE("%s: dlsym error %s for csd_client_mic_mute",
354 __func__, dlerror());
355 goto error;
356 }
357 csd->slow_talk = (slow_talk_t)dlsym(csd->csd_client,
358 "csd_client_slow_talk");
359 if (csd->slow_talk == NULL) {
360 ALOGE("%s: dlsym error %s for csd_client_slow_talk",
361 __func__, dlerror());
362 goto error;
363 }
364 csd->start_playback = (start_playback_t)dlsym(csd->csd_client,
365 "csd_client_start_playback");
366 if (csd->start_playback == NULL) {
367 ALOGE("%s: dlsym error %s for csd_client_start_playback",
368 __func__, dlerror());
369 goto error;
370 }
371 csd->stop_playback = (stop_playback_t)dlsym(csd->csd_client,
372 "csd_client_stop_playback");
373 if (csd->stop_playback == NULL) {
374 ALOGE("%s: dlsym error %s for csd_client_stop_playback",
375 __func__, dlerror());
376 goto error;
377 }
378 csd->start_record = (start_record_t)dlsym(csd->csd_client,
379 "csd_client_start_record");
380 if (csd->start_record == NULL) {
381 ALOGE("%s: dlsym error %s for csd_client_start_record",
382 __func__, dlerror());
383 goto error;
384 }
385 csd->stop_record = (stop_record_t)dlsym(csd->csd_client,
386 "csd_client_stop_record");
387 if (csd->stop_record == NULL) {
388 ALOGE("%s: dlsym error %s for csd_client_stop_record",
389 __func__, dlerror());
390 goto error;
391 }
392 csd->init = (init_t)dlsym(csd->csd_client, "csd_client_init");
393
394 if (csd->init == NULL) {
395 ALOGE("%s: dlsym error %s for csd_client_init",
396 __func__, dlerror());
397 goto error;
398 } else {
399 csd->init();
400 }
401 }
402 return csd;
403
404error:
405 free(csd);
406 csd = NULL;
407 return csd;
408}
409
410void close_csd_client(struct csd_data *csd)
411{
412 if (csd != NULL) {
413 csd->deinit();
414 dlclose(csd->csd_client);
415 free(csd);
416 csd = NULL;
417 }
418}
419
Eric Laurentb23d5282013-05-14 15:27:20 -0700420void *platform_init(struct audio_device *adev)
421{
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800422 char platform[PROPERTY_VALUE_MAX];
423 char baseband[PROPERTY_VALUE_MAX];
Eric Laurentb23d5282013-05-14 15:27:20 -0700424 char value[PROPERTY_VALUE_MAX];
425 struct platform_data *my_data;
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700426 int retry_num = 0;
427 const char *snd_card_name;
sangwoo1b9f4b32013-06-21 18:22:55 -0700428
429 adev->mixer = mixer_open(MIXER_CARD);
430
431 while (!adev->mixer && retry_num < RETRY_NUMBER) {
432 usleep(RETRY_US);
433 adev->mixer = mixer_open(MIXER_CARD);
434 retry_num++;
435 }
436
437 if (!adev->mixer) {
438 ALOGE("Unable to open the mixer, aborting.");
439 return NULL;
440 }
441
Damir Didjustof1d46c72013-11-06 17:59:04 -0800442 if (audio_extn_read_xml(adev, MIXER_CARD, MIXER_XML_PATH,
443 MIXER_XML_PATH_AUXPCM) == -ENOSYS)
444 adev->audio_route = audio_route_init(MIXER_CARD, MIXER_XML_PATH);
445
sangwoo1b9f4b32013-06-21 18:22:55 -0700446 if (!adev->audio_route) {
447 ALOGE("%s: Failed to init audio route controls, aborting.", __func__);
448 return NULL;
449 }
Eric Laurentb23d5282013-05-14 15:27:20 -0700450
451 my_data = calloc(1, sizeof(struct platform_data));
452
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700453 snd_card_name = mixer_get_name(adev->mixer);
454 my_data->hw_info = hw_info_init(snd_card_name);
455 if (!my_data->hw_info) {
456 ALOGE("%s: Failed to init hardware info", __func__);
457 }
458
Eric Laurentb23d5282013-05-14 15:27:20 -0700459 my_data->adev = adev;
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700460 my_data->btsco_sample_rate = SAMPLE_RATE_8KHZ;
Eric Laurentb23d5282013-05-14 15:27:20 -0700461 my_data->fluence_in_spkr_mode = false;
462 my_data->fluence_in_voice_call = false;
463 my_data->fluence_in_voice_rec = false;
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800464 my_data->fluence_in_audio_rec = false;
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700465 my_data->fluence_type = FLUENCE_NONE;
Eric Laurentb23d5282013-05-14 15:27:20 -0700466
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700467 property_get("ro.qc.sdk.audio.fluencetype", value, "");
468 if (!strncmp("fluencepro", value, sizeof("fluencepro"))) {
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800469 my_data->fluence_type = FLUENCE_QUAD_MIC | FLUENCE_DUAL_MIC;
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700470 } else if (!strncmp("fluence", value, sizeof("fluence"))) {
471 my_data->fluence_type = FLUENCE_DUAL_MIC;
472 } else {
473 my_data->fluence_type = FLUENCE_NONE;
Eric Laurentb23d5282013-05-14 15:27:20 -0700474 }
475
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700476 if (my_data->fluence_type != FLUENCE_NONE) {
Eric Laurentb23d5282013-05-14 15:27:20 -0700477 property_get("persist.audio.fluence.voicecall",value,"");
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700478 if (!strncmp("true", value, sizeof("true"))) {
Eric Laurentb23d5282013-05-14 15:27:20 -0700479 my_data->fluence_in_voice_call = true;
480 }
481
482 property_get("persist.audio.fluence.voicerec",value,"");
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700483 if (!strncmp("true", value, sizeof("true"))) {
Eric Laurentb23d5282013-05-14 15:27:20 -0700484 my_data->fluence_in_voice_rec = true;
485 }
486
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800487 property_get("persist.audio.fluence.audiorec",value,"");
488 if (!strncmp("true", value, sizeof("true"))) {
489 my_data->fluence_in_audio_rec = true;
490 }
491
Eric Laurentb23d5282013-05-14 15:27:20 -0700492 property_get("persist.audio.fluence.speaker",value,"");
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700493 if (!strncmp("true", value, sizeof("true"))) {
Eric Laurentb23d5282013-05-14 15:27:20 -0700494 my_data->fluence_in_spkr_mode = true;
495 }
496 }
497
498 my_data->acdb_handle = dlopen(LIB_ACDB_LOADER, RTLD_NOW);
499 if (my_data->acdb_handle == NULL) {
500 ALOGE("%s: DLOPEN failed for %s", __func__, LIB_ACDB_LOADER);
501 } else {
502 ALOGV("%s: DLOPEN successful for %s", __func__, LIB_ACDB_LOADER);
503 my_data->acdb_deallocate = (acdb_deallocate_t)dlsym(my_data->acdb_handle,
504 "acdb_loader_deallocate_ACDB");
505 my_data->acdb_send_audio_cal = (acdb_send_audio_cal_t)dlsym(my_data->acdb_handle,
506 "acdb_loader_send_audio_cal");
507 if (!my_data->acdb_send_audio_cal)
508 ALOGW("%s: Could not find the symbol acdb_send_audio_cal from %s",
509 __func__, LIB_ACDB_LOADER);
510 my_data->acdb_send_voice_cal = (acdb_send_voice_cal_t)dlsym(my_data->acdb_handle,
511 "acdb_loader_send_voice_cal");
512 my_data->acdb_init = (acdb_init_t)dlsym(my_data->acdb_handle,
513 "acdb_loader_init_ACDB");
514 if (my_data->acdb_init == NULL)
515 ALOGE("%s: dlsym error %s for acdb_loader_init_ACDB", __func__, dlerror());
516 else
517 my_data->acdb_init();
518 }
519
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800520 /* If platform is apq8084 and baseband is MDM, load CSD Client specific
521 * symbols. Voice call is handled by MDM and apps processor talks to
522 * MDM through CSD Client
523 */
524 property_get("ro.board.platform", platform, "");
525 property_get("ro.baseband", baseband, "");
526 if (!strncmp("apq8084", platform, sizeof("apq8084")) &&
527 !strncmp("mdm", baseband, sizeof("mdm"))) {
528 my_data->csd = open_csd_client();
529 }
530
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -0700531 /* init usb */
532 audio_extn_usb_init(adev);
533
Apoorv Raghuvanshi6178a3f2013-10-19 12:38:54 -0700534 /* Read one time ssr property */
535 audio_extn_ssr_update_enabled(adev);
Gopikrishnaiah Anandanf538cef2013-10-28 14:06:03 -0700536 audio_extn_spkr_prot_init(adev);
Eric Laurentb23d5282013-05-14 15:27:20 -0700537 return my_data;
538}
539
540void platform_deinit(void *platform)
541{
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700542 struct platform_data *my_data = (struct platform_data *)platform;
543
544 hw_info_deinit(my_data->hw_info);
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800545 close_csd_client(my_data->csd);
546
Eric Laurentb23d5282013-05-14 15:27:20 -0700547 free(platform);
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -0700548 /* deinit usb */
549 audio_extn_usb_deinit();
Eric Laurentb23d5282013-05-14 15:27:20 -0700550}
551
552const char *platform_get_snd_device_name(snd_device_t snd_device)
553{
554 if (snd_device >= SND_DEVICE_MIN && snd_device < SND_DEVICE_MAX)
555 return device_table[snd_device];
556 else
557 return "";
558}
559
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700560int platform_get_snd_device_name_extn(void *platform, snd_device_t snd_device,
561 char *device_name)
562{
563 struct platform_data *my_data = (struct platform_data *)platform;
564
565 if (snd_device >= SND_DEVICE_MIN && snd_device < SND_DEVICE_MAX) {
566 strlcpy(device_name, device_table[snd_device], DEVICE_NAME_MAX_SIZE);
567 hw_info_append_hw_type(my_data->hw_info, snd_device, device_name);
568 } else {
569 strlcpy(device_name, "", DEVICE_NAME_MAX_SIZE);
570 return -EINVAL;
571 }
572
573 return 0;
574}
575
Eric Laurentb23d5282013-05-14 15:27:20 -0700576void platform_add_backend_name(char *mixer_path, snd_device_t snd_device)
577{
578 if (snd_device == SND_DEVICE_IN_BT_SCO_MIC)
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700579 strlcat(mixer_path, " bt-sco", MIXER_PATH_MAX_LENGTH);
580 else if (snd_device == SND_DEVICE_IN_BT_SCO_MIC_WB)
581 strlcat(mixer_path, " bt-sco-wb", MIXER_PATH_MAX_LENGTH);
Eric Laurentb23d5282013-05-14 15:27:20 -0700582 else if(snd_device == SND_DEVICE_OUT_BT_SCO)
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700583 strlcat(mixer_path, " bt-sco", MIXER_PATH_MAX_LENGTH);
584 else if(snd_device == SND_DEVICE_OUT_BT_SCO_WB)
585 strlcat(mixer_path, " bt-sco-wb", MIXER_PATH_MAX_LENGTH);
Eric Laurentb23d5282013-05-14 15:27:20 -0700586 else if (snd_device == SND_DEVICE_OUT_HDMI)
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700587 strlcat(mixer_path, " hdmi", MIXER_PATH_MAX_LENGTH);
Eric Laurentb23d5282013-05-14 15:27:20 -0700588 else if (snd_device == SND_DEVICE_OUT_SPEAKER_AND_HDMI)
589 strcat(mixer_path, " speaker-and-hdmi");
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -0700590 else if (snd_device == SND_DEVICE_OUT_AFE_PROXY)
591 strlcat(mixer_path, " afe-proxy", MIXER_PATH_MAX_LENGTH);
592 else if (snd_device == SND_DEVICE_OUT_USB_HEADSET)
593 strlcat(mixer_path, " usb-headphones", MIXER_PATH_MAX_LENGTH);
594 else if (snd_device == SND_DEVICE_OUT_SPEAKER_AND_USB_HEADSET)
595 strlcat(mixer_path, " speaker-and-usb-headphones",
596 MIXER_PATH_MAX_LENGTH);
597 else if (snd_device == SND_DEVICE_IN_USB_HEADSET_MIC)
598 strlcat(mixer_path, " usb-headset-mic", MIXER_PATH_MAX_LENGTH);
Apoorv Raghuvanshi6e262842013-10-06 14:39:35 -0700599 else if (snd_device == SND_DEVICE_IN_CAPTURE_FM)
600 strlcat(mixer_path, " capture-fm", MIXER_PATH_MAX_LENGTH);
601 else if (snd_device == SND_DEVICE_OUT_TRANSMISSION_FM)
602 strlcat(mixer_path, " transmission-fm", MIXER_PATH_MAX_LENGTH);
Eric Laurentb23d5282013-05-14 15:27:20 -0700603}
604
605int platform_get_pcm_device_id(audio_usecase_t usecase, int device_type)
606{
607 int device_id;
608 if (device_type == PCM_PLAYBACK)
609 device_id = pcm_device_table[usecase][0];
610 else
611 device_id = pcm_device_table[usecase][1];
612 return device_id;
613}
614
615int platform_send_audio_calibration(void *platform, snd_device_t snd_device)
616{
617 struct platform_data *my_data = (struct platform_data *)platform;
618 int acdb_dev_id, acdb_dev_type;
619
620 acdb_dev_id = acdb_device_table[snd_device];
621 if (acdb_dev_id < 0) {
622 ALOGE("%s: Could not find acdb id for device(%d)",
623 __func__, snd_device);
624 return -EINVAL;
625 }
626 if (my_data->acdb_send_audio_cal) {
Eric Laurent994a6932013-07-17 11:51:42 -0700627 ("%s: sending audio calibration for snd_device(%d) acdb_id(%d)",
Eric Laurentb23d5282013-05-14 15:27:20 -0700628 __func__, snd_device, acdb_dev_id);
629 if (snd_device >= SND_DEVICE_OUT_BEGIN &&
630 snd_device < SND_DEVICE_OUT_END)
631 acdb_dev_type = ACDB_DEV_TYPE_OUT;
632 else
633 acdb_dev_type = ACDB_DEV_TYPE_IN;
634 my_data->acdb_send_audio_cal(acdb_dev_id, acdb_dev_type);
635 }
636 return 0;
637}
638
639int platform_switch_voice_call_device_pre(void *platform)
640{
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800641 struct platform_data *my_data = (struct platform_data *)platform;
642 int ret = 0;
643
Vidyakumar Athota1fd21792013-11-15 14:50:57 -0800644 if (my_data->csd != NULL &&
645 my_data->adev->mode == AUDIO_MODE_IN_CALL) {
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800646 /* This must be called before disabling mixer controls on APQ side */
647 ret = my_data->csd->disable_device();
648 if (ret < 0) {
649 ALOGE("%s: csd_client_disable_device, failed, error %d",
650 __func__, ret);
651 }
652 }
653 return ret;
Eric Laurentb23d5282013-05-14 15:27:20 -0700654}
655
656int platform_switch_voice_call_device_post(void *platform,
657 snd_device_t out_snd_device,
658 snd_device_t in_snd_device)
659{
660 struct platform_data *my_data = (struct platform_data *)platform;
661 int acdb_rx_id, acdb_tx_id;
662
663 if (my_data->acdb_send_voice_cal == NULL) {
664 ALOGE("%s: dlsym error for acdb_send_voice_call", __func__);
665 } else {
Vidyakumar Athota1fd21792013-11-15 14:50:57 -0800666 acdb_rx_id = acdb_device_table[out_snd_device];
667 acdb_tx_id = acdb_device_table[in_snd_device];
668
Eric Laurentb23d5282013-05-14 15:27:20 -0700669 if (acdb_rx_id > 0 && acdb_tx_id > 0)
670 my_data->acdb_send_voice_cal(acdb_rx_id, acdb_tx_id);
671 else
672 ALOGE("%s: Incorrect ACDB IDs (rx: %d tx: %d)", __func__,
673 acdb_rx_id, acdb_tx_id);
674 }
675
Vidyakumar Athota1fd21792013-11-15 14:50:57 -0800676 return 0;
677}
678
679int platform_switch_voice_call_usecase_route_post(void *platform,
680 snd_device_t out_snd_device,
681 snd_device_t in_snd_device)
682{
683 struct platform_data *my_data = (struct platform_data *)platform;
684 int acdb_rx_id, acdb_tx_id;
685 int ret = 0;
686
687 acdb_rx_id = acdb_device_table[out_snd_device];
688 acdb_tx_id = acdb_device_table[in_snd_device];
689
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800690 if (my_data->csd != NULL) {
Vidyakumar Athota1fd21792013-11-15 14:50:57 -0800691 if (acdb_rx_id > 0 && acdb_tx_id > 0) {
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800692 ret = my_data->csd->enable_device(acdb_rx_id, acdb_tx_id,
693 my_data->adev->acdb_settings);
694 if (ret < 0) {
695 ALOGE("%s: csd_enable_device, failed, error %d",
696 __func__, ret);
697 }
698 } else {
699 ALOGE("%s: Incorrect ACDB IDs (rx: %d tx: %d)", __func__,
700 acdb_rx_id, acdb_tx_id);
701 }
702 }
703 return ret;
Eric Laurentb23d5282013-05-14 15:27:20 -0700704}
705
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800706int platform_start_voice_call(void *platform, uint32_t vsid)
Eric Laurentb23d5282013-05-14 15:27:20 -0700707{
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800708 struct platform_data *my_data = (struct platform_data *)platform;
709 int ret = 0;
710
711 if (my_data->csd != NULL) {
712 ret = my_data->csd->start_voice(vsid);
713 if (ret < 0) {
714 ALOGE("%s: csd_start_voice error %d\n", __func__, ret);
715 }
716 }
717 return ret;
Eric Laurentb23d5282013-05-14 15:27:20 -0700718}
719
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800720int platform_stop_voice_call(void *platform, uint32_t vsid)
Eric Laurentb23d5282013-05-14 15:27:20 -0700721{
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800722 struct platform_data *my_data = (struct platform_data *)platform;
723 int ret = 0;
724
725 if (my_data->csd != NULL) {
726 ret = my_data->csd->stop_voice(vsid);
727 if (ret < 0) {
728 ALOGE("%s: csd_stop_voice error %d\n", __func__, ret);
729 }
730 }
731 return ret;
Eric Laurentb23d5282013-05-14 15:27:20 -0700732}
733
734int platform_set_voice_volume(void *platform, int volume)
735{
736 struct platform_data *my_data = (struct platform_data *)platform;
737 struct audio_device *adev = my_data->adev;
738 struct mixer_ctl *ctl;
sangwoo53b2cf02013-07-25 19:18:44 -0700739 const char *mixer_ctl_name = "Voice Rx Gain";
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800740 int vol_index = 0, ret = 0;
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700741 uint32_t set_values[ ] = {0,
742 ALL_SESSION_VSID,
743 DEFAULT_VOLUME_RAMP_DURATION_MS};
Eric Laurentb23d5282013-05-14 15:27:20 -0700744
745 // Voice volume levels are mapped to adsp volume levels as follows.
746 // 100 -> 5, 80 -> 4, 60 -> 3, 40 -> 2, 20 -> 1 0 -> 0
747 // But this values don't changed in kernel. So, below change is need.
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700748 vol_index = (int)percent_to_index(volume, MIN_VOL_INDEX, MAX_VOL_INDEX);
749 set_values[0] = vol_index;
Eric Laurentb23d5282013-05-14 15:27:20 -0700750
751 ctl = mixer_get_ctl_by_name(adev->mixer, mixer_ctl_name);
752 if (!ctl) {
753 ALOGE("%s: Could not get ctl for mixer cmd - %s",
754 __func__, mixer_ctl_name);
755 return -EINVAL;
756 }
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700757 ALOGV("Setting voice volume index: %d", set_values[0]);
758 mixer_ctl_set_array(ctl, set_values, ARRAY_SIZE(set_values));
Eric Laurentb23d5282013-05-14 15:27:20 -0700759
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800760 if (my_data->csd != NULL) {
761 ret = my_data->csd->volume(ALL_SESSION_VSID, volume);
762 if (ret < 0) {
763 ALOGE("%s: csd_volume error %d", __func__, ret);
764 }
765 }
766 return ret;
Eric Laurentb23d5282013-05-14 15:27:20 -0700767}
768
769int platform_set_mic_mute(void *platform, bool state)
770{
771 struct platform_data *my_data = (struct platform_data *)platform;
772 struct audio_device *adev = my_data->adev;
773 struct mixer_ctl *ctl;
774 const char *mixer_ctl_name = "Voice Tx Mute";
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800775 int ret = 0;
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700776 uint32_t set_values[ ] = {0,
777 ALL_SESSION_VSID,
778 DEFAULT_VOLUME_RAMP_DURATION_MS};
Eric Laurentb23d5282013-05-14 15:27:20 -0700779
Narsinga Rao Chella05573b72013-11-15 15:21:40 -0800780 set_values[0] = state;
781 ctl = mixer_get_ctl_by_name(adev->mixer, mixer_ctl_name);
782 if (!ctl) {
783 ALOGE("%s: Could not get ctl for mixer cmd - %s",
784 __func__, mixer_ctl_name);
785 return -EINVAL;
786 }
787 ALOGV("Setting voice mute state: %d", state);
788 mixer_ctl_set_array(ctl, set_values, ARRAY_SIZE(set_values));
Eric Laurentb23d5282013-05-14 15:27:20 -0700789
Narsinga Rao Chella05573b72013-11-15 15:21:40 -0800790 if (my_data->csd != NULL) {
791 ret = my_data->csd->mic_mute(ALL_SESSION_VSID, state);
792 if (ret < 0) {
793 ALOGE("%s: csd_mic_mute error %d", __func__, ret);
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800794 }
795 }
796 return ret;
Eric Laurentb23d5282013-05-14 15:27:20 -0700797}
798
799snd_device_t platform_get_output_snd_device(void *platform, audio_devices_t devices)
800{
801 struct platform_data *my_data = (struct platform_data *)platform;
802 struct audio_device *adev = my_data->adev;
803 audio_mode_t mode = adev->mode;
804 snd_device_t snd_device = SND_DEVICE_NONE;
805
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -0700806 audio_channel_mask_t channel_mask = (adev->active_input == NULL) ?
807 AUDIO_CHANNEL_IN_MONO : adev->active_input->channel_mask;
808 int channel_count = popcount(channel_mask);
809
Eric Laurentb23d5282013-05-14 15:27:20 -0700810 ALOGV("%s: enter: output devices(%#x)", __func__, devices);
811 if (devices == AUDIO_DEVICE_NONE ||
812 devices & AUDIO_DEVICE_BIT_IN) {
813 ALOGV("%s: Invalid output devices (%#x)", __func__, devices);
814 goto exit;
815 }
816
Narsinga Rao Chella05573b72013-11-15 15:21:40 -0800817 if ((mode == AUDIO_MODE_IN_CALL) ||
818 voice_extn_compress_voip_is_active(adev)) {
Eric Laurentb23d5282013-05-14 15:27:20 -0700819 if (devices & AUDIO_DEVICE_OUT_WIRED_HEADPHONE ||
820 devices & AUDIO_DEVICE_OUT_WIRED_HEADSET) {
Narsinga Rao Chella05573b72013-11-15 15:21:40 -0800821 if ((adev->voice.tty_mode != TTY_MODE_OFF) &&
822 !voice_extn_compress_voip_is_active(adev)) {
823 switch (adev->voice.tty_mode) {
824 case TTY_MODE_FULL:
825 snd_device = SND_DEVICE_OUT_VOICE_TTY_FULL_HEADPHONES;
826 break;
827 case TTY_MODE_VCO:
828 snd_device = SND_DEVICE_OUT_VOICE_TTY_VCO_HEADPHONES;
829 break;
830 case TTY_MODE_HCO:
831 snd_device = SND_DEVICE_OUT_VOICE_TTY_HCO_HANDSET;
832 break;
833 default:
834 ALOGE("%s: Invalid TTY mode (%#x)",
835 __func__, adev->voice.tty_mode);
836 }
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700837 } else if (audio_extn_get_anc_enabled()) {
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -0700838 if (audio_extn_should_use_fb_anc())
839 snd_device = SND_DEVICE_OUT_VOICE_ANC_FB_HEADSET;
840 else
841 snd_device = SND_DEVICE_OUT_VOICE_ANC_HEADSET;
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700842 } else {
Eric Laurentb23d5282013-05-14 15:27:20 -0700843 snd_device = SND_DEVICE_OUT_VOICE_HEADPHONES;
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700844 }
Eric Laurentb23d5282013-05-14 15:27:20 -0700845 } else if (devices & AUDIO_DEVICE_OUT_ALL_SCO) {
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700846 if (my_data->btsco_sample_rate == SAMPLE_RATE_16KHZ)
847 snd_device = SND_DEVICE_OUT_BT_SCO_WB;
848 else
849 snd_device = SND_DEVICE_OUT_BT_SCO;
Eric Laurentb23d5282013-05-14 15:27:20 -0700850 } else if (devices & AUDIO_DEVICE_OUT_SPEAKER) {
851 snd_device = SND_DEVICE_OUT_VOICE_SPEAKER;
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -0700852 } else if (devices & AUDIO_DEVICE_OUT_ANLG_DOCK_HEADSET ||
853 devices & AUDIO_DEVICE_OUT_DGTL_DOCK_HEADSET) {
854 snd_device = SND_DEVICE_OUT_USB_HEADSET;
Apoorv Raghuvanshi6e262842013-10-06 14:39:35 -0700855 } else if (devices & AUDIO_DEVICE_OUT_FM_TX) {
856 snd_device = SND_DEVICE_OUT_TRANSMISSION_FM;
Eric Laurentb23d5282013-05-14 15:27:20 -0700857 } else if (devices & AUDIO_DEVICE_OUT_EARPIECE) {
Ravi Kumar Alamandaceb40822013-11-06 11:01:47 -0800858 if (audio_extn_should_use_handset_anc(channel_count))
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -0700859 snd_device = SND_DEVICE_OUT_ANC_HANDSET;
Eric Laurentb23d5282013-05-14 15:27:20 -0700860 else
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700861 snd_device = SND_DEVICE_OUT_VOICE_HANDSET;
Eric Laurentb23d5282013-05-14 15:27:20 -0700862 }
863 if (snd_device != SND_DEVICE_NONE) {
864 goto exit;
865 }
866 }
867
868 if (popcount(devices) == 2) {
869 if (devices == (AUDIO_DEVICE_OUT_WIRED_HEADPHONE |
870 AUDIO_DEVICE_OUT_SPEAKER)) {
871 snd_device = SND_DEVICE_OUT_SPEAKER_AND_HEADPHONES;
872 } else if (devices == (AUDIO_DEVICE_OUT_WIRED_HEADSET |
873 AUDIO_DEVICE_OUT_SPEAKER)) {
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -0700874 if (audio_extn_get_anc_enabled())
875 snd_device = SND_DEVICE_OUT_SPEAKER_AND_ANC_HEADSET;
876 else
877 snd_device = SND_DEVICE_OUT_SPEAKER_AND_HEADPHONES;
Eric Laurentb23d5282013-05-14 15:27:20 -0700878 } else if (devices == (AUDIO_DEVICE_OUT_AUX_DIGITAL |
879 AUDIO_DEVICE_OUT_SPEAKER)) {
880 snd_device = SND_DEVICE_OUT_SPEAKER_AND_HDMI;
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -0700881 } else if (devices == (AUDIO_DEVICE_OUT_ANLG_DOCK_HEADSET |
882 AUDIO_DEVICE_OUT_SPEAKER)) {
883 snd_device = SND_DEVICE_OUT_SPEAKER_AND_USB_HEADSET;
Eric Laurentb23d5282013-05-14 15:27:20 -0700884 } else {
885 ALOGE("%s: Invalid combo device(%#x)", __func__, devices);
886 goto exit;
887 }
888 if (snd_device != SND_DEVICE_NONE) {
889 goto exit;
890 }
891 }
892
893 if (popcount(devices) != 1) {
894 ALOGE("%s: Invalid output devices(%#x)", __func__, devices);
895 goto exit;
896 }
897
898 if (devices & AUDIO_DEVICE_OUT_WIRED_HEADPHONE ||
899 devices & AUDIO_DEVICE_OUT_WIRED_HEADSET) {
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -0700900 if (devices & AUDIO_DEVICE_OUT_WIRED_HEADSET
901 && audio_extn_get_anc_enabled()) {
902 if (audio_extn_should_use_fb_anc())
903 snd_device = SND_DEVICE_OUT_ANC_FB_HEADSET;
904 else
905 snd_device = SND_DEVICE_OUT_ANC_HEADSET;
906 }
907 else
908 snd_device = SND_DEVICE_OUT_HEADPHONES;
Eric Laurentb23d5282013-05-14 15:27:20 -0700909 } else if (devices & AUDIO_DEVICE_OUT_SPEAKER) {
910 if (adev->speaker_lr_swap)
911 snd_device = SND_DEVICE_OUT_SPEAKER_REVERSE;
912 else
913 snd_device = SND_DEVICE_OUT_SPEAKER;
914 } else if (devices & AUDIO_DEVICE_OUT_ALL_SCO) {
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700915 if (my_data->btsco_sample_rate == SAMPLE_RATE_16KHZ)
916 snd_device = SND_DEVICE_OUT_BT_SCO_WB;
917 else
918 snd_device = SND_DEVICE_OUT_BT_SCO;
Eric Laurentb23d5282013-05-14 15:27:20 -0700919 } else if (devices & AUDIO_DEVICE_OUT_AUX_DIGITAL) {
920 snd_device = SND_DEVICE_OUT_HDMI ;
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -0700921 } else if (devices & AUDIO_DEVICE_OUT_ANLG_DOCK_HEADSET ||
922 devices & AUDIO_DEVICE_OUT_DGTL_DOCK_HEADSET) {
923 snd_device = SND_DEVICE_OUT_USB_HEADSET;
Apoorv Raghuvanshi6e262842013-10-06 14:39:35 -0700924 } else if (devices & AUDIO_DEVICE_OUT_FM_TX) {
925 snd_device = SND_DEVICE_OUT_TRANSMISSION_FM;
Eric Laurentb23d5282013-05-14 15:27:20 -0700926 } else if (devices & AUDIO_DEVICE_OUT_EARPIECE) {
927 snd_device = SND_DEVICE_OUT_HANDSET;
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -0700928 } else if (devices & AUDIO_DEVICE_OUT_PROXY) {
929 ALOGD("%s: setting sink capability for Proxy", __func__);
930 audio_extn_set_afe_proxy_channel_mixer(adev);
931 snd_device = SND_DEVICE_OUT_AFE_PROXY;
Eric Laurentb23d5282013-05-14 15:27:20 -0700932 } else {
933 ALOGE("%s: Unknown device(s) %#x", __func__, devices);
934 }
935exit:
936 ALOGV("%s: exit: snd_device(%s)", __func__, device_table[snd_device]);
937 return snd_device;
938}
939
940snd_device_t platform_get_input_snd_device(void *platform, audio_devices_t out_device)
941{
942 struct platform_data *my_data = (struct platform_data *)platform;
943 struct audio_device *adev = my_data->adev;
944 audio_source_t source = (adev->active_input == NULL) ?
945 AUDIO_SOURCE_DEFAULT : adev->active_input->source;
946
947 audio_mode_t mode = adev->mode;
948 audio_devices_t in_device = ((adev->active_input == NULL) ?
949 AUDIO_DEVICE_NONE : adev->active_input->device)
950 & ~AUDIO_DEVICE_BIT_IN;
951 audio_channel_mask_t channel_mask = (adev->active_input == NULL) ?
952 AUDIO_CHANNEL_IN_MONO : adev->active_input->channel_mask;
953 snd_device_t snd_device = SND_DEVICE_NONE;
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -0700954 int channel_count = popcount(channel_mask);
Eric Laurentb23d5282013-05-14 15:27:20 -0700955
956 ALOGV("%s: enter: out_device(%#x) in_device(%#x)",
957 __func__, out_device, in_device);
Helen Zeng067b96b2013-11-26 12:10:29 -0800958 if ((out_device != AUDIO_DEVICE_NONE) && ((mode == AUDIO_MODE_IN_CALL) ||
959 voice_extn_compress_voip_is_active(adev))) {
Narsinga Rao Chella05573b72013-11-15 15:21:40 -0800960 if ((adev->voice.tty_mode != TTY_MODE_OFF) &&
961 !voice_extn_compress_voip_is_active(adev)) {
Eric Laurentb23d5282013-05-14 15:27:20 -0700962 if (out_device & AUDIO_DEVICE_OUT_WIRED_HEADPHONE ||
963 out_device & AUDIO_DEVICE_OUT_WIRED_HEADSET) {
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700964 switch (adev->voice.tty_mode) {
Eric Laurentb23d5282013-05-14 15:27:20 -0700965 case TTY_MODE_FULL:
966 snd_device = SND_DEVICE_IN_VOICE_TTY_FULL_HEADSET_MIC;
967 break;
968 case TTY_MODE_VCO:
969 snd_device = SND_DEVICE_IN_VOICE_TTY_VCO_HANDSET_MIC;
970 break;
971 case TTY_MODE_HCO:
972 snd_device = SND_DEVICE_IN_VOICE_TTY_HCO_HEADSET_MIC;
973 break;
974 default:
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700975 ALOGE("%s: Invalid TTY mode (%#x)",
976 __func__, adev->voice.tty_mode);
Eric Laurentb23d5282013-05-14 15:27:20 -0700977 }
978 goto exit;
979 }
980 }
981 if (out_device & AUDIO_DEVICE_OUT_EARPIECE ||
982 out_device & AUDIO_DEVICE_OUT_WIRED_HEADPHONE) {
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -0700983 if (out_device & AUDIO_DEVICE_OUT_EARPIECE &&
984 audio_extn_should_use_handset_anc(channel_count)) {
985 snd_device = SND_DEVICE_IN_AANC_HANDSET_MIC;
986 } else if (my_data->fluence_type == FLUENCE_NONE ||
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700987 my_data->fluence_in_voice_call == false) {
Eric Laurentb23d5282013-05-14 15:27:20 -0700988 snd_device = SND_DEVICE_IN_HANDSET_MIC;
Vimal Puthanveed5b4d3f12013-11-05 15:57:39 -0800989 set_echo_reference(adev->mixer, "SLIM_RX");
Eric Laurentb23d5282013-05-14 15:27:20 -0700990 } else {
Ravi Kumar Alamandaceb40822013-11-06 11:01:47 -0800991 snd_device = SND_DEVICE_IN_VOICE_DMIC;
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700992 adev->acdb_settings |= DMIC_FLAG;
Eric Laurentb23d5282013-05-14 15:27:20 -0700993 }
994 } else if (out_device & AUDIO_DEVICE_OUT_WIRED_HEADSET) {
995 snd_device = SND_DEVICE_IN_VOICE_HEADSET_MIC;
996 } else if (out_device & AUDIO_DEVICE_OUT_ALL_SCO) {
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700997 if (my_data->btsco_sample_rate == SAMPLE_RATE_16KHZ)
998 snd_device = SND_DEVICE_IN_BT_SCO_MIC_WB;
999 else
1000 snd_device = SND_DEVICE_IN_BT_SCO_MIC;
Eric Laurentb23d5282013-05-14 15:27:20 -07001001 } else if (out_device & AUDIO_DEVICE_OUT_SPEAKER) {
Mingming Yin8e5a4f62013-10-07 15:23:41 -07001002 if (my_data->fluence_type != FLUENCE_NONE &&
1003 my_data->fluence_in_voice_call &&
1004 my_data->fluence_in_spkr_mode) {
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -08001005 if(my_data->fluence_type & FLUENCE_QUAD_MIC) {
Mingming Yin8e5a4f62013-10-07 15:23:41 -07001006 adev->acdb_settings |= QMIC_FLAG;
1007 snd_device = SND_DEVICE_IN_VOICE_SPEAKER_QMIC;
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -08001008 } else {
1009 adev->acdb_settings |= DMIC_FLAG;
1010 snd_device = SND_DEVICE_IN_VOICE_SPEAKER_DMIC;
Mingming Yin8e5a4f62013-10-07 15:23:41 -07001011 }
Eric Laurentb23d5282013-05-14 15:27:20 -07001012 } else {
1013 snd_device = SND_DEVICE_IN_VOICE_SPEAKER_MIC;
1014 }
1015 }
1016 } else if (source == AUDIO_SOURCE_CAMCORDER) {
1017 if (in_device & AUDIO_DEVICE_IN_BUILTIN_MIC ||
1018 in_device & AUDIO_DEVICE_IN_BACK_MIC) {
1019 snd_device = SND_DEVICE_IN_CAMCORDER_MIC;
1020 }
1021 } else if (source == AUDIO_SOURCE_VOICE_RECOGNITION) {
1022 if (in_device & AUDIO_DEVICE_IN_BUILTIN_MIC) {
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -08001023 if (channel_count == 2) {
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -08001024 snd_device = SND_DEVICE_IN_VOICE_REC_DMIC_STEREO;
Mingming Yin8e5a4f62013-10-07 15:23:41 -07001025 adev->acdb_settings |= DMIC_FLAG;
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -08001026 } else if (adev->active_input->enable_ns)
1027 snd_device = SND_DEVICE_IN_VOICE_REC_MIC_NS;
1028 else if (my_data->fluence_type != FLUENCE_NONE &&
1029 my_data->fluence_in_voice_rec) {
1030 snd_device = SND_DEVICE_IN_VOICE_REC_DMIC_FLUENCE;
1031 adev->acdb_settings |= DMIC_FLAG;
1032 } else {
1033 snd_device = SND_DEVICE_IN_VOICE_REC_MIC;
1034 }
Eric Laurentb23d5282013-05-14 15:27:20 -07001035 }
1036 } else if (source == AUDIO_SOURCE_VOICE_COMMUNICATION) {
1037 if (out_device & AUDIO_DEVICE_OUT_SPEAKER)
1038 in_device = AUDIO_DEVICE_IN_BACK_MIC;
1039 if (adev->active_input) {
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -08001040 if (adev->active_input->enable_aec &&
1041 adev->active_input->enable_ns) {
Eric Laurentb23d5282013-05-14 15:27:20 -07001042 if (in_device & AUDIO_DEVICE_IN_BACK_MIC) {
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -08001043 if (my_data->fluence_type & FLUENCE_DUAL_MIC &&
1044 my_data->fluence_in_spkr_mode) {
1045 snd_device = SND_DEVICE_IN_SPEAKER_DMIC_AEC_NS;
1046 adev->acdb_settings |= DMIC_FLAG;
1047 } else
1048 snd_device = SND_DEVICE_IN_SPEAKER_MIC_AEC_NS;
Eric Laurentb23d5282013-05-14 15:27:20 -07001049 } else if (in_device & AUDIO_DEVICE_IN_BUILTIN_MIC) {
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -08001050 if (my_data->fluence_type & FLUENCE_DUAL_MIC) {
1051 snd_device = SND_DEVICE_IN_HANDSET_DMIC_AEC_NS;
1052 adev->acdb_settings |= DMIC_FLAG;
1053 } else
1054 snd_device = SND_DEVICE_IN_HANDSET_MIC_AEC_NS;
Eric Laurentb23d5282013-05-14 15:27:20 -07001055 } else if (in_device & AUDIO_DEVICE_IN_WIRED_HEADSET) {
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -08001056 snd_device = SND_DEVICE_IN_HEADSET_MIC_FLUENCE;
Eric Laurentb23d5282013-05-14 15:27:20 -07001057 }
1058 set_echo_reference(adev->mixer, "SLIM_RX");
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -08001059 } else if (adev->active_input->enable_aec) {
1060 if (in_device & AUDIO_DEVICE_IN_BACK_MIC) {
1061 if (my_data->fluence_type & FLUENCE_DUAL_MIC) {
1062 snd_device = SND_DEVICE_IN_SPEAKER_DMIC_AEC;
1063 adev->acdb_settings |= DMIC_FLAG;
1064 } else
1065 snd_device = SND_DEVICE_IN_SPEAKER_MIC_AEC;
1066 } else if (in_device & AUDIO_DEVICE_IN_BUILTIN_MIC) {
1067 if (my_data->fluence_type & FLUENCE_DUAL_MIC) {
1068 snd_device = SND_DEVICE_IN_HANDSET_DMIC_AEC;
1069 adev->acdb_settings |= DMIC_FLAG;
1070 } else
1071 snd_device = SND_DEVICE_IN_HANDSET_MIC_AEC;
1072 } else if (in_device & AUDIO_DEVICE_IN_WIRED_HEADSET) {
1073 snd_device = SND_DEVICE_IN_HEADSET_MIC_FLUENCE;
1074 }
1075 set_echo_reference(adev->mixer, "SLIM_RX");
1076 } else if (adev->active_input->enable_ns) {
1077 if (in_device & AUDIO_DEVICE_IN_BACK_MIC) {
1078 if (my_data->fluence_type & FLUENCE_DUAL_MIC) {
1079 snd_device = SND_DEVICE_IN_SPEAKER_DMIC_NS;
1080 adev->acdb_settings |= DMIC_FLAG;
1081 } else
1082 snd_device = SND_DEVICE_IN_SPEAKER_MIC_NS;
1083 } else if (in_device & AUDIO_DEVICE_IN_BUILTIN_MIC) {
1084 if (my_data->fluence_type & FLUENCE_DUAL_MIC) {
1085 snd_device = SND_DEVICE_IN_HANDSET_DMIC_NS;
1086 adev->acdb_settings |= DMIC_FLAG;
1087 } else
1088 snd_device = SND_DEVICE_IN_HANDSET_MIC_NS;
1089 } else if (in_device & AUDIO_DEVICE_IN_WIRED_HEADSET) {
1090 snd_device = SND_DEVICE_IN_HEADSET_MIC_FLUENCE;
1091 }
1092 set_echo_reference(adev->mixer, "NONE");
Eric Laurentb23d5282013-05-14 15:27:20 -07001093 } else
1094 set_echo_reference(adev->mixer, "NONE");
1095 }
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -08001096 } else if (source == AUDIO_SOURCE_MIC) {
Apoorv Raghuvanshic0536542013-11-14 16:25:59 -08001097 if (in_device & AUDIO_DEVICE_IN_BUILTIN_MIC &&
1098 channel_count == 1 ) {
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -08001099 if(my_data->fluence_type & FLUENCE_DUAL_MIC &&
1100 my_data->fluence_in_audio_rec)
1101 snd_device = SND_DEVICE_IN_HANDSET_DMIC;
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -08001102 }
Mingming Yinab429782013-11-07 11:16:55 -08001103 } else if (source == AUDIO_SOURCE_FM_RX ||
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -08001104 source == AUDIO_SOURCE_FM_RX_A2DP) {
Preetam Singh Ranawatde84f1a2013-11-01 14:58:16 -07001105 snd_device = SND_DEVICE_IN_CAPTURE_FM;
Eric Laurentb23d5282013-05-14 15:27:20 -07001106 } else if (source == AUDIO_SOURCE_DEFAULT) {
1107 goto exit;
1108 }
1109
1110
1111 if (snd_device != SND_DEVICE_NONE) {
1112 goto exit;
1113 }
1114
1115 if (in_device != AUDIO_DEVICE_NONE &&
1116 !(in_device & AUDIO_DEVICE_IN_VOICE_CALL) &&
1117 !(in_device & AUDIO_DEVICE_IN_COMMUNICATION)) {
1118 if (in_device & AUDIO_DEVICE_IN_BUILTIN_MIC) {
Apoorv Raghuvanshi6178a3f2013-10-19 12:38:54 -07001119 if (audio_extn_ssr_get_enabled() && channel_count == 6)
1120 snd_device = SND_DEVICE_IN_QUAD_MIC;
Ravi Kumar Alamandafae42112013-11-07 23:31:54 -08001121 else if (channel_count == 2)
Apoorv Raghuvanshi6bd8dbf2013-10-19 18:37:52 -07001122 snd_device = SND_DEVICE_IN_HANDSET_STEREO_DMIC;
Apoorv Raghuvanshi6178a3f2013-10-19 12:38:54 -07001123 else
1124 snd_device = SND_DEVICE_IN_HANDSET_MIC;
Eric Laurentb23d5282013-05-14 15:27:20 -07001125 } else if (in_device & AUDIO_DEVICE_IN_BACK_MIC) {
1126 snd_device = SND_DEVICE_IN_SPEAKER_MIC;
1127 } else if (in_device & AUDIO_DEVICE_IN_WIRED_HEADSET) {
1128 snd_device = SND_DEVICE_IN_HEADSET_MIC;
1129 } else if (in_device & AUDIO_DEVICE_IN_BLUETOOTH_SCO_HEADSET) {
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001130 if (my_data->btsco_sample_rate == SAMPLE_RATE_16KHZ)
1131 snd_device = SND_DEVICE_IN_BT_SCO_MIC_WB;
1132 else
1133 snd_device = SND_DEVICE_IN_BT_SCO_MIC;
Eric Laurentb23d5282013-05-14 15:27:20 -07001134 } else if (in_device & AUDIO_DEVICE_IN_AUX_DIGITAL) {
1135 snd_device = SND_DEVICE_IN_HDMI_MIC;
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -07001136 } else if (in_device & AUDIO_DEVICE_IN_ANLG_DOCK_HEADSET ||
1137 in_device & AUDIO_DEVICE_IN_DGTL_DOCK_HEADSET) {
1138 snd_device = SND_DEVICE_IN_USB_HEADSET_MIC;
Apoorv Raghuvanshi6e262842013-10-06 14:39:35 -07001139 } else if (in_device & AUDIO_DEVICE_IN_FM_RX) {
1140 snd_device = SND_DEVICE_IN_CAPTURE_FM;
Eric Laurentb23d5282013-05-14 15:27:20 -07001141 } else {
1142 ALOGE("%s: Unknown input device(s) %#x", __func__, in_device);
1143 ALOGW("%s: Using default handset-mic", __func__);
1144 snd_device = SND_DEVICE_IN_HANDSET_MIC;
1145 }
1146 } else {
1147 if (out_device & AUDIO_DEVICE_OUT_EARPIECE) {
1148 snd_device = SND_DEVICE_IN_HANDSET_MIC;
1149 } else if (out_device & AUDIO_DEVICE_OUT_WIRED_HEADSET) {
1150 snd_device = SND_DEVICE_IN_HEADSET_MIC;
1151 } else if (out_device & AUDIO_DEVICE_OUT_SPEAKER) {
Apoorv Raghuvanshi6bd8dbf2013-10-19 18:37:52 -07001152 if (channel_count > 1)
1153 snd_device = SND_DEVICE_IN_SPEAKER_STEREO_DMIC;
1154 else
1155 snd_device = SND_DEVICE_IN_SPEAKER_MIC;
Eric Laurentb23d5282013-05-14 15:27:20 -07001156 } else if (out_device & AUDIO_DEVICE_OUT_WIRED_HEADPHONE) {
1157 snd_device = SND_DEVICE_IN_HANDSET_MIC;
1158 } else if (out_device & AUDIO_DEVICE_OUT_BLUETOOTH_SCO_HEADSET) {
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001159 if (my_data->btsco_sample_rate == SAMPLE_RATE_16KHZ)
1160 snd_device = SND_DEVICE_IN_BT_SCO_MIC_WB;
1161 else
1162 snd_device = SND_DEVICE_IN_BT_SCO_MIC;
Eric Laurentb23d5282013-05-14 15:27:20 -07001163 } else if (out_device & AUDIO_DEVICE_OUT_AUX_DIGITAL) {
1164 snd_device = SND_DEVICE_IN_HDMI_MIC;
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -07001165 } else if (out_device & AUDIO_DEVICE_OUT_ANLG_DOCK_HEADSET ||
1166 out_device & AUDIO_DEVICE_OUT_DGTL_DOCK_HEADSET) {
1167 snd_device = SND_DEVICE_IN_USB_HEADSET_MIC;
Eric Laurentb23d5282013-05-14 15:27:20 -07001168 } else {
1169 ALOGE("%s: Unknown output device(s) %#x", __func__, out_device);
1170 ALOGW("%s: Using default handset-mic", __func__);
1171 snd_device = SND_DEVICE_IN_HANDSET_MIC;
1172 }
1173 }
1174exit:
1175 ALOGV("%s: exit: in_snd_device(%s)", __func__, device_table[snd_device]);
1176 return snd_device;
1177}
1178
1179int platform_set_hdmi_channels(void *platform, int channel_count)
1180{
1181 struct platform_data *my_data = (struct platform_data *)platform;
1182 struct audio_device *adev = my_data->adev;
1183 struct mixer_ctl *ctl;
1184 const char *channel_cnt_str = NULL;
1185 const char *mixer_ctl_name = "HDMI_RX Channels";
1186 switch (channel_count) {
1187 case 8:
1188 channel_cnt_str = "Eight"; break;
1189 case 7:
1190 channel_cnt_str = "Seven"; break;
1191 case 6:
1192 channel_cnt_str = "Six"; break;
1193 case 5:
1194 channel_cnt_str = "Five"; break;
1195 case 4:
1196 channel_cnt_str = "Four"; break;
1197 case 3:
1198 channel_cnt_str = "Three"; break;
1199 default:
1200 channel_cnt_str = "Two"; break;
1201 }
1202 ctl = mixer_get_ctl_by_name(adev->mixer, mixer_ctl_name);
1203 if (!ctl) {
1204 ALOGE("%s: Could not get ctl for mixer cmd - %s",
1205 __func__, mixer_ctl_name);
1206 return -EINVAL;
1207 }
1208 ALOGV("HDMI channel count: %s", channel_cnt_str);
1209 mixer_ctl_set_enum_by_string(ctl, channel_cnt_str);
1210 return 0;
1211}
1212
Haynes Mathew George47cd4cb2013-07-19 11:58:50 -07001213int platform_edid_get_max_channels(void *platform)
Eric Laurentb23d5282013-05-14 15:27:20 -07001214{
Haynes Mathew George47cd4cb2013-07-19 11:58:50 -07001215 struct platform_data *my_data = (struct platform_data *)platform;
1216 struct audio_device *adev = my_data->adev;
Eric Laurentb23d5282013-05-14 15:27:20 -07001217 char block[MAX_SAD_BLOCKS * SAD_BLOCK_SIZE];
1218 char *sad = block;
1219 int num_audio_blocks;
1220 int channel_count;
1221 int max_channels = 0;
Haynes Mathew George47cd4cb2013-07-19 11:58:50 -07001222 int i, ret, count;
Eric Laurentb23d5282013-05-14 15:27:20 -07001223
Haynes Mathew George47cd4cb2013-07-19 11:58:50 -07001224 struct mixer_ctl *ctl;
1225
1226 ctl = mixer_get_ctl_by_name(adev->mixer, AUDIO_DATA_BLOCK_MIXER_CTL);
1227 if (!ctl) {
1228 ALOGE("%s: Could not get ctl for mixer cmd - %s",
1229 __func__, AUDIO_DATA_BLOCK_MIXER_CTL);
Eric Laurentb23d5282013-05-14 15:27:20 -07001230 return 0;
1231 }
1232
Haynes Mathew George47cd4cb2013-07-19 11:58:50 -07001233 mixer_ctl_update(ctl);
1234
1235 count = mixer_ctl_get_num_values(ctl);
Eric Laurentb23d5282013-05-14 15:27:20 -07001236
1237 /* Read SAD blocks, clamping the maximum size for safety */
Haynes Mathew George47cd4cb2013-07-19 11:58:50 -07001238 if (count > (int)sizeof(block))
1239 count = (int)sizeof(block);
Eric Laurentb23d5282013-05-14 15:27:20 -07001240
Haynes Mathew George47cd4cb2013-07-19 11:58:50 -07001241 ret = mixer_ctl_get_array(ctl, block, count);
1242 if (ret != 0) {
1243 ALOGE("%s: mixer_ctl_get_array() failed to get EDID info", __func__);
1244 return 0;
1245 }
Eric Laurentb23d5282013-05-14 15:27:20 -07001246
1247 /* Calculate the number of SAD blocks */
Haynes Mathew George47cd4cb2013-07-19 11:58:50 -07001248 num_audio_blocks = count / SAD_BLOCK_SIZE;
Eric Laurentb23d5282013-05-14 15:27:20 -07001249
1250 for (i = 0; i < num_audio_blocks; i++) {
1251 /* Only consider LPCM blocks */
Haynes Mathew George47cd4cb2013-07-19 11:58:50 -07001252 if ((sad[0] >> 3) != EDID_FORMAT_LPCM) {
1253 sad += 3;
Eric Laurentb23d5282013-05-14 15:27:20 -07001254 continue;
Haynes Mathew George47cd4cb2013-07-19 11:58:50 -07001255 }
Eric Laurentb23d5282013-05-14 15:27:20 -07001256
1257 channel_count = (sad[0] & 0x7) + 1;
1258 if (channel_count > max_channels)
1259 max_channels = channel_count;
1260
1261 /* Advance to next block */
1262 sad += 3;
1263 }
1264
1265 return max_channels;
1266}
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001267
1268static int platform_set_slowtalk(struct platform_data *my_data, bool state)
1269{
1270 int ret = 0;
1271 struct audio_device *adev = my_data->adev;
1272 struct mixer_ctl *ctl;
1273 const char *mixer_ctl_name = "Slowtalk Enable";
1274 uint32_t set_values[ ] = {0,
1275 ALL_SESSION_VSID};
1276
1277 set_values[0] = state;
1278 ctl = mixer_get_ctl_by_name(adev->mixer, mixer_ctl_name);
1279 if (!ctl) {
1280 ALOGE("%s: Could not get ctl for mixer cmd - %s",
1281 __func__, mixer_ctl_name);
1282 ret = -EINVAL;
1283 } else {
1284 ALOGV("Setting slowtalk state: %d", state);
1285 ret = mixer_ctl_set_array(ctl, set_values, ARRAY_SIZE(set_values));
1286 my_data->slowtalk = state;
1287 }
1288
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -08001289 if (my_data->csd != NULL) {
1290 ret = my_data->csd->slow_talk(ALL_SESSION_VSID, state);
1291 if (ret < 0) {
1292 ALOGE("%s: csd_client_disable_device, failed, error %d",
1293 __func__, ret);
1294 }
1295 }
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001296 return ret;
1297}
1298
1299int platform_set_parameters(void *platform, struct str_parms *parms)
1300{
1301 struct platform_data *my_data = (struct platform_data *)platform;
1302 char *str;
1303 char value[32];
1304 int val;
1305 int ret = 0;
1306
1307 ALOGV("%s: enter: %s", __func__, str_parms_to_str(parms));
1308
1309 ret = str_parms_get_int(parms, AUDIO_PARAMETER_KEY_BTSCO, &val);
1310 if (ret >= 0) {
1311 str_parms_del(parms, AUDIO_PARAMETER_KEY_BTSCO);
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001312 my_data->btsco_sample_rate = val;
Vidyakumar Athota67c42712013-12-04 14:03:06 -08001313 if (val == SAMPLE_RATE_16KHZ) {
1314 audio_route_apply_path(my_data->adev->audio_route,
1315 "bt-sco-wb-samplerate");
1316 audio_route_update_mixer(my_data->adev->audio_route);
1317 }
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001318 }
1319
1320 ret = str_parms_get_int(parms, AUDIO_PARAMETER_KEY_SLOWTALK, &val);
1321 if (ret >= 0) {
1322 str_parms_del(parms, AUDIO_PARAMETER_KEY_SLOWTALK);
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001323 ret = platform_set_slowtalk(my_data, val);
1324 if (ret)
1325 ALOGE("%s: Failed to set slow talk err: %d", __func__, ret);
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001326 }
1327
1328 ALOGV("%s: exit with code(%d)", __func__, ret);
1329 return ret;
1330}
1331
Vidyakumar Athota2850d532013-11-19 16:02:12 -08001332int platform_set_incall_recording_session_id(void *platform,
1333 uint32_t session_id, int rec_mode)
Shiv Maliyappanahallida107642013-10-17 11:16:13 -07001334{
1335 int ret = 0;
1336 struct platform_data *my_data = (struct platform_data *)platform;
1337 struct audio_device *adev = my_data->adev;
1338 struct mixer_ctl *ctl;
1339 const char *mixer_ctl_name = "Voc VSID";
1340 int num_ctl_values;
1341 int i;
1342
1343 ctl = mixer_get_ctl_by_name(adev->mixer, mixer_ctl_name);
1344 if (!ctl) {
1345 ALOGE("%s: Could not get ctl for mixer cmd - %s",
1346 __func__, mixer_ctl_name);
1347 ret = -EINVAL;
1348 } else {
1349 num_ctl_values = mixer_ctl_get_num_values(ctl);
1350 for (i = 0; i < num_ctl_values; i++) {
1351 if (mixer_ctl_set_value(ctl, i, session_id)) {
1352 ALOGV("Error: invalid session_id: %x", session_id);
1353 ret = -EINVAL;
1354 break;
1355 }
1356 }
1357 }
1358
Vidyakumar Athota2850d532013-11-19 16:02:12 -08001359 if (my_data->csd != NULL) {
1360 ret = my_data->csd->start_record(ALL_SESSION_VSID, rec_mode);
1361 if (ret < 0) {
1362 ALOGE("%s: csd_client_start_record failed, error %d",
1363 __func__, ret);
1364 }
1365 }
1366
1367 return ret;
1368}
1369
1370int platform_stop_incall_recording_usecase(void *platform)
1371{
1372 int ret = 0;
1373 struct platform_data *my_data = (struct platform_data *)platform;
1374
1375 if (my_data->csd != NULL) {
1376 ret = my_data->csd->stop_record(ALL_SESSION_VSID);
1377 if (ret < 0) {
1378 ALOGE("%s: csd_client_stop_record failed, error %d",
1379 __func__, ret);
1380 }
1381 }
1382
1383 return ret;
1384}
1385
1386int platform_start_incall_music_usecase(void *platform)
1387{
1388 int ret = 0;
1389 struct platform_data *my_data = (struct platform_data *)platform;
1390
1391 if (my_data->csd != NULL) {
1392 ret = my_data->csd->start_playback(ALL_SESSION_VSID);
1393 if (ret < 0) {
1394 ALOGE("%s: csd_client_start_playback failed, error %d",
1395 __func__, ret);
1396 }
1397 }
1398
1399 return ret;
1400}
1401
1402int platform_stop_incall_music_usecase(void *platform)
1403{
1404 int ret = 0;
1405 struct platform_data *my_data = (struct platform_data *)platform;
1406
1407 if (my_data->csd != NULL) {
1408 ret = my_data->csd->stop_playback(ALL_SESSION_VSID);
1409 if (ret < 0) {
1410 ALOGE("%s: csd_client_stop_playback failed, error %d",
1411 __func__, ret);
1412 }
1413 }
1414
Shiv Maliyappanahallida107642013-10-17 11:16:13 -07001415 return ret;
1416}
1417
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001418void platform_get_parameters(void *platform,
1419 struct str_parms *query,
1420 struct str_parms *reply)
1421{
1422 struct platform_data *my_data = (struct platform_data *)platform;
1423 char *str = NULL;
1424 char value[256] = {0};
1425 int ret;
1426 int fluence_type;
1427
1428 ret = str_parms_get_str(query, AUDIO_PARAMETER_KEY_FLUENCE_TYPE,
1429 value, sizeof(value));
1430 if (ret >= 0) {
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -08001431 if (my_data->fluence_type & FLUENCE_QUAD_MIC) {
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001432 strlcpy(value, "fluencepro", sizeof(value));
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -08001433 } else if (my_data->fluence_type & FLUENCE_DUAL_MIC) {
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001434 strlcpy(value, "fluence", sizeof(value));
1435 } else {
1436 strlcpy(value, "none", sizeof(value));
1437 }
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001438
1439 str_parms_add_str(reply, AUDIO_PARAMETER_KEY_FLUENCE_TYPE, value);
1440 }
1441
Shiv Maliyappanahalli9d899292013-11-20 14:43:01 -08001442 memset(value, 0, sizeof(value));
1443 ret = str_parms_get_str(query, AUDIO_PARAMETER_KEY_SLOWTALK,
1444 value, sizeof(value));
1445 if (ret >= 0) {
1446 str_parms_add_int(reply, AUDIO_PARAMETER_KEY_SLOWTALK,
1447 my_data->slowtalk);
1448 }
1449
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001450 ALOGV("%s: exit: returns - %s", __func__, str_parms_to_str(reply));
1451}
1452
Haynes Mathew George7ff216f2013-09-11 19:51:41 -07001453/* Delay in Us */
1454int64_t platform_render_latency(audio_usecase_t usecase)
1455{
1456 switch (usecase) {
1457 case USECASE_AUDIO_PLAYBACK_DEEP_BUFFER:
1458 return DEEP_BUFFER_PLATFORM_DELAY;
1459 case USECASE_AUDIO_PLAYBACK_LOW_LATENCY:
1460 return LOW_LATENCY_PLATFORM_DELAY;
1461 default:
1462 return 0;
1463 }
1464}
Preetam Singh Ranawatde84f1a2013-11-01 14:58:16 -07001465
Mingming Yine62d7842013-10-25 16:26:03 -07001466int platform_update_usecase_from_source(int source, int usecase)
Preetam Singh Ranawatde84f1a2013-11-01 14:58:16 -07001467{
Mingming Yinab429782013-11-07 11:16:55 -08001468 ALOGV("%s: input source :%d", __func__, source);
1469 if(source == AUDIO_SOURCE_FM_RX_A2DP)
Mingming Yine62d7842013-10-25 16:26:03 -07001470 usecase = USECASE_AUDIO_RECORD_FM_VIRTUAL;
1471 return usecase;
Preetam Singh Ranawatde84f1a2013-11-01 14:58:16 -07001472}
Kiran Kandide144c82013-11-20 15:58:32 -08001473
1474bool platform_listen_update_status(snd_device_t snd_device)
1475{
1476 if ((snd_device >= SND_DEVICE_IN_BEGIN) &&
1477 (snd_device < SND_DEVICE_IN_END) &&
1478 (snd_device != SND_DEVICE_IN_CAPTURE_FM) &&
1479 (snd_device != SND_DEVICE_IN_CAPTURE_VI_FEEDBACK))
1480 return true;
1481 else
1482 return false;
1483}