blob: 4c218360264613f2d180aae99eb9bb748b6018c4 [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
Apoorv Raghuvanshi84fa2fe2013-12-04 11:57:47 -080056#define MAX_SND_CARD 8
sangwoo1b9f4b32013-06-21 18:22:55 -070057
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -070058#define SAMPLE_RATE_8KHZ 8000
59#define SAMPLE_RATE_16KHZ 16000
60
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -070061#define AUDIO_PARAMETER_KEY_FLUENCE_TYPE "fluence"
62#define AUDIO_PARAMETER_KEY_BTSCO "bt_samplerate"
63#define AUDIO_PARAMETER_KEY_SLOWTALK "st_enable"
sangwoo53b2cf02013-07-25 19:18:44 -070064
Eric Laurentb23d5282013-05-14 15:27:20 -070065struct audio_block_header
66{
67 int reserved;
68 int length;
69};
70
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -080071/* Audio calibration related functions */
Eric Laurentb23d5282013-05-14 15:27:20 -070072typedef void (*acdb_deallocate_t)();
73typedef int (*acdb_init_t)();
74typedef void (*acdb_send_audio_cal_t)(int, int);
75typedef void (*acdb_send_voice_cal_t)(int, int);
76
Eric Laurentb23d5282013-05-14 15:27:20 -070077struct platform_data {
78 struct audio_device *adev;
79 bool fluence_in_spkr_mode;
80 bool fluence_in_voice_call;
81 bool fluence_in_voice_rec;
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -080082 bool fluence_in_audio_rec;
Mingming Yin8e5a4f62013-10-07 15:23:41 -070083 int fluence_type;
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -070084 int btsco_sample_rate;
85 bool slowtalk;
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -070086 /* Audio calibration related functions */
Eric Laurentb23d5282013-05-14 15:27:20 -070087 void *acdb_handle;
88 acdb_init_t acdb_init;
89 acdb_deallocate_t acdb_deallocate;
90 acdb_send_audio_cal_t acdb_send_audio_cal;
91 acdb_send_voice_cal_t acdb_send_voice_cal;
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -070092
93 void *hw_info;
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -080094 struct csd_data *csd;
Eric Laurentb23d5282013-05-14 15:27:20 -070095};
96
97static const int pcm_device_table[AUDIO_USECASE_MAX][2] = {
Mingming Yin8e5a4f62013-10-07 15:23:41 -070098 [USECASE_AUDIO_PLAYBACK_DEEP_BUFFER] = {DEEP_BUFFER_PCM_DEVICE,
99 DEEP_BUFFER_PCM_DEVICE},
100 [USECASE_AUDIO_PLAYBACK_LOW_LATENCY] = {LOWLATENCY_PCM_DEVICE,
Preetam Singh Ranawatde84f1a2013-11-01 14:58:16 -0700101 LOWLATENCY_PCM_DEVICE},
102 [USECASE_AUDIO_PLAYBACK_MULTI_CH] = {MULTIMEDIA2_PCM_DEVICE,
103 MULTIMEDIA2_PCM_DEVICE},
Krishnankutty Kolathappillya43f96e2013-11-01 12:17:53 -0700104 [USECASE_AUDIO_PLAYBACK_OFFLOAD] =
105 {PLAYBACK_OFFLOAD_DEVICE, PLAYBACK_OFFLOAD_DEVICE},
Shiv Maliyappanahallida107642013-10-17 11:16:13 -0700106 [USECASE_AUDIO_RECORD] = {AUDIO_RECORD_PCM_DEVICE, AUDIO_RECORD_PCM_DEVICE},
Mingming Yine62d7842013-10-25 16:26:03 -0700107 [USECASE_AUDIO_RECORD_COMPRESS] = {COMPRESS_CAPTURE_DEVICE, COMPRESS_CAPTURE_DEVICE},
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700108 [USECASE_AUDIO_RECORD_LOW_LATENCY] = {LOWLATENCY_PCM_DEVICE,
109 LOWLATENCY_PCM_DEVICE},
Preetam Singh Ranawatde84f1a2013-11-01 14:58:16 -0700110 [USECASE_AUDIO_RECORD_FM_VIRTUAL] = {MULTIMEDIA2_PCM_DEVICE,
111 MULTIMEDIA2_PCM_DEVICE},
Apoorv Raghuvanshi6e262842013-10-06 14:39:35 -0700112 [USECASE_AUDIO_PLAYBACK_FM] = {FM_PLAYBACK_PCM_DEVICE, FM_CAPTURE_PCM_DEVICE},
Vimal Puthanveed5b4d3f12013-11-05 15:57:39 -0800113 [USECASE_AUDIO_HFP_SCO] = {HFP_PCM_RX, HFP_SCO_RX},
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700114 [USECASE_VOICE_CALL] = {VOICE_CALL_PCM_DEVICE, VOICE_CALL_PCM_DEVICE},
115 [USECASE_VOICE2_CALL] = {VOICE2_CALL_PCM_DEVICE, VOICE2_CALL_PCM_DEVICE},
116 [USECASE_VOLTE_CALL] = {VOLTE_CALL_PCM_DEVICE, VOLTE_CALL_PCM_DEVICE},
117 [USECASE_QCHAT_CALL] = {QCHAT_CALL_PCM_DEVICE, QCHAT_CALL_PCM_DEVICE},
Narsinga Rao Chella05573b72013-11-15 15:21:40 -0800118 [USECASE_COMPRESS_VOIP_CALL] = {COMPRESS_VOIP_CALL_PCM_DEVICE, COMPRESS_VOIP_CALL_PCM_DEVICE},
Shiv Maliyappanahallida107642013-10-17 11:16:13 -0700119 [USECASE_INCALL_REC_UPLINK] = {AUDIO_RECORD_PCM_DEVICE,
120 AUDIO_RECORD_PCM_DEVICE},
121 [USECASE_INCALL_REC_DOWNLINK] = {AUDIO_RECORD_PCM_DEVICE,
122 AUDIO_RECORD_PCM_DEVICE},
123 [USECASE_INCALL_REC_UPLINK_AND_DOWNLINK] = {AUDIO_RECORD_PCM_DEVICE,
124 AUDIO_RECORD_PCM_DEVICE},
Helen Zenge56b4852013-12-03 16:54:40 -0800125 [USECASE_INCALL_REC_UPLINK_COMPRESS] = {COMPRESS_CAPTURE_DEVICE,
126 COMPRESS_CAPTURE_DEVICE},
127 [USECASE_INCALL_REC_DOWNLINK_COMPRESS] = {COMPRESS_CAPTURE_DEVICE,
128 COMPRESS_CAPTURE_DEVICE},
129 [USECASE_INCALL_REC_UPLINK_AND_DOWNLINK_COMPRESS] = {COMPRESS_CAPTURE_DEVICE,
130 COMPRESS_CAPTURE_DEVICE},
Shiv Maliyappanahallif3b9a422013-10-22 16:38:08 -0700131 [USECASE_INCALL_MUSIC_UPLINK] = {INCALL_MUSIC_UPLINK_PCM_DEVICE,
132 INCALL_MUSIC_UPLINK_PCM_DEVICE},
133 [USECASE_INCALL_MUSIC_UPLINK2] = {INCALL_MUSIC_UPLINK2_PCM_DEVICE,
134 INCALL_MUSIC_UPLINK2_PCM_DEVICE},
Gopikrishnaiah Anandanf538cef2013-10-28 14:06:03 -0700135 [USECASE_AUDIO_SPKR_CALIB_RX] = {SPKR_PROT_CALIB_RX_PCM_DEVICE, -1},
136 [USECASE_AUDIO_SPKR_CALIB_TX] = {-1, SPKR_PROT_CALIB_TX_PCM_DEVICE},
Eric Laurentb23d5282013-05-14 15:27:20 -0700137};
138
139/* Array to store sound devices */
140static const char * const device_table[SND_DEVICE_MAX] = {
141 [SND_DEVICE_NONE] = "none",
142 /* Playback sound devices */
143 [SND_DEVICE_OUT_HANDSET] = "handset",
144 [SND_DEVICE_OUT_SPEAKER] = "speaker",
145 [SND_DEVICE_OUT_SPEAKER_REVERSE] = "speaker-reverse",
146 [SND_DEVICE_OUT_HEADPHONES] = "headphones",
147 [SND_DEVICE_OUT_SPEAKER_AND_HEADPHONES] = "speaker-and-headphones",
148 [SND_DEVICE_OUT_VOICE_HANDSET] = "voice-handset",
149 [SND_DEVICE_OUT_VOICE_SPEAKER] = "voice-speaker",
150 [SND_DEVICE_OUT_VOICE_HEADPHONES] = "voice-headphones",
151 [SND_DEVICE_OUT_HDMI] = "hdmi",
152 [SND_DEVICE_OUT_SPEAKER_AND_HDMI] = "speaker-and-hdmi",
153 [SND_DEVICE_OUT_BT_SCO] = "bt-sco-headset",
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700154 [SND_DEVICE_OUT_BT_SCO_WB] = "bt-sco-headset-wb",
Eric Laurentb23d5282013-05-14 15:27:20 -0700155 [SND_DEVICE_OUT_VOICE_TTY_FULL_HEADPHONES] = "voice-tty-full-headphones",
156 [SND_DEVICE_OUT_VOICE_TTY_VCO_HEADPHONES] = "voice-tty-vco-headphones",
157 [SND_DEVICE_OUT_VOICE_TTY_HCO_HANDSET] = "voice-tty-hco-handset",
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -0700158 [SND_DEVICE_OUT_AFE_PROXY] = "afe-proxy",
159 [SND_DEVICE_OUT_USB_HEADSET] = "usb-headphones",
160 [SND_DEVICE_OUT_SPEAKER_AND_USB_HEADSET] = "speaker-and-usb-headphones",
Apoorv Raghuvanshi6e262842013-10-06 14:39:35 -0700161 [SND_DEVICE_OUT_TRANSMISSION_FM] = "transmission-fm",
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -0700162 [SND_DEVICE_OUT_ANC_HEADSET] = "anc-headphones",
163 [SND_DEVICE_OUT_ANC_FB_HEADSET] = "anc-fb-headphones",
164 [SND_DEVICE_OUT_VOICE_ANC_HEADSET] = "voice-anc-headphones",
165 [SND_DEVICE_OUT_VOICE_ANC_FB_HEADSET] = "voice-anc-fb-headphones",
166 [SND_DEVICE_OUT_SPEAKER_AND_ANC_HEADSET] = "speaker-and-anc-headphones",
167 [SND_DEVICE_OUT_ANC_HANDSET] = "anc-handset",
Gopikrishnaiah Anandanf538cef2013-10-28 14:06:03 -0700168 [SND_DEVICE_OUT_SPEAKER_PROTECTED] = "speaker-protected",
Eric Laurentb23d5282013-05-14 15:27:20 -0700169
170 /* Capture sound devices */
171 [SND_DEVICE_IN_HANDSET_MIC] = "handset-mic",
Eric Laurentb23d5282013-05-14 15:27:20 -0700172 [SND_DEVICE_IN_HANDSET_MIC_AEC] = "handset-mic",
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -0800173 [SND_DEVICE_IN_HANDSET_MIC_NS] = "handset-mic",
174 [SND_DEVICE_IN_HANDSET_MIC_AEC_NS] = "handset-mic",
175 [SND_DEVICE_IN_HANDSET_DMIC] = "dmic-endfire",
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800176 [SND_DEVICE_IN_HANDSET_DMIC_AEC] = "dmic-endfire",
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -0800177 [SND_DEVICE_IN_HANDSET_DMIC_NS] = "dmic-endfire",
178 [SND_DEVICE_IN_HANDSET_DMIC_AEC_NS] = "dmic-endfire",
179 [SND_DEVICE_IN_SPEAKER_MIC] = "speaker-mic",
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800180 [SND_DEVICE_IN_SPEAKER_MIC_AEC] = "speaker-mic",
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -0800181 [SND_DEVICE_IN_SPEAKER_MIC_NS] = "speaker-mic",
182 [SND_DEVICE_IN_SPEAKER_MIC_AEC_NS] = "speaker-mic",
183 [SND_DEVICE_IN_SPEAKER_DMIC] = "speaker-dmic-endfire",
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800184 [SND_DEVICE_IN_SPEAKER_DMIC_AEC] = "speaker-dmic-endfire",
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -0800185 [SND_DEVICE_IN_SPEAKER_DMIC_NS] = "speaker-dmic-endfire",
186 [SND_DEVICE_IN_SPEAKER_DMIC_AEC_NS] = "speaker-dmic-endfire",
187 [SND_DEVICE_IN_HEADSET_MIC] = "headset-mic",
188 [SND_DEVICE_IN_HEADSET_MIC_FLUENCE] = "headset-mic",
Eric Laurentb23d5282013-05-14 15:27:20 -0700189 [SND_DEVICE_IN_VOICE_SPEAKER_MIC] = "voice-speaker-mic",
190 [SND_DEVICE_IN_VOICE_HEADSET_MIC] = "voice-headset-mic",
191 [SND_DEVICE_IN_HDMI_MIC] = "hdmi-mic",
192 [SND_DEVICE_IN_BT_SCO_MIC] = "bt-sco-mic",
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700193 [SND_DEVICE_IN_BT_SCO_MIC_WB] = "bt-sco-mic-wb",
Eric Laurentb23d5282013-05-14 15:27:20 -0700194 [SND_DEVICE_IN_CAMCORDER_MIC] = "camcorder-mic",
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700195 [SND_DEVICE_IN_VOICE_DMIC] = "voice-dmic-ef",
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700196 [SND_DEVICE_IN_VOICE_SPEAKER_DMIC] = "voice-speaker-dmic-ef",
Eric Laurentb23d5282013-05-14 15:27:20 -0700197 [SND_DEVICE_IN_VOICE_TTY_FULL_HEADSET_MIC] = "voice-tty-full-headset-mic",
198 [SND_DEVICE_IN_VOICE_TTY_VCO_HANDSET_MIC] = "voice-tty-vco-handset-mic",
199 [SND_DEVICE_IN_VOICE_TTY_HCO_HEADSET_MIC] = "voice-tty-hco-headset-mic",
200 [SND_DEVICE_IN_VOICE_REC_MIC] = "voice-rec-mic",
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -0800201 [SND_DEVICE_IN_VOICE_REC_MIC_NS] = "voice-rec-mic",
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800202 [SND_DEVICE_IN_VOICE_REC_DMIC_STEREO] = "voice-rec-dmic-ef",
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700203 [SND_DEVICE_IN_VOICE_REC_DMIC_FLUENCE] = "voice-rec-dmic-ef-fluence",
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -0700204 [SND_DEVICE_IN_USB_HEADSET_MIC] = "usb-headset-mic",
Apoorv Raghuvanshi6e262842013-10-06 14:39:35 -0700205 [SND_DEVICE_IN_CAPTURE_FM] = "capture-fm",
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -0700206 [SND_DEVICE_IN_AANC_HANDSET_MIC] = "aanc-handset-mic",
Apoorv Raghuvanshi6178a3f2013-10-19 12:38:54 -0700207 [SND_DEVICE_IN_QUAD_MIC] = "quad-mic",
Apoorv Raghuvanshi6bd8dbf2013-10-19 18:37:52 -0700208 [SND_DEVICE_IN_HANDSET_STEREO_DMIC] = "handset-stereo-dmic-ef",
209 [SND_DEVICE_IN_SPEAKER_STEREO_DMIC] = "speaker-stereo-dmic-ef",
Gopikrishnaiah Anandanf538cef2013-10-28 14:06:03 -0700210 [SND_DEVICE_IN_CAPTURE_VI_FEEDBACK] = "vi-feedback",
Eric Laurentb23d5282013-05-14 15:27:20 -0700211};
212
213/* ACDB IDs (audio DSP path configuration IDs) for each sound device */
214static const int acdb_device_table[SND_DEVICE_MAX] = {
215 [SND_DEVICE_NONE] = -1,
216 [SND_DEVICE_OUT_HANDSET] = 7,
Vidyakumar Athotac29d4ab2013-11-14 16:58:02 -0800217 [SND_DEVICE_OUT_SPEAKER] = 14,
218 [SND_DEVICE_OUT_SPEAKER_REVERSE] = 14,
Eric Laurentb23d5282013-05-14 15:27:20 -0700219 [SND_DEVICE_OUT_HEADPHONES] = 10,
220 [SND_DEVICE_OUT_SPEAKER_AND_HEADPHONES] = 10,
221 [SND_DEVICE_OUT_VOICE_HANDSET] = 7,
Vidyakumar Athotac29d4ab2013-11-14 16:58:02 -0800222 [SND_DEVICE_OUT_VOICE_SPEAKER] = 14,
Eric Laurentb23d5282013-05-14 15:27:20 -0700223 [SND_DEVICE_OUT_VOICE_HEADPHONES] = 10,
224 [SND_DEVICE_OUT_HDMI] = 18,
Vidyakumar Athotac29d4ab2013-11-14 16:58:02 -0800225 [SND_DEVICE_OUT_SPEAKER_AND_HDMI] = 14,
Eric Laurentb23d5282013-05-14 15:27:20 -0700226 [SND_DEVICE_OUT_BT_SCO] = 22,
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700227 [SND_DEVICE_OUT_BT_SCO_WB] = 39,
Eric Laurentb23d5282013-05-14 15:27:20 -0700228 [SND_DEVICE_OUT_VOICE_TTY_FULL_HEADPHONES] = 17,
229 [SND_DEVICE_OUT_VOICE_TTY_VCO_HEADPHONES] = 17,
230 [SND_DEVICE_OUT_VOICE_TTY_HCO_HANDSET] = 37,
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -0700231 [SND_DEVICE_OUT_AFE_PROXY] = 0,
232 [SND_DEVICE_OUT_USB_HEADSET] = 0,
233 [SND_DEVICE_OUT_SPEAKER_AND_USB_HEADSET] = 14,
Apoorv Raghuvanshi6e262842013-10-06 14:39:35 -0700234 [SND_DEVICE_OUT_TRANSMISSION_FM] = 0,
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -0700235 [SND_DEVICE_OUT_ANC_HEADSET] = 26,
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700236 [SND_DEVICE_OUT_ANC_FB_HEADSET] = 27,
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -0700237 [SND_DEVICE_OUT_VOICE_ANC_HEADSET] = 26,
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700238 [SND_DEVICE_OUT_VOICE_ANC_FB_HEADSET] = 27,
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -0700239 [SND_DEVICE_OUT_SPEAKER_AND_ANC_HEADSET] = 26,
240 [SND_DEVICE_OUT_ANC_HANDSET] = 103,
Gopikrishnaiah Anandanf538cef2013-10-28 14:06:03 -0700241 [SND_DEVICE_OUT_SPEAKER_PROTECTED] = 101,
Eric Laurentb23d5282013-05-14 15:27:20 -0700242
243 [SND_DEVICE_IN_HANDSET_MIC] = 4,
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -0800244 [SND_DEVICE_IN_HANDSET_MIC_AEC] = 106,
245 [SND_DEVICE_IN_HANDSET_MIC_NS] = 107,
246 [SND_DEVICE_IN_HANDSET_MIC_AEC_NS] = 108,
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800247 [SND_DEVICE_IN_HANDSET_DMIC] = 41,
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -0800248 [SND_DEVICE_IN_HANDSET_DMIC_AEC] = 109,
249 [SND_DEVICE_IN_HANDSET_DMIC_NS] = 110,
250 [SND_DEVICE_IN_HANDSET_DMIC_AEC_NS] = 111,
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800251 [SND_DEVICE_IN_SPEAKER_MIC] = 11,
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -0800252 [SND_DEVICE_IN_SPEAKER_MIC_AEC] = 112,
253 [SND_DEVICE_IN_SPEAKER_MIC_NS] = 113,
254 [SND_DEVICE_IN_SPEAKER_MIC_AEC_NS] = 114,
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800255 [SND_DEVICE_IN_SPEAKER_DMIC] = 43,
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -0800256 [SND_DEVICE_IN_SPEAKER_DMIC_AEC] = 115,
257 [SND_DEVICE_IN_SPEAKER_DMIC_NS] = 116,
258 [SND_DEVICE_IN_SPEAKER_DMIC_AEC_NS] = 117,
Eric Laurentb23d5282013-05-14 15:27:20 -0700259 [SND_DEVICE_IN_HEADSET_MIC] = 8,
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -0800260 [SND_DEVICE_IN_HEADSET_MIC_FLUENCE] = 47,
Eric Laurentb23d5282013-05-14 15:27:20 -0700261 [SND_DEVICE_IN_VOICE_SPEAKER_MIC] = 11,
262 [SND_DEVICE_IN_VOICE_HEADSET_MIC] = 8,
263 [SND_DEVICE_IN_HDMI_MIC] = 4,
264 [SND_DEVICE_IN_BT_SCO_MIC] = 21,
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700265 [SND_DEVICE_IN_BT_SCO_MIC_WB] = 38,
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800266 [SND_DEVICE_IN_CAMCORDER_MIC] = 4,
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700267 [SND_DEVICE_IN_VOICE_DMIC] = 41,
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700268 [SND_DEVICE_IN_VOICE_SPEAKER_DMIC] = 43,
Eric Laurentb23d5282013-05-14 15:27:20 -0700269 [SND_DEVICE_IN_VOICE_TTY_FULL_HEADSET_MIC] = 16,
270 [SND_DEVICE_IN_VOICE_TTY_VCO_HANDSET_MIC] = 36,
271 [SND_DEVICE_IN_VOICE_TTY_HCO_HEADSET_MIC] = 16,
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800272 [SND_DEVICE_IN_VOICE_REC_MIC] = 4,
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -0800273 [SND_DEVICE_IN_VOICE_REC_MIC_NS] = 107,
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800274 [SND_DEVICE_IN_VOICE_REC_DMIC_STEREO] = 34,
275 [SND_DEVICE_IN_VOICE_REC_DMIC_FLUENCE] = 41,
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -0700276 [SND_DEVICE_IN_USB_HEADSET_MIC] = 44,
Apoorv Raghuvanshi6e262842013-10-06 14:39:35 -0700277 [SND_DEVICE_IN_CAPTURE_FM] = 0,
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -0700278 [SND_DEVICE_IN_AANC_HANDSET_MIC] = 104,
Apoorv Raghuvanshi6178a3f2013-10-19 12:38:54 -0700279 [SND_DEVICE_IN_QUAD_MIC] = 46,
Apoorv Raghuvanshi6bd8dbf2013-10-19 18:37:52 -0700280 [SND_DEVICE_IN_HANDSET_STEREO_DMIC] = 34,
281 [SND_DEVICE_IN_SPEAKER_STEREO_DMIC] = 35,
Gopikrishnaiah Anandanf538cef2013-10-28 14:06:03 -0700282 [SND_DEVICE_IN_CAPTURE_VI_FEEDBACK] = 102,
Eric Laurentb23d5282013-05-14 15:27:20 -0700283};
284
Haynes Mathew George7ff216f2013-09-11 19:51:41 -0700285#define DEEP_BUFFER_PLATFORM_DELAY (29*1000LL)
286#define LOW_LATENCY_PLATFORM_DELAY (13*1000LL)
287
Eric Laurentb23d5282013-05-14 15:27:20 -0700288static int set_echo_reference(struct mixer *mixer, const char* ec_ref)
289{
290 struct mixer_ctl *ctl;
291 const char *mixer_ctl_name = "EC_REF_RX";
292
293 ctl = mixer_get_ctl_by_name(mixer, mixer_ctl_name);
294 if (!ctl) {
295 ALOGE("%s: Could not get ctl for mixer cmd - %s",
296 __func__, mixer_ctl_name);
297 return -EINVAL;
298 }
299 ALOGV("Setting EC Reference: %s", ec_ref);
300 mixer_ctl_set_enum_by_string(ctl, ec_ref);
301 return 0;
302}
303
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800304static struct csd_data *open_csd_client()
305{
306 struct csd_data *csd = calloc(1, sizeof(struct csd_data));
307
308 csd->csd_client = dlopen(LIB_CSD_CLIENT, RTLD_NOW);
309 if (csd->csd_client == NULL) {
310 ALOGE("%s: DLOPEN failed for %s", __func__, LIB_CSD_CLIENT);
311 goto error;
312 } else {
313 ALOGV("%s: DLOPEN successful for %s", __func__, LIB_CSD_CLIENT);
314
315 csd->deinit = (deinit_t)dlsym(csd->csd_client,
316 "csd_client_deinit");
317 if (csd->deinit == NULL) {
318 ALOGE("%s: dlsym error %s for csd_client_deinit", __func__,
319 dlerror());
320 goto error;
321 }
322 csd->disable_device = (disable_device_t)dlsym(csd->csd_client,
323 "csd_client_disable_device");
324 if (csd->disable_device == NULL) {
325 ALOGE("%s: dlsym error %s for csd_client_disable_device",
326 __func__, dlerror());
327 goto error;
328 }
329 csd->enable_device = (enable_device_t)dlsym(csd->csd_client,
330 "csd_client_enable_device");
331 if (csd->enable_device == NULL) {
332 ALOGE("%s: dlsym error %s for csd_client_enable_device",
333 __func__, dlerror());
334 goto error;
335 }
336 csd->start_voice = (start_voice_t)dlsym(csd->csd_client,
337 "csd_client_start_voice");
338 if (csd->start_voice == NULL) {
339 ALOGE("%s: dlsym error %s for csd_client_start_voice",
340 __func__, dlerror());
341 goto error;
342 }
343 csd->stop_voice = (stop_voice_t)dlsym(csd->csd_client,
344 "csd_client_stop_voice");
345 if (csd->stop_voice == NULL) {
346 ALOGE("%s: dlsym error %s for csd_client_stop_voice",
347 __func__, dlerror());
348 goto error;
349 }
350 csd->volume = (volume_t)dlsym(csd->csd_client,
351 "csd_client_volume");
352 if (csd->volume == NULL) {
353 ALOGE("%s: dlsym error %s for csd_client_volume",
354 __func__, dlerror());
355 goto error;
356 }
357 csd->mic_mute = (mic_mute_t)dlsym(csd->csd_client,
358 "csd_client_mic_mute");
359 if (csd->mic_mute == NULL) {
360 ALOGE("%s: dlsym error %s for csd_client_mic_mute",
361 __func__, dlerror());
362 goto error;
363 }
364 csd->slow_talk = (slow_talk_t)dlsym(csd->csd_client,
365 "csd_client_slow_talk");
366 if (csd->slow_talk == NULL) {
367 ALOGE("%s: dlsym error %s for csd_client_slow_talk",
368 __func__, dlerror());
369 goto error;
370 }
371 csd->start_playback = (start_playback_t)dlsym(csd->csd_client,
372 "csd_client_start_playback");
373 if (csd->start_playback == NULL) {
374 ALOGE("%s: dlsym error %s for csd_client_start_playback",
375 __func__, dlerror());
376 goto error;
377 }
378 csd->stop_playback = (stop_playback_t)dlsym(csd->csd_client,
379 "csd_client_stop_playback");
380 if (csd->stop_playback == NULL) {
381 ALOGE("%s: dlsym error %s for csd_client_stop_playback",
382 __func__, dlerror());
383 goto error;
384 }
385 csd->start_record = (start_record_t)dlsym(csd->csd_client,
386 "csd_client_start_record");
387 if (csd->start_record == NULL) {
388 ALOGE("%s: dlsym error %s for csd_client_start_record",
389 __func__, dlerror());
390 goto error;
391 }
392 csd->stop_record = (stop_record_t)dlsym(csd->csd_client,
393 "csd_client_stop_record");
394 if (csd->stop_record == NULL) {
395 ALOGE("%s: dlsym error %s for csd_client_stop_record",
396 __func__, dlerror());
397 goto error;
398 }
399 csd->init = (init_t)dlsym(csd->csd_client, "csd_client_init");
400
401 if (csd->init == NULL) {
402 ALOGE("%s: dlsym error %s for csd_client_init",
403 __func__, dlerror());
404 goto error;
405 } else {
406 csd->init();
407 }
408 }
409 return csd;
410
411error:
412 free(csd);
413 csd = NULL;
414 return csd;
415}
416
417void close_csd_client(struct csd_data *csd)
418{
419 if (csd != NULL) {
420 csd->deinit();
421 dlclose(csd->csd_client);
422 free(csd);
423 csd = NULL;
424 }
425}
426
Eric Laurentb23d5282013-05-14 15:27:20 -0700427void *platform_init(struct audio_device *adev)
428{
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800429 char platform[PROPERTY_VALUE_MAX];
430 char baseband[PROPERTY_VALUE_MAX];
Eric Laurentb23d5282013-05-14 15:27:20 -0700431 char value[PROPERTY_VALUE_MAX];
Apoorv Raghuvanshi84fa2fe2013-12-04 11:57:47 -0800432 struct platform_data *my_data = NULL;
433 int retry_num = 0, snd_card_num = 0;
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700434 const char *snd_card_name;
sangwoo1b9f4b32013-06-21 18:22:55 -0700435
Eric Laurentb23d5282013-05-14 15:27:20 -0700436 my_data = calloc(1, sizeof(struct platform_data));
437
Apoorv Raghuvanshi84fa2fe2013-12-04 11:57:47 -0800438 while (snd_card_num < MAX_SND_CARD) {
439 adev->mixer = mixer_open(snd_card_num);
440
441 while (!adev->mixer && retry_num < RETRY_NUMBER) {
442 usleep(RETRY_US);
443 adev->mixer = mixer_open(snd_card_num);
444 retry_num++;
445 }
446
447 if (!adev->mixer) {
448 ALOGE("%s: Unable to open the mixer card: %d", __func__,
449 snd_card_num);
450 retry_num = 0;
451 snd_card_num++;
452 continue;
453 }
454
455 snd_card_name = mixer_get_name(adev->mixer);
456 ALOGV("%s: snd_card_name: %s", __func__, snd_card_name);
457
458 my_data->hw_info = hw_info_init(snd_card_name);
459 if (!my_data->hw_info) {
460 ALOGE("%s: Failed to init hardware info", __func__);
461 } else {
462 if (audio_extn_read_xml(adev, snd_card_num, MIXER_XML_PATH,
463 MIXER_XML_PATH_AUXPCM) == -ENOSYS)
464 adev->audio_route = audio_route_init(snd_card_num,
465 MIXER_XML_PATH);
466 if (!adev->audio_route) {
467 ALOGE("%s: Failed to init audio route controls, aborting.",
468 __func__);
469 free(my_data);
470 return NULL;
471 }
472 adev->snd_card = snd_card_num;
473 ALOGD("%s: Opened sound card:%d", __func__, snd_card_num);
474 break;
475 }
476 retry_num = 0;
477 snd_card_num++;
478 }
479
480 if (snd_card_num >= MAX_SND_CARD) {
481 ALOGE("%s: Unable to find correct sound card, aborting.", __func__);
482 free(my_data);
483 return NULL;
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700484 }
485
Eric Laurentb23d5282013-05-14 15:27:20 -0700486 my_data->adev = adev;
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700487 my_data->btsco_sample_rate = SAMPLE_RATE_8KHZ;
Eric Laurentb23d5282013-05-14 15:27:20 -0700488 my_data->fluence_in_spkr_mode = false;
489 my_data->fluence_in_voice_call = false;
490 my_data->fluence_in_voice_rec = false;
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800491 my_data->fluence_in_audio_rec = false;
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700492 my_data->fluence_type = FLUENCE_NONE;
Eric Laurentb23d5282013-05-14 15:27:20 -0700493
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700494 property_get("ro.qc.sdk.audio.fluencetype", value, "");
495 if (!strncmp("fluencepro", value, sizeof("fluencepro"))) {
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800496 my_data->fluence_type = FLUENCE_QUAD_MIC | FLUENCE_DUAL_MIC;
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700497 } else if (!strncmp("fluence", value, sizeof("fluence"))) {
498 my_data->fluence_type = FLUENCE_DUAL_MIC;
499 } else {
500 my_data->fluence_type = FLUENCE_NONE;
Eric Laurentb23d5282013-05-14 15:27:20 -0700501 }
502
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700503 if (my_data->fluence_type != FLUENCE_NONE) {
Eric Laurentb23d5282013-05-14 15:27:20 -0700504 property_get("persist.audio.fluence.voicecall",value,"");
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700505 if (!strncmp("true", value, sizeof("true"))) {
Eric Laurentb23d5282013-05-14 15:27:20 -0700506 my_data->fluence_in_voice_call = true;
507 }
508
509 property_get("persist.audio.fluence.voicerec",value,"");
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700510 if (!strncmp("true", value, sizeof("true"))) {
Eric Laurentb23d5282013-05-14 15:27:20 -0700511 my_data->fluence_in_voice_rec = true;
512 }
513
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800514 property_get("persist.audio.fluence.audiorec",value,"");
515 if (!strncmp("true", value, sizeof("true"))) {
516 my_data->fluence_in_audio_rec = true;
517 }
518
Eric Laurentb23d5282013-05-14 15:27:20 -0700519 property_get("persist.audio.fluence.speaker",value,"");
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700520 if (!strncmp("true", value, sizeof("true"))) {
Eric Laurentb23d5282013-05-14 15:27:20 -0700521 my_data->fluence_in_spkr_mode = true;
522 }
523 }
524
525 my_data->acdb_handle = dlopen(LIB_ACDB_LOADER, RTLD_NOW);
526 if (my_data->acdb_handle == NULL) {
527 ALOGE("%s: DLOPEN failed for %s", __func__, LIB_ACDB_LOADER);
528 } else {
529 ALOGV("%s: DLOPEN successful for %s", __func__, LIB_ACDB_LOADER);
530 my_data->acdb_deallocate = (acdb_deallocate_t)dlsym(my_data->acdb_handle,
531 "acdb_loader_deallocate_ACDB");
532 my_data->acdb_send_audio_cal = (acdb_send_audio_cal_t)dlsym(my_data->acdb_handle,
533 "acdb_loader_send_audio_cal");
534 if (!my_data->acdb_send_audio_cal)
535 ALOGW("%s: Could not find the symbol acdb_send_audio_cal from %s",
536 __func__, LIB_ACDB_LOADER);
537 my_data->acdb_send_voice_cal = (acdb_send_voice_cal_t)dlsym(my_data->acdb_handle,
538 "acdb_loader_send_voice_cal");
539 my_data->acdb_init = (acdb_init_t)dlsym(my_data->acdb_handle,
540 "acdb_loader_init_ACDB");
541 if (my_data->acdb_init == NULL)
542 ALOGE("%s: dlsym error %s for acdb_loader_init_ACDB", __func__, dlerror());
543 else
544 my_data->acdb_init();
545 }
546
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800547 /* If platform is apq8084 and baseband is MDM, load CSD Client specific
548 * symbols. Voice call is handled by MDM and apps processor talks to
549 * MDM through CSD Client
550 */
551 property_get("ro.board.platform", platform, "");
552 property_get("ro.baseband", baseband, "");
553 if (!strncmp("apq8084", platform, sizeof("apq8084")) &&
554 !strncmp("mdm", baseband, sizeof("mdm"))) {
555 my_data->csd = open_csd_client();
556 }
557
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -0700558 /* init usb */
559 audio_extn_usb_init(adev);
Apoorv Raghuvanshi84fa2fe2013-12-04 11:57:47 -0800560 /* update sound cards appropriately */
561 audio_extn_usb_set_proxy_sound_card(adev->snd_card);
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -0700562
Apoorv Raghuvanshi6178a3f2013-10-19 12:38:54 -0700563 /* Read one time ssr property */
564 audio_extn_ssr_update_enabled(adev);
Gopikrishnaiah Anandanf538cef2013-10-28 14:06:03 -0700565 audio_extn_spkr_prot_init(adev);
Eric Laurentb23d5282013-05-14 15:27:20 -0700566 return my_data;
567}
568
569void platform_deinit(void *platform)
570{
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700571 struct platform_data *my_data = (struct platform_data *)platform;
572
573 hw_info_deinit(my_data->hw_info);
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800574 close_csd_client(my_data->csd);
575
Eric Laurentb23d5282013-05-14 15:27:20 -0700576 free(platform);
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -0700577 /* deinit usb */
578 audio_extn_usb_deinit();
Eric Laurentb23d5282013-05-14 15:27:20 -0700579}
580
581const char *platform_get_snd_device_name(snd_device_t snd_device)
582{
583 if (snd_device >= SND_DEVICE_MIN && snd_device < SND_DEVICE_MAX)
584 return device_table[snd_device];
585 else
586 return "";
587}
588
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700589int platform_get_snd_device_name_extn(void *platform, snd_device_t snd_device,
590 char *device_name)
591{
592 struct platform_data *my_data = (struct platform_data *)platform;
593
594 if (snd_device >= SND_DEVICE_MIN && snd_device < SND_DEVICE_MAX) {
595 strlcpy(device_name, device_table[snd_device], DEVICE_NAME_MAX_SIZE);
596 hw_info_append_hw_type(my_data->hw_info, snd_device, device_name);
597 } else {
598 strlcpy(device_name, "", DEVICE_NAME_MAX_SIZE);
599 return -EINVAL;
600 }
601
602 return 0;
603}
604
Eric Laurentb23d5282013-05-14 15:27:20 -0700605void platform_add_backend_name(char *mixer_path, snd_device_t snd_device)
606{
607 if (snd_device == SND_DEVICE_IN_BT_SCO_MIC)
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700608 strlcat(mixer_path, " bt-sco", MIXER_PATH_MAX_LENGTH);
609 else if (snd_device == SND_DEVICE_IN_BT_SCO_MIC_WB)
610 strlcat(mixer_path, " bt-sco-wb", MIXER_PATH_MAX_LENGTH);
Eric Laurentb23d5282013-05-14 15:27:20 -0700611 else if(snd_device == SND_DEVICE_OUT_BT_SCO)
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700612 strlcat(mixer_path, " bt-sco", MIXER_PATH_MAX_LENGTH);
613 else if(snd_device == SND_DEVICE_OUT_BT_SCO_WB)
614 strlcat(mixer_path, " bt-sco-wb", MIXER_PATH_MAX_LENGTH);
Eric Laurentb23d5282013-05-14 15:27:20 -0700615 else if (snd_device == SND_DEVICE_OUT_HDMI)
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700616 strlcat(mixer_path, " hdmi", MIXER_PATH_MAX_LENGTH);
Eric Laurentb23d5282013-05-14 15:27:20 -0700617 else if (snd_device == SND_DEVICE_OUT_SPEAKER_AND_HDMI)
618 strcat(mixer_path, " speaker-and-hdmi");
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -0700619 else if (snd_device == SND_DEVICE_OUT_AFE_PROXY)
620 strlcat(mixer_path, " afe-proxy", MIXER_PATH_MAX_LENGTH);
621 else if (snd_device == SND_DEVICE_OUT_USB_HEADSET)
622 strlcat(mixer_path, " usb-headphones", MIXER_PATH_MAX_LENGTH);
623 else if (snd_device == SND_DEVICE_OUT_SPEAKER_AND_USB_HEADSET)
624 strlcat(mixer_path, " speaker-and-usb-headphones",
625 MIXER_PATH_MAX_LENGTH);
626 else if (snd_device == SND_DEVICE_IN_USB_HEADSET_MIC)
627 strlcat(mixer_path, " usb-headset-mic", MIXER_PATH_MAX_LENGTH);
Apoorv Raghuvanshi6e262842013-10-06 14:39:35 -0700628 else if (snd_device == SND_DEVICE_IN_CAPTURE_FM)
629 strlcat(mixer_path, " capture-fm", MIXER_PATH_MAX_LENGTH);
630 else if (snd_device == SND_DEVICE_OUT_TRANSMISSION_FM)
631 strlcat(mixer_path, " transmission-fm", MIXER_PATH_MAX_LENGTH);
Eric Laurentb23d5282013-05-14 15:27:20 -0700632}
633
634int platform_get_pcm_device_id(audio_usecase_t usecase, int device_type)
635{
636 int device_id;
637 if (device_type == PCM_PLAYBACK)
638 device_id = pcm_device_table[usecase][0];
639 else
640 device_id = pcm_device_table[usecase][1];
641 return device_id;
642}
643
644int platform_send_audio_calibration(void *platform, snd_device_t snd_device)
645{
646 struct platform_data *my_data = (struct platform_data *)platform;
647 int acdb_dev_id, acdb_dev_type;
648
649 acdb_dev_id = acdb_device_table[snd_device];
650 if (acdb_dev_id < 0) {
651 ALOGE("%s: Could not find acdb id for device(%d)",
652 __func__, snd_device);
653 return -EINVAL;
654 }
655 if (my_data->acdb_send_audio_cal) {
Eric Laurent994a6932013-07-17 11:51:42 -0700656 ("%s: sending audio calibration for snd_device(%d) acdb_id(%d)",
Eric Laurentb23d5282013-05-14 15:27:20 -0700657 __func__, snd_device, acdb_dev_id);
658 if (snd_device >= SND_DEVICE_OUT_BEGIN &&
659 snd_device < SND_DEVICE_OUT_END)
660 acdb_dev_type = ACDB_DEV_TYPE_OUT;
661 else
662 acdb_dev_type = ACDB_DEV_TYPE_IN;
663 my_data->acdb_send_audio_cal(acdb_dev_id, acdb_dev_type);
664 }
665 return 0;
666}
667
668int platform_switch_voice_call_device_pre(void *platform)
669{
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800670 struct platform_data *my_data = (struct platform_data *)platform;
671 int ret = 0;
672
Vidyakumar Athota1fd21792013-11-15 14:50:57 -0800673 if (my_data->csd != NULL &&
674 my_data->adev->mode == AUDIO_MODE_IN_CALL) {
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800675 /* This must be called before disabling mixer controls on APQ side */
676 ret = my_data->csd->disable_device();
677 if (ret < 0) {
678 ALOGE("%s: csd_client_disable_device, failed, error %d",
679 __func__, ret);
680 }
681 }
682 return ret;
Eric Laurentb23d5282013-05-14 15:27:20 -0700683}
684
685int platform_switch_voice_call_device_post(void *platform,
686 snd_device_t out_snd_device,
687 snd_device_t in_snd_device)
688{
689 struct platform_data *my_data = (struct platform_data *)platform;
690 int acdb_rx_id, acdb_tx_id;
691
692 if (my_data->acdb_send_voice_cal == NULL) {
693 ALOGE("%s: dlsym error for acdb_send_voice_call", __func__);
694 } else {
Vidyakumar Athota1fd21792013-11-15 14:50:57 -0800695 acdb_rx_id = acdb_device_table[out_snd_device];
696 acdb_tx_id = acdb_device_table[in_snd_device];
697
Eric Laurentb23d5282013-05-14 15:27:20 -0700698 if (acdb_rx_id > 0 && acdb_tx_id > 0)
699 my_data->acdb_send_voice_cal(acdb_rx_id, acdb_tx_id);
700 else
701 ALOGE("%s: Incorrect ACDB IDs (rx: %d tx: %d)", __func__,
702 acdb_rx_id, acdb_tx_id);
703 }
704
Vidyakumar Athota1fd21792013-11-15 14:50:57 -0800705 return 0;
706}
707
708int platform_switch_voice_call_usecase_route_post(void *platform,
709 snd_device_t out_snd_device,
710 snd_device_t in_snd_device)
711{
712 struct platform_data *my_data = (struct platform_data *)platform;
713 int acdb_rx_id, acdb_tx_id;
714 int ret = 0;
715
716 acdb_rx_id = acdb_device_table[out_snd_device];
717 acdb_tx_id = acdb_device_table[in_snd_device];
718
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800719 if (my_data->csd != NULL) {
Vidyakumar Athota1fd21792013-11-15 14:50:57 -0800720 if (acdb_rx_id > 0 && acdb_tx_id > 0) {
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800721 ret = my_data->csd->enable_device(acdb_rx_id, acdb_tx_id,
722 my_data->adev->acdb_settings);
723 if (ret < 0) {
724 ALOGE("%s: csd_enable_device, failed, error %d",
725 __func__, ret);
726 }
727 } else {
728 ALOGE("%s: Incorrect ACDB IDs (rx: %d tx: %d)", __func__,
729 acdb_rx_id, acdb_tx_id);
730 }
731 }
732 return ret;
Eric Laurentb23d5282013-05-14 15:27:20 -0700733}
734
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800735int platform_start_voice_call(void *platform, uint32_t vsid)
Eric Laurentb23d5282013-05-14 15:27:20 -0700736{
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800737 struct platform_data *my_data = (struct platform_data *)platform;
738 int ret = 0;
739
740 if (my_data->csd != NULL) {
741 ret = my_data->csd->start_voice(vsid);
742 if (ret < 0) {
743 ALOGE("%s: csd_start_voice error %d\n", __func__, ret);
744 }
745 }
746 return ret;
Eric Laurentb23d5282013-05-14 15:27:20 -0700747}
748
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800749int platform_stop_voice_call(void *platform, uint32_t vsid)
Eric Laurentb23d5282013-05-14 15:27:20 -0700750{
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800751 struct platform_data *my_data = (struct platform_data *)platform;
752 int ret = 0;
753
754 if (my_data->csd != NULL) {
755 ret = my_data->csd->stop_voice(vsid);
756 if (ret < 0) {
757 ALOGE("%s: csd_stop_voice error %d\n", __func__, ret);
758 }
759 }
760 return ret;
Eric Laurentb23d5282013-05-14 15:27:20 -0700761}
762
763int platform_set_voice_volume(void *platform, int volume)
764{
765 struct platform_data *my_data = (struct platform_data *)platform;
766 struct audio_device *adev = my_data->adev;
767 struct mixer_ctl *ctl;
sangwoo53b2cf02013-07-25 19:18:44 -0700768 const char *mixer_ctl_name = "Voice Rx Gain";
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800769 int vol_index = 0, ret = 0;
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700770 uint32_t set_values[ ] = {0,
771 ALL_SESSION_VSID,
772 DEFAULT_VOLUME_RAMP_DURATION_MS};
Eric Laurentb23d5282013-05-14 15:27:20 -0700773
774 // Voice volume levels are mapped to adsp volume levels as follows.
775 // 100 -> 5, 80 -> 4, 60 -> 3, 40 -> 2, 20 -> 1 0 -> 0
776 // But this values don't changed in kernel. So, below change is need.
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700777 vol_index = (int)percent_to_index(volume, MIN_VOL_INDEX, MAX_VOL_INDEX);
778 set_values[0] = vol_index;
Eric Laurentb23d5282013-05-14 15:27:20 -0700779
780 ctl = mixer_get_ctl_by_name(adev->mixer, mixer_ctl_name);
781 if (!ctl) {
782 ALOGE("%s: Could not get ctl for mixer cmd - %s",
783 __func__, mixer_ctl_name);
784 return -EINVAL;
785 }
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700786 ALOGV("Setting voice volume index: %d", set_values[0]);
787 mixer_ctl_set_array(ctl, set_values, ARRAY_SIZE(set_values));
Eric Laurentb23d5282013-05-14 15:27:20 -0700788
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800789 if (my_data->csd != NULL) {
790 ret = my_data->csd->volume(ALL_SESSION_VSID, volume);
791 if (ret < 0) {
792 ALOGE("%s: csd_volume error %d", __func__, ret);
793 }
794 }
795 return ret;
Eric Laurentb23d5282013-05-14 15:27:20 -0700796}
797
798int platform_set_mic_mute(void *platform, bool state)
799{
800 struct platform_data *my_data = (struct platform_data *)platform;
801 struct audio_device *adev = my_data->adev;
802 struct mixer_ctl *ctl;
803 const char *mixer_ctl_name = "Voice Tx Mute";
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800804 int ret = 0;
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700805 uint32_t set_values[ ] = {0,
806 ALL_SESSION_VSID,
807 DEFAULT_VOLUME_RAMP_DURATION_MS};
Eric Laurentb23d5282013-05-14 15:27:20 -0700808
Narsinga Rao Chella05573b72013-11-15 15:21:40 -0800809 set_values[0] = state;
810 ctl = mixer_get_ctl_by_name(adev->mixer, mixer_ctl_name);
811 if (!ctl) {
812 ALOGE("%s: Could not get ctl for mixer cmd - %s",
813 __func__, mixer_ctl_name);
814 return -EINVAL;
815 }
816 ALOGV("Setting voice mute state: %d", state);
817 mixer_ctl_set_array(ctl, set_values, ARRAY_SIZE(set_values));
Eric Laurentb23d5282013-05-14 15:27:20 -0700818
Narsinga Rao Chella05573b72013-11-15 15:21:40 -0800819 if (my_data->csd != NULL) {
820 ret = my_data->csd->mic_mute(ALL_SESSION_VSID, state);
821 if (ret < 0) {
822 ALOGE("%s: csd_mic_mute error %d", __func__, ret);
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800823 }
824 }
825 return ret;
Eric Laurentb23d5282013-05-14 15:27:20 -0700826}
827
828snd_device_t platform_get_output_snd_device(void *platform, audio_devices_t devices)
829{
830 struct platform_data *my_data = (struct platform_data *)platform;
831 struct audio_device *adev = my_data->adev;
832 audio_mode_t mode = adev->mode;
833 snd_device_t snd_device = SND_DEVICE_NONE;
834
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -0700835 audio_channel_mask_t channel_mask = (adev->active_input == NULL) ?
836 AUDIO_CHANNEL_IN_MONO : adev->active_input->channel_mask;
837 int channel_count = popcount(channel_mask);
838
Eric Laurentb23d5282013-05-14 15:27:20 -0700839 ALOGV("%s: enter: output devices(%#x)", __func__, devices);
840 if (devices == AUDIO_DEVICE_NONE ||
841 devices & AUDIO_DEVICE_BIT_IN) {
842 ALOGV("%s: Invalid output devices (%#x)", __func__, devices);
843 goto exit;
844 }
845
Narsinga Rao Chella05573b72013-11-15 15:21:40 -0800846 if ((mode == AUDIO_MODE_IN_CALL) ||
847 voice_extn_compress_voip_is_active(adev)) {
Eric Laurentb23d5282013-05-14 15:27:20 -0700848 if (devices & AUDIO_DEVICE_OUT_WIRED_HEADPHONE ||
849 devices & AUDIO_DEVICE_OUT_WIRED_HEADSET) {
Narsinga Rao Chella05573b72013-11-15 15:21:40 -0800850 if ((adev->voice.tty_mode != TTY_MODE_OFF) &&
851 !voice_extn_compress_voip_is_active(adev)) {
852 switch (adev->voice.tty_mode) {
853 case TTY_MODE_FULL:
854 snd_device = SND_DEVICE_OUT_VOICE_TTY_FULL_HEADPHONES;
855 break;
856 case TTY_MODE_VCO:
857 snd_device = SND_DEVICE_OUT_VOICE_TTY_VCO_HEADPHONES;
858 break;
859 case TTY_MODE_HCO:
860 snd_device = SND_DEVICE_OUT_VOICE_TTY_HCO_HANDSET;
861 break;
862 default:
863 ALOGE("%s: Invalid TTY mode (%#x)",
864 __func__, adev->voice.tty_mode);
865 }
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700866 } else if (audio_extn_get_anc_enabled()) {
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -0700867 if (audio_extn_should_use_fb_anc())
868 snd_device = SND_DEVICE_OUT_VOICE_ANC_FB_HEADSET;
869 else
870 snd_device = SND_DEVICE_OUT_VOICE_ANC_HEADSET;
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700871 } else {
Eric Laurentb23d5282013-05-14 15:27:20 -0700872 snd_device = SND_DEVICE_OUT_VOICE_HEADPHONES;
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700873 }
Eric Laurentb23d5282013-05-14 15:27:20 -0700874 } else if (devices & AUDIO_DEVICE_OUT_ALL_SCO) {
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700875 if (my_data->btsco_sample_rate == SAMPLE_RATE_16KHZ)
876 snd_device = SND_DEVICE_OUT_BT_SCO_WB;
877 else
878 snd_device = SND_DEVICE_OUT_BT_SCO;
Eric Laurentb23d5282013-05-14 15:27:20 -0700879 } else if (devices & AUDIO_DEVICE_OUT_SPEAKER) {
880 snd_device = SND_DEVICE_OUT_VOICE_SPEAKER;
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -0700881 } else if (devices & AUDIO_DEVICE_OUT_ANLG_DOCK_HEADSET ||
882 devices & AUDIO_DEVICE_OUT_DGTL_DOCK_HEADSET) {
883 snd_device = SND_DEVICE_OUT_USB_HEADSET;
Apoorv Raghuvanshi6e262842013-10-06 14:39:35 -0700884 } else if (devices & AUDIO_DEVICE_OUT_FM_TX) {
885 snd_device = SND_DEVICE_OUT_TRANSMISSION_FM;
Eric Laurentb23d5282013-05-14 15:27:20 -0700886 } else if (devices & AUDIO_DEVICE_OUT_EARPIECE) {
Ravi Kumar Alamandaceb40822013-11-06 11:01:47 -0800887 if (audio_extn_should_use_handset_anc(channel_count))
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -0700888 snd_device = SND_DEVICE_OUT_ANC_HANDSET;
Eric Laurentb23d5282013-05-14 15:27:20 -0700889 else
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700890 snd_device = SND_DEVICE_OUT_VOICE_HANDSET;
Eric Laurentb23d5282013-05-14 15:27:20 -0700891 }
892 if (snd_device != SND_DEVICE_NONE) {
893 goto exit;
894 }
895 }
896
897 if (popcount(devices) == 2) {
898 if (devices == (AUDIO_DEVICE_OUT_WIRED_HEADPHONE |
899 AUDIO_DEVICE_OUT_SPEAKER)) {
900 snd_device = SND_DEVICE_OUT_SPEAKER_AND_HEADPHONES;
901 } else if (devices == (AUDIO_DEVICE_OUT_WIRED_HEADSET |
902 AUDIO_DEVICE_OUT_SPEAKER)) {
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -0700903 if (audio_extn_get_anc_enabled())
904 snd_device = SND_DEVICE_OUT_SPEAKER_AND_ANC_HEADSET;
905 else
906 snd_device = SND_DEVICE_OUT_SPEAKER_AND_HEADPHONES;
Eric Laurentb23d5282013-05-14 15:27:20 -0700907 } else if (devices == (AUDIO_DEVICE_OUT_AUX_DIGITAL |
908 AUDIO_DEVICE_OUT_SPEAKER)) {
909 snd_device = SND_DEVICE_OUT_SPEAKER_AND_HDMI;
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -0700910 } else if (devices == (AUDIO_DEVICE_OUT_ANLG_DOCK_HEADSET |
911 AUDIO_DEVICE_OUT_SPEAKER)) {
912 snd_device = SND_DEVICE_OUT_SPEAKER_AND_USB_HEADSET;
Eric Laurentb23d5282013-05-14 15:27:20 -0700913 } else {
914 ALOGE("%s: Invalid combo device(%#x)", __func__, devices);
915 goto exit;
916 }
917 if (snd_device != SND_DEVICE_NONE) {
918 goto exit;
919 }
920 }
921
922 if (popcount(devices) != 1) {
923 ALOGE("%s: Invalid output devices(%#x)", __func__, devices);
924 goto exit;
925 }
926
927 if (devices & AUDIO_DEVICE_OUT_WIRED_HEADPHONE ||
928 devices & AUDIO_DEVICE_OUT_WIRED_HEADSET) {
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -0700929 if (devices & AUDIO_DEVICE_OUT_WIRED_HEADSET
930 && audio_extn_get_anc_enabled()) {
931 if (audio_extn_should_use_fb_anc())
932 snd_device = SND_DEVICE_OUT_ANC_FB_HEADSET;
933 else
934 snd_device = SND_DEVICE_OUT_ANC_HEADSET;
935 }
936 else
937 snd_device = SND_DEVICE_OUT_HEADPHONES;
Eric Laurentb23d5282013-05-14 15:27:20 -0700938 } else if (devices & AUDIO_DEVICE_OUT_SPEAKER) {
939 if (adev->speaker_lr_swap)
940 snd_device = SND_DEVICE_OUT_SPEAKER_REVERSE;
941 else
942 snd_device = SND_DEVICE_OUT_SPEAKER;
943 } else if (devices & AUDIO_DEVICE_OUT_ALL_SCO) {
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700944 if (my_data->btsco_sample_rate == SAMPLE_RATE_16KHZ)
945 snd_device = SND_DEVICE_OUT_BT_SCO_WB;
946 else
947 snd_device = SND_DEVICE_OUT_BT_SCO;
Eric Laurentb23d5282013-05-14 15:27:20 -0700948 } else if (devices & AUDIO_DEVICE_OUT_AUX_DIGITAL) {
949 snd_device = SND_DEVICE_OUT_HDMI ;
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -0700950 } else if (devices & AUDIO_DEVICE_OUT_ANLG_DOCK_HEADSET ||
951 devices & AUDIO_DEVICE_OUT_DGTL_DOCK_HEADSET) {
952 snd_device = SND_DEVICE_OUT_USB_HEADSET;
Apoorv Raghuvanshi6e262842013-10-06 14:39:35 -0700953 } else if (devices & AUDIO_DEVICE_OUT_FM_TX) {
954 snd_device = SND_DEVICE_OUT_TRANSMISSION_FM;
Eric Laurentb23d5282013-05-14 15:27:20 -0700955 } else if (devices & AUDIO_DEVICE_OUT_EARPIECE) {
956 snd_device = SND_DEVICE_OUT_HANDSET;
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -0700957 } else if (devices & AUDIO_DEVICE_OUT_PROXY) {
958 ALOGD("%s: setting sink capability for Proxy", __func__);
959 audio_extn_set_afe_proxy_channel_mixer(adev);
960 snd_device = SND_DEVICE_OUT_AFE_PROXY;
Eric Laurentb23d5282013-05-14 15:27:20 -0700961 } else {
962 ALOGE("%s: Unknown device(s) %#x", __func__, devices);
963 }
964exit:
965 ALOGV("%s: exit: snd_device(%s)", __func__, device_table[snd_device]);
966 return snd_device;
967}
968
969snd_device_t platform_get_input_snd_device(void *platform, audio_devices_t out_device)
970{
971 struct platform_data *my_data = (struct platform_data *)platform;
972 struct audio_device *adev = my_data->adev;
973 audio_source_t source = (adev->active_input == NULL) ?
974 AUDIO_SOURCE_DEFAULT : adev->active_input->source;
975
976 audio_mode_t mode = adev->mode;
977 audio_devices_t in_device = ((adev->active_input == NULL) ?
978 AUDIO_DEVICE_NONE : adev->active_input->device)
979 & ~AUDIO_DEVICE_BIT_IN;
980 audio_channel_mask_t channel_mask = (adev->active_input == NULL) ?
981 AUDIO_CHANNEL_IN_MONO : adev->active_input->channel_mask;
982 snd_device_t snd_device = SND_DEVICE_NONE;
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -0700983 int channel_count = popcount(channel_mask);
Eric Laurentb23d5282013-05-14 15:27:20 -0700984
985 ALOGV("%s: enter: out_device(%#x) in_device(%#x)",
986 __func__, out_device, in_device);
Helen Zeng067b96b2013-11-26 12:10:29 -0800987 if ((out_device != AUDIO_DEVICE_NONE) && ((mode == AUDIO_MODE_IN_CALL) ||
988 voice_extn_compress_voip_is_active(adev))) {
Narsinga Rao Chella05573b72013-11-15 15:21:40 -0800989 if ((adev->voice.tty_mode != TTY_MODE_OFF) &&
990 !voice_extn_compress_voip_is_active(adev)) {
Eric Laurentb23d5282013-05-14 15:27:20 -0700991 if (out_device & AUDIO_DEVICE_OUT_WIRED_HEADPHONE ||
992 out_device & AUDIO_DEVICE_OUT_WIRED_HEADSET) {
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700993 switch (adev->voice.tty_mode) {
Eric Laurentb23d5282013-05-14 15:27:20 -0700994 case TTY_MODE_FULL:
995 snd_device = SND_DEVICE_IN_VOICE_TTY_FULL_HEADSET_MIC;
996 break;
997 case TTY_MODE_VCO:
998 snd_device = SND_DEVICE_IN_VOICE_TTY_VCO_HANDSET_MIC;
999 break;
1000 case TTY_MODE_HCO:
1001 snd_device = SND_DEVICE_IN_VOICE_TTY_HCO_HEADSET_MIC;
1002 break;
1003 default:
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001004 ALOGE("%s: Invalid TTY mode (%#x)",
1005 __func__, adev->voice.tty_mode);
Eric Laurentb23d5282013-05-14 15:27:20 -07001006 }
1007 goto exit;
1008 }
1009 }
1010 if (out_device & AUDIO_DEVICE_OUT_EARPIECE ||
1011 out_device & AUDIO_DEVICE_OUT_WIRED_HEADPHONE) {
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -07001012 if (out_device & AUDIO_DEVICE_OUT_EARPIECE &&
1013 audio_extn_should_use_handset_anc(channel_count)) {
1014 snd_device = SND_DEVICE_IN_AANC_HANDSET_MIC;
1015 } else if (my_data->fluence_type == FLUENCE_NONE ||
Mingming Yin8e5a4f62013-10-07 15:23:41 -07001016 my_data->fluence_in_voice_call == false) {
Eric Laurentb23d5282013-05-14 15:27:20 -07001017 snd_device = SND_DEVICE_IN_HANDSET_MIC;
Vimal Puthanveed5b4d3f12013-11-05 15:57:39 -08001018 set_echo_reference(adev->mixer, "SLIM_RX");
Eric Laurentb23d5282013-05-14 15:27:20 -07001019 } else {
Ravi Kumar Alamandaceb40822013-11-06 11:01:47 -08001020 snd_device = SND_DEVICE_IN_VOICE_DMIC;
Mingming Yin8e5a4f62013-10-07 15:23:41 -07001021 adev->acdb_settings |= DMIC_FLAG;
Eric Laurentb23d5282013-05-14 15:27:20 -07001022 }
1023 } else if (out_device & AUDIO_DEVICE_OUT_WIRED_HEADSET) {
1024 snd_device = SND_DEVICE_IN_VOICE_HEADSET_MIC;
1025 } else if (out_device & AUDIO_DEVICE_OUT_ALL_SCO) {
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001026 if (my_data->btsco_sample_rate == SAMPLE_RATE_16KHZ)
1027 snd_device = SND_DEVICE_IN_BT_SCO_MIC_WB;
1028 else
1029 snd_device = SND_DEVICE_IN_BT_SCO_MIC;
Eric Laurentb23d5282013-05-14 15:27:20 -07001030 } else if (out_device & AUDIO_DEVICE_OUT_SPEAKER) {
Mingming Yin8e5a4f62013-10-07 15:23:41 -07001031 if (my_data->fluence_type != FLUENCE_NONE &&
1032 my_data->fluence_in_voice_call &&
1033 my_data->fluence_in_spkr_mode) {
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -08001034 if(my_data->fluence_type & FLUENCE_QUAD_MIC) {
Mingming Yin8e5a4f62013-10-07 15:23:41 -07001035 adev->acdb_settings |= QMIC_FLAG;
1036 snd_device = SND_DEVICE_IN_VOICE_SPEAKER_QMIC;
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -08001037 } else {
1038 adev->acdb_settings |= DMIC_FLAG;
1039 snd_device = SND_DEVICE_IN_VOICE_SPEAKER_DMIC;
Mingming Yin8e5a4f62013-10-07 15:23:41 -07001040 }
Eric Laurentb23d5282013-05-14 15:27:20 -07001041 } else {
1042 snd_device = SND_DEVICE_IN_VOICE_SPEAKER_MIC;
1043 }
1044 }
1045 } else if (source == AUDIO_SOURCE_CAMCORDER) {
1046 if (in_device & AUDIO_DEVICE_IN_BUILTIN_MIC ||
1047 in_device & AUDIO_DEVICE_IN_BACK_MIC) {
1048 snd_device = SND_DEVICE_IN_CAMCORDER_MIC;
1049 }
1050 } else if (source == AUDIO_SOURCE_VOICE_RECOGNITION) {
1051 if (in_device & AUDIO_DEVICE_IN_BUILTIN_MIC) {
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -08001052 if (channel_count == 2) {
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -08001053 snd_device = SND_DEVICE_IN_VOICE_REC_DMIC_STEREO;
Mingming Yin8e5a4f62013-10-07 15:23:41 -07001054 adev->acdb_settings |= DMIC_FLAG;
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -08001055 } else if (adev->active_input->enable_ns)
1056 snd_device = SND_DEVICE_IN_VOICE_REC_MIC_NS;
1057 else if (my_data->fluence_type != FLUENCE_NONE &&
1058 my_data->fluence_in_voice_rec) {
1059 snd_device = SND_DEVICE_IN_VOICE_REC_DMIC_FLUENCE;
1060 adev->acdb_settings |= DMIC_FLAG;
1061 } else {
1062 snd_device = SND_DEVICE_IN_VOICE_REC_MIC;
1063 }
Eric Laurentb23d5282013-05-14 15:27:20 -07001064 }
1065 } else if (source == AUDIO_SOURCE_VOICE_COMMUNICATION) {
1066 if (out_device & AUDIO_DEVICE_OUT_SPEAKER)
1067 in_device = AUDIO_DEVICE_IN_BACK_MIC;
1068 if (adev->active_input) {
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -08001069 if (adev->active_input->enable_aec &&
1070 adev->active_input->enable_ns) {
Eric Laurentb23d5282013-05-14 15:27:20 -07001071 if (in_device & AUDIO_DEVICE_IN_BACK_MIC) {
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -08001072 if (my_data->fluence_type & FLUENCE_DUAL_MIC &&
1073 my_data->fluence_in_spkr_mode) {
1074 snd_device = SND_DEVICE_IN_SPEAKER_DMIC_AEC_NS;
1075 adev->acdb_settings |= DMIC_FLAG;
1076 } else
1077 snd_device = SND_DEVICE_IN_SPEAKER_MIC_AEC_NS;
Eric Laurentb23d5282013-05-14 15:27:20 -07001078 } else if (in_device & AUDIO_DEVICE_IN_BUILTIN_MIC) {
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -08001079 if (my_data->fluence_type & FLUENCE_DUAL_MIC) {
1080 snd_device = SND_DEVICE_IN_HANDSET_DMIC_AEC_NS;
1081 adev->acdb_settings |= DMIC_FLAG;
1082 } else
1083 snd_device = SND_DEVICE_IN_HANDSET_MIC_AEC_NS;
Eric Laurentb23d5282013-05-14 15:27:20 -07001084 } else if (in_device & AUDIO_DEVICE_IN_WIRED_HEADSET) {
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -08001085 snd_device = SND_DEVICE_IN_HEADSET_MIC_FLUENCE;
Eric Laurentb23d5282013-05-14 15:27:20 -07001086 }
1087 set_echo_reference(adev->mixer, "SLIM_RX");
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -08001088 } else if (adev->active_input->enable_aec) {
1089 if (in_device & AUDIO_DEVICE_IN_BACK_MIC) {
1090 if (my_data->fluence_type & FLUENCE_DUAL_MIC) {
1091 snd_device = SND_DEVICE_IN_SPEAKER_DMIC_AEC;
1092 adev->acdb_settings |= DMIC_FLAG;
1093 } else
1094 snd_device = SND_DEVICE_IN_SPEAKER_MIC_AEC;
1095 } else if (in_device & AUDIO_DEVICE_IN_BUILTIN_MIC) {
1096 if (my_data->fluence_type & FLUENCE_DUAL_MIC) {
1097 snd_device = SND_DEVICE_IN_HANDSET_DMIC_AEC;
1098 adev->acdb_settings |= DMIC_FLAG;
1099 } else
1100 snd_device = SND_DEVICE_IN_HANDSET_MIC_AEC;
1101 } else if (in_device & AUDIO_DEVICE_IN_WIRED_HEADSET) {
1102 snd_device = SND_DEVICE_IN_HEADSET_MIC_FLUENCE;
1103 }
1104 set_echo_reference(adev->mixer, "SLIM_RX");
1105 } else if (adev->active_input->enable_ns) {
1106 if (in_device & AUDIO_DEVICE_IN_BACK_MIC) {
1107 if (my_data->fluence_type & FLUENCE_DUAL_MIC) {
1108 snd_device = SND_DEVICE_IN_SPEAKER_DMIC_NS;
1109 adev->acdb_settings |= DMIC_FLAG;
1110 } else
1111 snd_device = SND_DEVICE_IN_SPEAKER_MIC_NS;
1112 } else if (in_device & AUDIO_DEVICE_IN_BUILTIN_MIC) {
1113 if (my_data->fluence_type & FLUENCE_DUAL_MIC) {
1114 snd_device = SND_DEVICE_IN_HANDSET_DMIC_NS;
1115 adev->acdb_settings |= DMIC_FLAG;
1116 } else
1117 snd_device = SND_DEVICE_IN_HANDSET_MIC_NS;
1118 } else if (in_device & AUDIO_DEVICE_IN_WIRED_HEADSET) {
1119 snd_device = SND_DEVICE_IN_HEADSET_MIC_FLUENCE;
1120 }
1121 set_echo_reference(adev->mixer, "NONE");
Eric Laurentb23d5282013-05-14 15:27:20 -07001122 } else
1123 set_echo_reference(adev->mixer, "NONE");
1124 }
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -08001125 } else if (source == AUDIO_SOURCE_MIC) {
Apoorv Raghuvanshic0536542013-11-14 16:25:59 -08001126 if (in_device & AUDIO_DEVICE_IN_BUILTIN_MIC &&
1127 channel_count == 1 ) {
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -08001128 if(my_data->fluence_type & FLUENCE_DUAL_MIC &&
1129 my_data->fluence_in_audio_rec)
1130 snd_device = SND_DEVICE_IN_HANDSET_DMIC;
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -08001131 }
Mingming Yinab429782013-11-07 11:16:55 -08001132 } else if (source == AUDIO_SOURCE_FM_RX ||
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -08001133 source == AUDIO_SOURCE_FM_RX_A2DP) {
Preetam Singh Ranawatde84f1a2013-11-01 14:58:16 -07001134 snd_device = SND_DEVICE_IN_CAPTURE_FM;
Eric Laurentb23d5282013-05-14 15:27:20 -07001135 } else if (source == AUDIO_SOURCE_DEFAULT) {
1136 goto exit;
1137 }
1138
1139
1140 if (snd_device != SND_DEVICE_NONE) {
1141 goto exit;
1142 }
1143
1144 if (in_device != AUDIO_DEVICE_NONE &&
1145 !(in_device & AUDIO_DEVICE_IN_VOICE_CALL) &&
1146 !(in_device & AUDIO_DEVICE_IN_COMMUNICATION)) {
1147 if (in_device & AUDIO_DEVICE_IN_BUILTIN_MIC) {
Apoorv Raghuvanshi6178a3f2013-10-19 12:38:54 -07001148 if (audio_extn_ssr_get_enabled() && channel_count == 6)
1149 snd_device = SND_DEVICE_IN_QUAD_MIC;
Ravi Kumar Alamandafae42112013-11-07 23:31:54 -08001150 else if (channel_count == 2)
Apoorv Raghuvanshi6bd8dbf2013-10-19 18:37:52 -07001151 snd_device = SND_DEVICE_IN_HANDSET_STEREO_DMIC;
Apoorv Raghuvanshi6178a3f2013-10-19 12:38:54 -07001152 else
1153 snd_device = SND_DEVICE_IN_HANDSET_MIC;
Eric Laurentb23d5282013-05-14 15:27:20 -07001154 } else if (in_device & AUDIO_DEVICE_IN_BACK_MIC) {
1155 snd_device = SND_DEVICE_IN_SPEAKER_MIC;
1156 } else if (in_device & AUDIO_DEVICE_IN_WIRED_HEADSET) {
1157 snd_device = SND_DEVICE_IN_HEADSET_MIC;
1158 } else if (in_device & AUDIO_DEVICE_IN_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 (in_device & AUDIO_DEVICE_IN_AUX_DIGITAL) {
1164 snd_device = SND_DEVICE_IN_HDMI_MIC;
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -07001165 } else if (in_device & AUDIO_DEVICE_IN_ANLG_DOCK_HEADSET ||
1166 in_device & AUDIO_DEVICE_IN_DGTL_DOCK_HEADSET) {
1167 snd_device = SND_DEVICE_IN_USB_HEADSET_MIC;
Apoorv Raghuvanshi6e262842013-10-06 14:39:35 -07001168 } else if (in_device & AUDIO_DEVICE_IN_FM_RX) {
1169 snd_device = SND_DEVICE_IN_CAPTURE_FM;
Eric Laurentb23d5282013-05-14 15:27:20 -07001170 } else {
1171 ALOGE("%s: Unknown input device(s) %#x", __func__, in_device);
1172 ALOGW("%s: Using default handset-mic", __func__);
1173 snd_device = SND_DEVICE_IN_HANDSET_MIC;
1174 }
1175 } else {
1176 if (out_device & AUDIO_DEVICE_OUT_EARPIECE) {
1177 snd_device = SND_DEVICE_IN_HANDSET_MIC;
1178 } else if (out_device & AUDIO_DEVICE_OUT_WIRED_HEADSET) {
1179 snd_device = SND_DEVICE_IN_HEADSET_MIC;
1180 } else if (out_device & AUDIO_DEVICE_OUT_SPEAKER) {
Apoorv Raghuvanshi6bd8dbf2013-10-19 18:37:52 -07001181 if (channel_count > 1)
1182 snd_device = SND_DEVICE_IN_SPEAKER_STEREO_DMIC;
1183 else
1184 snd_device = SND_DEVICE_IN_SPEAKER_MIC;
Eric Laurentb23d5282013-05-14 15:27:20 -07001185 } else if (out_device & AUDIO_DEVICE_OUT_WIRED_HEADPHONE) {
1186 snd_device = SND_DEVICE_IN_HANDSET_MIC;
1187 } else if (out_device & AUDIO_DEVICE_OUT_BLUETOOTH_SCO_HEADSET) {
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001188 if (my_data->btsco_sample_rate == SAMPLE_RATE_16KHZ)
1189 snd_device = SND_DEVICE_IN_BT_SCO_MIC_WB;
1190 else
1191 snd_device = SND_DEVICE_IN_BT_SCO_MIC;
Eric Laurentb23d5282013-05-14 15:27:20 -07001192 } else if (out_device & AUDIO_DEVICE_OUT_AUX_DIGITAL) {
1193 snd_device = SND_DEVICE_IN_HDMI_MIC;
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -07001194 } else if (out_device & AUDIO_DEVICE_OUT_ANLG_DOCK_HEADSET ||
1195 out_device & AUDIO_DEVICE_OUT_DGTL_DOCK_HEADSET) {
1196 snd_device = SND_DEVICE_IN_USB_HEADSET_MIC;
Eric Laurentb23d5282013-05-14 15:27:20 -07001197 } else {
1198 ALOGE("%s: Unknown output device(s) %#x", __func__, out_device);
1199 ALOGW("%s: Using default handset-mic", __func__);
1200 snd_device = SND_DEVICE_IN_HANDSET_MIC;
1201 }
1202 }
1203exit:
1204 ALOGV("%s: exit: in_snd_device(%s)", __func__, device_table[snd_device]);
1205 return snd_device;
1206}
1207
1208int platform_set_hdmi_channels(void *platform, int channel_count)
1209{
1210 struct platform_data *my_data = (struct platform_data *)platform;
1211 struct audio_device *adev = my_data->adev;
1212 struct mixer_ctl *ctl;
1213 const char *channel_cnt_str = NULL;
1214 const char *mixer_ctl_name = "HDMI_RX Channels";
1215 switch (channel_count) {
1216 case 8:
1217 channel_cnt_str = "Eight"; break;
1218 case 7:
1219 channel_cnt_str = "Seven"; break;
1220 case 6:
1221 channel_cnt_str = "Six"; break;
1222 case 5:
1223 channel_cnt_str = "Five"; break;
1224 case 4:
1225 channel_cnt_str = "Four"; break;
1226 case 3:
1227 channel_cnt_str = "Three"; break;
1228 default:
1229 channel_cnt_str = "Two"; break;
1230 }
1231 ctl = mixer_get_ctl_by_name(adev->mixer, mixer_ctl_name);
1232 if (!ctl) {
1233 ALOGE("%s: Could not get ctl for mixer cmd - %s",
1234 __func__, mixer_ctl_name);
1235 return -EINVAL;
1236 }
1237 ALOGV("HDMI channel count: %s", channel_cnt_str);
1238 mixer_ctl_set_enum_by_string(ctl, channel_cnt_str);
1239 return 0;
1240}
1241
Haynes Mathew George47cd4cb2013-07-19 11:58:50 -07001242int platform_edid_get_max_channels(void *platform)
Eric Laurentb23d5282013-05-14 15:27:20 -07001243{
Haynes Mathew George47cd4cb2013-07-19 11:58:50 -07001244 struct platform_data *my_data = (struct platform_data *)platform;
1245 struct audio_device *adev = my_data->adev;
Eric Laurentb23d5282013-05-14 15:27:20 -07001246 char block[MAX_SAD_BLOCKS * SAD_BLOCK_SIZE];
1247 char *sad = block;
1248 int num_audio_blocks;
1249 int channel_count;
1250 int max_channels = 0;
Haynes Mathew George47cd4cb2013-07-19 11:58:50 -07001251 int i, ret, count;
Eric Laurentb23d5282013-05-14 15:27:20 -07001252
Haynes Mathew George47cd4cb2013-07-19 11:58:50 -07001253 struct mixer_ctl *ctl;
1254
1255 ctl = mixer_get_ctl_by_name(adev->mixer, AUDIO_DATA_BLOCK_MIXER_CTL);
1256 if (!ctl) {
1257 ALOGE("%s: Could not get ctl for mixer cmd - %s",
1258 __func__, AUDIO_DATA_BLOCK_MIXER_CTL);
Eric Laurentb23d5282013-05-14 15:27:20 -07001259 return 0;
1260 }
1261
Haynes Mathew George47cd4cb2013-07-19 11:58:50 -07001262 mixer_ctl_update(ctl);
1263
1264 count = mixer_ctl_get_num_values(ctl);
Eric Laurentb23d5282013-05-14 15:27:20 -07001265
1266 /* Read SAD blocks, clamping the maximum size for safety */
Haynes Mathew George47cd4cb2013-07-19 11:58:50 -07001267 if (count > (int)sizeof(block))
1268 count = (int)sizeof(block);
Eric Laurentb23d5282013-05-14 15:27:20 -07001269
Haynes Mathew George47cd4cb2013-07-19 11:58:50 -07001270 ret = mixer_ctl_get_array(ctl, block, count);
1271 if (ret != 0) {
1272 ALOGE("%s: mixer_ctl_get_array() failed to get EDID info", __func__);
1273 return 0;
1274 }
Eric Laurentb23d5282013-05-14 15:27:20 -07001275
1276 /* Calculate the number of SAD blocks */
Haynes Mathew George47cd4cb2013-07-19 11:58:50 -07001277 num_audio_blocks = count / SAD_BLOCK_SIZE;
Eric Laurentb23d5282013-05-14 15:27:20 -07001278
1279 for (i = 0; i < num_audio_blocks; i++) {
1280 /* Only consider LPCM blocks */
Haynes Mathew George47cd4cb2013-07-19 11:58:50 -07001281 if ((sad[0] >> 3) != EDID_FORMAT_LPCM) {
1282 sad += 3;
Eric Laurentb23d5282013-05-14 15:27:20 -07001283 continue;
Haynes Mathew George47cd4cb2013-07-19 11:58:50 -07001284 }
Eric Laurentb23d5282013-05-14 15:27:20 -07001285
1286 channel_count = (sad[0] & 0x7) + 1;
1287 if (channel_count > max_channels)
1288 max_channels = channel_count;
1289
1290 /* Advance to next block */
1291 sad += 3;
1292 }
1293
1294 return max_channels;
1295}
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001296
1297static int platform_set_slowtalk(struct platform_data *my_data, bool state)
1298{
1299 int ret = 0;
1300 struct audio_device *adev = my_data->adev;
1301 struct mixer_ctl *ctl;
1302 const char *mixer_ctl_name = "Slowtalk Enable";
1303 uint32_t set_values[ ] = {0,
1304 ALL_SESSION_VSID};
1305
1306 set_values[0] = state;
1307 ctl = mixer_get_ctl_by_name(adev->mixer, mixer_ctl_name);
1308 if (!ctl) {
1309 ALOGE("%s: Could not get ctl for mixer cmd - %s",
1310 __func__, mixer_ctl_name);
1311 ret = -EINVAL;
1312 } else {
1313 ALOGV("Setting slowtalk state: %d", state);
1314 ret = mixer_ctl_set_array(ctl, set_values, ARRAY_SIZE(set_values));
1315 my_data->slowtalk = state;
1316 }
1317
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -08001318 if (my_data->csd != NULL) {
1319 ret = my_data->csd->slow_talk(ALL_SESSION_VSID, state);
1320 if (ret < 0) {
1321 ALOGE("%s: csd_client_disable_device, failed, error %d",
1322 __func__, ret);
1323 }
1324 }
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001325 return ret;
1326}
1327
1328int platform_set_parameters(void *platform, struct str_parms *parms)
1329{
1330 struct platform_data *my_data = (struct platform_data *)platform;
1331 char *str;
1332 char value[32];
1333 int val;
1334 int ret = 0;
1335
1336 ALOGV("%s: enter: %s", __func__, str_parms_to_str(parms));
1337
1338 ret = str_parms_get_int(parms, AUDIO_PARAMETER_KEY_BTSCO, &val);
1339 if (ret >= 0) {
1340 str_parms_del(parms, AUDIO_PARAMETER_KEY_BTSCO);
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001341 my_data->btsco_sample_rate = val;
Vidyakumar Athota67c42712013-12-04 14:03:06 -08001342 if (val == SAMPLE_RATE_16KHZ) {
1343 audio_route_apply_path(my_data->adev->audio_route,
1344 "bt-sco-wb-samplerate");
1345 audio_route_update_mixer(my_data->adev->audio_route);
1346 }
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001347 }
1348
1349 ret = str_parms_get_int(parms, AUDIO_PARAMETER_KEY_SLOWTALK, &val);
1350 if (ret >= 0) {
1351 str_parms_del(parms, AUDIO_PARAMETER_KEY_SLOWTALK);
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001352 ret = platform_set_slowtalk(my_data, val);
1353 if (ret)
1354 ALOGE("%s: Failed to set slow talk err: %d", __func__, ret);
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001355 }
1356
1357 ALOGV("%s: exit with code(%d)", __func__, ret);
1358 return ret;
1359}
1360
Vidyakumar Athota2850d532013-11-19 16:02:12 -08001361int platform_set_incall_recording_session_id(void *platform,
1362 uint32_t session_id, int rec_mode)
Shiv Maliyappanahallida107642013-10-17 11:16:13 -07001363{
1364 int ret = 0;
1365 struct platform_data *my_data = (struct platform_data *)platform;
1366 struct audio_device *adev = my_data->adev;
1367 struct mixer_ctl *ctl;
1368 const char *mixer_ctl_name = "Voc VSID";
1369 int num_ctl_values;
1370 int i;
1371
1372 ctl = mixer_get_ctl_by_name(adev->mixer, mixer_ctl_name);
1373 if (!ctl) {
1374 ALOGE("%s: Could not get ctl for mixer cmd - %s",
1375 __func__, mixer_ctl_name);
1376 ret = -EINVAL;
1377 } else {
1378 num_ctl_values = mixer_ctl_get_num_values(ctl);
1379 for (i = 0; i < num_ctl_values; i++) {
1380 if (mixer_ctl_set_value(ctl, i, session_id)) {
1381 ALOGV("Error: invalid session_id: %x", session_id);
1382 ret = -EINVAL;
1383 break;
1384 }
1385 }
1386 }
1387
Vidyakumar Athota2850d532013-11-19 16:02:12 -08001388 if (my_data->csd != NULL) {
1389 ret = my_data->csd->start_record(ALL_SESSION_VSID, rec_mode);
1390 if (ret < 0) {
1391 ALOGE("%s: csd_client_start_record failed, error %d",
1392 __func__, ret);
1393 }
1394 }
1395
1396 return ret;
1397}
1398
1399int platform_stop_incall_recording_usecase(void *platform)
1400{
1401 int ret = 0;
1402 struct platform_data *my_data = (struct platform_data *)platform;
1403
1404 if (my_data->csd != NULL) {
1405 ret = my_data->csd->stop_record(ALL_SESSION_VSID);
1406 if (ret < 0) {
1407 ALOGE("%s: csd_client_stop_record failed, error %d",
1408 __func__, ret);
1409 }
1410 }
1411
1412 return ret;
1413}
1414
1415int platform_start_incall_music_usecase(void *platform)
1416{
1417 int ret = 0;
1418 struct platform_data *my_data = (struct platform_data *)platform;
1419
1420 if (my_data->csd != NULL) {
1421 ret = my_data->csd->start_playback(ALL_SESSION_VSID);
1422 if (ret < 0) {
1423 ALOGE("%s: csd_client_start_playback failed, error %d",
1424 __func__, ret);
1425 }
1426 }
1427
1428 return ret;
1429}
1430
1431int platform_stop_incall_music_usecase(void *platform)
1432{
1433 int ret = 0;
1434 struct platform_data *my_data = (struct platform_data *)platform;
1435
1436 if (my_data->csd != NULL) {
1437 ret = my_data->csd->stop_playback(ALL_SESSION_VSID);
1438 if (ret < 0) {
1439 ALOGE("%s: csd_client_stop_playback failed, error %d",
1440 __func__, ret);
1441 }
1442 }
1443
Shiv Maliyappanahallida107642013-10-17 11:16:13 -07001444 return ret;
1445}
1446
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001447void platform_get_parameters(void *platform,
1448 struct str_parms *query,
1449 struct str_parms *reply)
1450{
1451 struct platform_data *my_data = (struct platform_data *)platform;
1452 char *str = NULL;
1453 char value[256] = {0};
1454 int ret;
1455 int fluence_type;
1456
1457 ret = str_parms_get_str(query, AUDIO_PARAMETER_KEY_FLUENCE_TYPE,
1458 value, sizeof(value));
1459 if (ret >= 0) {
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -08001460 if (my_data->fluence_type & FLUENCE_QUAD_MIC) {
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001461 strlcpy(value, "fluencepro", sizeof(value));
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -08001462 } else if (my_data->fluence_type & FLUENCE_DUAL_MIC) {
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001463 strlcpy(value, "fluence", sizeof(value));
1464 } else {
1465 strlcpy(value, "none", sizeof(value));
1466 }
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001467
1468 str_parms_add_str(reply, AUDIO_PARAMETER_KEY_FLUENCE_TYPE, value);
1469 }
1470
Shiv Maliyappanahalli9d899292013-11-20 14:43:01 -08001471 memset(value, 0, sizeof(value));
1472 ret = str_parms_get_str(query, AUDIO_PARAMETER_KEY_SLOWTALK,
1473 value, sizeof(value));
1474 if (ret >= 0) {
1475 str_parms_add_int(reply, AUDIO_PARAMETER_KEY_SLOWTALK,
1476 my_data->slowtalk);
1477 }
1478
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001479 ALOGV("%s: exit: returns - %s", __func__, str_parms_to_str(reply));
1480}
1481
Haynes Mathew George7ff216f2013-09-11 19:51:41 -07001482/* Delay in Us */
1483int64_t platform_render_latency(audio_usecase_t usecase)
1484{
1485 switch (usecase) {
1486 case USECASE_AUDIO_PLAYBACK_DEEP_BUFFER:
1487 return DEEP_BUFFER_PLATFORM_DELAY;
1488 case USECASE_AUDIO_PLAYBACK_LOW_LATENCY:
1489 return LOW_LATENCY_PLATFORM_DELAY;
1490 default:
1491 return 0;
1492 }
1493}
Preetam Singh Ranawatde84f1a2013-11-01 14:58:16 -07001494
Mingming Yine62d7842013-10-25 16:26:03 -07001495int platform_update_usecase_from_source(int source, int usecase)
Preetam Singh Ranawatde84f1a2013-11-01 14:58:16 -07001496{
Mingming Yinab429782013-11-07 11:16:55 -08001497 ALOGV("%s: input source :%d", __func__, source);
1498 if(source == AUDIO_SOURCE_FM_RX_A2DP)
Mingming Yine62d7842013-10-25 16:26:03 -07001499 usecase = USECASE_AUDIO_RECORD_FM_VIRTUAL;
1500 return usecase;
Preetam Singh Ranawatde84f1a2013-11-01 14:58:16 -07001501}
Kiran Kandide144c82013-11-20 15:58:32 -08001502
1503bool platform_listen_update_status(snd_device_t snd_device)
1504{
1505 if ((snd_device >= SND_DEVICE_IN_BEGIN) &&
1506 (snd_device < SND_DEVICE_IN_END) &&
1507 (snd_device != SND_DEVICE_IN_CAPTURE_FM) &&
1508 (snd_device != SND_DEVICE_IN_CAPTURE_VI_FEEDBACK))
1509 return true;
1510 else
1511 return false;
1512}