blob: 34ff8cc6f77b8ea9630e71201c9853c88316a8a4 [file] [log] [blame]
Eric Laurentb23d5282013-05-14 15:27:20 -07001/*
Shiv Maliyappanahalli3e064fd2013-12-16 15:54:40 -08002 * Copyright (c) 2013-2014, The Linux Foundation. All rights reserved.
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -07003 * Not a Contribution.
4 *
Shiv Maliyappanahalli8911f282014-01-10 15:56:19 -08005 * Copyright (C) 2013 The Android Open Source Project
Eric Laurentb23d5282013-05-14 15:27:20 -07006 *
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"
Ben Romberger55886882014-01-10 13:49:02 -080034#include "platform_parser.h"
Eric Laurentb23d5282013-05-14 15:27:20 -070035
Haynes Mathew George47cd4cb2013-07-19 11:58:50 -070036#define MIXER_XML_PATH "/system/etc/mixer_paths.xml"
Damir Didjustof1d46c72013-11-06 17:59:04 -080037#define MIXER_XML_PATH_AUXPCM "/system/etc/mixer_paths_auxpcm.xml"
Eric Laurentb23d5282013-05-14 15:27:20 -070038#define LIB_ACDB_LOADER "libacdbloader.so"
Haynes Mathew George47cd4cb2013-07-19 11:58:50 -070039#define AUDIO_DATA_BLOCK_MIXER_CTL "HDMI EDID"
Eric Laurentb23d5282013-05-14 15:27:20 -070040
Eric Laurentb23d5282013-05-14 15:27:20 -070041/*
Eric Laurentb23d5282013-05-14 15:27:20 -070042 * This file will have a maximum of 38 bytes:
43 *
44 * 4 bytes: number of audio blocks
45 * 4 bytes: total length of Short Audio Descriptor (SAD) blocks
46 * Maximum 10 * 3 bytes: SAD blocks
47 */
48#define MAX_SAD_BLOCKS 10
49#define SAD_BLOCK_SIZE 3
50
51/* EDID format ID for LPCM audio */
52#define EDID_FORMAT_LPCM 1
53
sangwoo1b9f4b32013-06-21 18:22:55 -070054/* Retry for delay in FW loading*/
55#define RETRY_NUMBER 10
56#define RETRY_US 500000
Apoorv Raghuvanshi84fa2fe2013-12-04 11:57:47 -080057#define MAX_SND_CARD 8
sangwoo1b9f4b32013-06-21 18:22:55 -070058
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -070059#define SAMPLE_RATE_8KHZ 8000
60#define SAMPLE_RATE_16KHZ 16000
61
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -070062#define AUDIO_PARAMETER_KEY_FLUENCE_TYPE "fluence"
63#define AUDIO_PARAMETER_KEY_BTSCO "bt_samplerate"
64#define AUDIO_PARAMETER_KEY_SLOWTALK "st_enable"
Ben Rombergerc1dc70d2013-12-19 15:11:17 -080065#define AUDIO_PARAMETER_KEY_VOLUME_BOOST "volume_boost"
66
67enum {
68 VOICE_FEATURE_SET_DEFAULT,
69 VOICE_FEATURE_SET_VOLUME_BOOST
70};
sangwoo53b2cf02013-07-25 19:18:44 -070071
Eric Laurentb23d5282013-05-14 15:27:20 -070072struct audio_block_header
73{
74 int reserved;
75 int length;
76};
77
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -080078/* Audio calibration related functions */
Eric Laurentb23d5282013-05-14 15:27:20 -070079typedef void (*acdb_deallocate_t)();
80typedef int (*acdb_init_t)();
81typedef void (*acdb_send_audio_cal_t)(int, int);
82typedef void (*acdb_send_voice_cal_t)(int, int);
Ben Rombergerc1dc70d2013-12-19 15:11:17 -080083typedef int (*acdb_reload_vocvoltable_t)(int);
Eric Laurentb23d5282013-05-14 15:27:20 -070084
Eric Laurentb23d5282013-05-14 15:27:20 -070085struct platform_data {
86 struct audio_device *adev;
87 bool fluence_in_spkr_mode;
88 bool fluence_in_voice_call;
89 bool fluence_in_voice_rec;
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -080090 bool fluence_in_audio_rec;
Mingming Yin8e5a4f62013-10-07 15:23:41 -070091 int fluence_type;
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -070092 int btsco_sample_rate;
93 bool slowtalk;
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -070094 /* Audio calibration related functions */
Ben Rombergerc1dc70d2013-12-19 15:11:17 -080095 void *acdb_handle;
96 int voice_feature_set;
97 acdb_init_t acdb_init;
98 acdb_deallocate_t acdb_deallocate;
99 acdb_send_audio_cal_t acdb_send_audio_cal;
100 acdb_send_voice_cal_t acdb_send_voice_cal;
101 acdb_reload_vocvoltable_t acdb_reload_vocvoltable;
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700102
103 void *hw_info;
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800104 struct csd_data *csd;
Eric Laurentb23d5282013-05-14 15:27:20 -0700105};
106
107static const int pcm_device_table[AUDIO_USECASE_MAX][2] = {
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700108 [USECASE_AUDIO_PLAYBACK_DEEP_BUFFER] = {DEEP_BUFFER_PCM_DEVICE,
109 DEEP_BUFFER_PCM_DEVICE},
110 [USECASE_AUDIO_PLAYBACK_LOW_LATENCY] = {LOWLATENCY_PCM_DEVICE,
Preetam Singh Ranawatde84f1a2013-11-01 14:58:16 -0700111 LOWLATENCY_PCM_DEVICE},
112 [USECASE_AUDIO_PLAYBACK_MULTI_CH] = {MULTIMEDIA2_PCM_DEVICE,
113 MULTIMEDIA2_PCM_DEVICE},
Krishnankutty Kolathappillya43f96e2013-11-01 12:17:53 -0700114 [USECASE_AUDIO_PLAYBACK_OFFLOAD] =
115 {PLAYBACK_OFFLOAD_DEVICE, PLAYBACK_OFFLOAD_DEVICE},
Shiv Maliyappanahallida107642013-10-17 11:16:13 -0700116 [USECASE_AUDIO_RECORD] = {AUDIO_RECORD_PCM_DEVICE, AUDIO_RECORD_PCM_DEVICE},
Mingming Yine62d7842013-10-25 16:26:03 -0700117 [USECASE_AUDIO_RECORD_COMPRESS] = {COMPRESS_CAPTURE_DEVICE, COMPRESS_CAPTURE_DEVICE},
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700118 [USECASE_AUDIO_RECORD_LOW_LATENCY] = {LOWLATENCY_PCM_DEVICE,
119 LOWLATENCY_PCM_DEVICE},
Preetam Singh Ranawatde84f1a2013-11-01 14:58:16 -0700120 [USECASE_AUDIO_RECORD_FM_VIRTUAL] = {MULTIMEDIA2_PCM_DEVICE,
121 MULTIMEDIA2_PCM_DEVICE},
Apoorv Raghuvanshi6e262842013-10-06 14:39:35 -0700122 [USECASE_AUDIO_PLAYBACK_FM] = {FM_PLAYBACK_PCM_DEVICE, FM_CAPTURE_PCM_DEVICE},
Vimal Puthanveed5b4d3f12013-11-05 15:57:39 -0800123 [USECASE_AUDIO_HFP_SCO] = {HFP_PCM_RX, HFP_SCO_RX},
Vimal Puthanveed47e64852013-12-20 13:23:39 -0800124 [USECASE_AUDIO_HFP_SCO_WB] = {HFP_PCM_RX, HFP_SCO_RX},
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700125 [USECASE_VOICE_CALL] = {VOICE_CALL_PCM_DEVICE, VOICE_CALL_PCM_DEVICE},
126 [USECASE_VOICE2_CALL] = {VOICE2_CALL_PCM_DEVICE, VOICE2_CALL_PCM_DEVICE},
127 [USECASE_VOLTE_CALL] = {VOLTE_CALL_PCM_DEVICE, VOLTE_CALL_PCM_DEVICE},
128 [USECASE_QCHAT_CALL] = {QCHAT_CALL_PCM_DEVICE, QCHAT_CALL_PCM_DEVICE},
Narsinga Rao Chella05573b72013-11-15 15:21:40 -0800129 [USECASE_COMPRESS_VOIP_CALL] = {COMPRESS_VOIP_CALL_PCM_DEVICE, COMPRESS_VOIP_CALL_PCM_DEVICE},
Shiv Maliyappanahallida107642013-10-17 11:16:13 -0700130 [USECASE_INCALL_REC_UPLINK] = {AUDIO_RECORD_PCM_DEVICE,
131 AUDIO_RECORD_PCM_DEVICE},
132 [USECASE_INCALL_REC_DOWNLINK] = {AUDIO_RECORD_PCM_DEVICE,
133 AUDIO_RECORD_PCM_DEVICE},
134 [USECASE_INCALL_REC_UPLINK_AND_DOWNLINK] = {AUDIO_RECORD_PCM_DEVICE,
135 AUDIO_RECORD_PCM_DEVICE},
Helen Zenge56b4852013-12-03 16:54:40 -0800136 [USECASE_INCALL_REC_UPLINK_COMPRESS] = {COMPRESS_CAPTURE_DEVICE,
137 COMPRESS_CAPTURE_DEVICE},
138 [USECASE_INCALL_REC_DOWNLINK_COMPRESS] = {COMPRESS_CAPTURE_DEVICE,
139 COMPRESS_CAPTURE_DEVICE},
140 [USECASE_INCALL_REC_UPLINK_AND_DOWNLINK_COMPRESS] = {COMPRESS_CAPTURE_DEVICE,
141 COMPRESS_CAPTURE_DEVICE},
Shiv Maliyappanahallif3b9a422013-10-22 16:38:08 -0700142 [USECASE_INCALL_MUSIC_UPLINK] = {INCALL_MUSIC_UPLINK_PCM_DEVICE,
143 INCALL_MUSIC_UPLINK_PCM_DEVICE},
144 [USECASE_INCALL_MUSIC_UPLINK2] = {INCALL_MUSIC_UPLINK2_PCM_DEVICE,
145 INCALL_MUSIC_UPLINK2_PCM_DEVICE},
Gopikrishnaiah Anandanf538cef2013-10-28 14:06:03 -0700146 [USECASE_AUDIO_SPKR_CALIB_RX] = {SPKR_PROT_CALIB_RX_PCM_DEVICE, -1},
147 [USECASE_AUDIO_SPKR_CALIB_TX] = {-1, SPKR_PROT_CALIB_TX_PCM_DEVICE},
Eric Laurentb23d5282013-05-14 15:27:20 -0700148};
149
150/* Array to store sound devices */
151static const char * const device_table[SND_DEVICE_MAX] = {
152 [SND_DEVICE_NONE] = "none",
153 /* Playback sound devices */
154 [SND_DEVICE_OUT_HANDSET] = "handset",
155 [SND_DEVICE_OUT_SPEAKER] = "speaker",
156 [SND_DEVICE_OUT_SPEAKER_REVERSE] = "speaker-reverse",
157 [SND_DEVICE_OUT_HEADPHONES] = "headphones",
158 [SND_DEVICE_OUT_SPEAKER_AND_HEADPHONES] = "speaker-and-headphones",
159 [SND_DEVICE_OUT_VOICE_HANDSET] = "voice-handset",
160 [SND_DEVICE_OUT_VOICE_SPEAKER] = "voice-speaker",
161 [SND_DEVICE_OUT_VOICE_HEADPHONES] = "voice-headphones",
162 [SND_DEVICE_OUT_HDMI] = "hdmi",
163 [SND_DEVICE_OUT_SPEAKER_AND_HDMI] = "speaker-and-hdmi",
164 [SND_DEVICE_OUT_BT_SCO] = "bt-sco-headset",
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700165 [SND_DEVICE_OUT_BT_SCO_WB] = "bt-sco-headset-wb",
Eric Laurentb23d5282013-05-14 15:27:20 -0700166 [SND_DEVICE_OUT_VOICE_TTY_FULL_HEADPHONES] = "voice-tty-full-headphones",
167 [SND_DEVICE_OUT_VOICE_TTY_VCO_HEADPHONES] = "voice-tty-vco-headphones",
168 [SND_DEVICE_OUT_VOICE_TTY_HCO_HANDSET] = "voice-tty-hco-handset",
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -0700169 [SND_DEVICE_OUT_AFE_PROXY] = "afe-proxy",
170 [SND_DEVICE_OUT_USB_HEADSET] = "usb-headphones",
171 [SND_DEVICE_OUT_SPEAKER_AND_USB_HEADSET] = "speaker-and-usb-headphones",
Apoorv Raghuvanshi6e262842013-10-06 14:39:35 -0700172 [SND_DEVICE_OUT_TRANSMISSION_FM] = "transmission-fm",
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -0700173 [SND_DEVICE_OUT_ANC_HEADSET] = "anc-headphones",
174 [SND_DEVICE_OUT_ANC_FB_HEADSET] = "anc-fb-headphones",
175 [SND_DEVICE_OUT_VOICE_ANC_HEADSET] = "voice-anc-headphones",
176 [SND_DEVICE_OUT_VOICE_ANC_FB_HEADSET] = "voice-anc-fb-headphones",
177 [SND_DEVICE_OUT_SPEAKER_AND_ANC_HEADSET] = "speaker-and-anc-headphones",
178 [SND_DEVICE_OUT_ANC_HANDSET] = "anc-handset",
Gopikrishnaiah Anandanf538cef2013-10-28 14:06:03 -0700179 [SND_DEVICE_OUT_SPEAKER_PROTECTED] = "speaker-protected",
Eric Laurentb23d5282013-05-14 15:27:20 -0700180
181 /* Capture sound devices */
182 [SND_DEVICE_IN_HANDSET_MIC] = "handset-mic",
Eric Laurentb23d5282013-05-14 15:27:20 -0700183 [SND_DEVICE_IN_HANDSET_MIC_AEC] = "handset-mic",
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -0800184 [SND_DEVICE_IN_HANDSET_MIC_NS] = "handset-mic",
185 [SND_DEVICE_IN_HANDSET_MIC_AEC_NS] = "handset-mic",
186 [SND_DEVICE_IN_HANDSET_DMIC] = "dmic-endfire",
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800187 [SND_DEVICE_IN_HANDSET_DMIC_AEC] = "dmic-endfire",
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -0800188 [SND_DEVICE_IN_HANDSET_DMIC_NS] = "dmic-endfire",
189 [SND_DEVICE_IN_HANDSET_DMIC_AEC_NS] = "dmic-endfire",
190 [SND_DEVICE_IN_SPEAKER_MIC] = "speaker-mic",
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800191 [SND_DEVICE_IN_SPEAKER_MIC_AEC] = "speaker-mic",
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -0800192 [SND_DEVICE_IN_SPEAKER_MIC_NS] = "speaker-mic",
193 [SND_DEVICE_IN_SPEAKER_MIC_AEC_NS] = "speaker-mic",
194 [SND_DEVICE_IN_SPEAKER_DMIC] = "speaker-dmic-endfire",
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800195 [SND_DEVICE_IN_SPEAKER_DMIC_AEC] = "speaker-dmic-endfire",
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -0800196 [SND_DEVICE_IN_SPEAKER_DMIC_NS] = "speaker-dmic-endfire",
197 [SND_DEVICE_IN_SPEAKER_DMIC_AEC_NS] = "speaker-dmic-endfire",
198 [SND_DEVICE_IN_HEADSET_MIC] = "headset-mic",
199 [SND_DEVICE_IN_HEADSET_MIC_FLUENCE] = "headset-mic",
Eric Laurentb23d5282013-05-14 15:27:20 -0700200 [SND_DEVICE_IN_VOICE_SPEAKER_MIC] = "voice-speaker-mic",
201 [SND_DEVICE_IN_VOICE_HEADSET_MIC] = "voice-headset-mic",
202 [SND_DEVICE_IN_HDMI_MIC] = "hdmi-mic",
203 [SND_DEVICE_IN_BT_SCO_MIC] = "bt-sco-mic",
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700204 [SND_DEVICE_IN_BT_SCO_MIC_WB] = "bt-sco-mic-wb",
Eric Laurentb23d5282013-05-14 15:27:20 -0700205 [SND_DEVICE_IN_CAMCORDER_MIC] = "camcorder-mic",
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700206 [SND_DEVICE_IN_VOICE_DMIC] = "voice-dmic-ef",
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700207 [SND_DEVICE_IN_VOICE_SPEAKER_DMIC] = "voice-speaker-dmic-ef",
Vidyakumar Athotaadfe4e32013-12-13 14:51:26 -0800208 [SND_DEVICE_IN_VOICE_SPEAKER_QMIC] = "voice-speaker-qmic",
Eric Laurentb23d5282013-05-14 15:27:20 -0700209 [SND_DEVICE_IN_VOICE_TTY_FULL_HEADSET_MIC] = "voice-tty-full-headset-mic",
210 [SND_DEVICE_IN_VOICE_TTY_VCO_HANDSET_MIC] = "voice-tty-vco-handset-mic",
211 [SND_DEVICE_IN_VOICE_TTY_HCO_HEADSET_MIC] = "voice-tty-hco-headset-mic",
212 [SND_DEVICE_IN_VOICE_REC_MIC] = "voice-rec-mic",
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -0800213 [SND_DEVICE_IN_VOICE_REC_MIC_NS] = "voice-rec-mic",
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800214 [SND_DEVICE_IN_VOICE_REC_DMIC_STEREO] = "voice-rec-dmic-ef",
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700215 [SND_DEVICE_IN_VOICE_REC_DMIC_FLUENCE] = "voice-rec-dmic-ef-fluence",
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -0700216 [SND_DEVICE_IN_USB_HEADSET_MIC] = "usb-headset-mic",
Apoorv Raghuvanshi6e262842013-10-06 14:39:35 -0700217 [SND_DEVICE_IN_CAPTURE_FM] = "capture-fm",
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -0700218 [SND_DEVICE_IN_AANC_HANDSET_MIC] = "aanc-handset-mic",
Apoorv Raghuvanshi6178a3f2013-10-19 12:38:54 -0700219 [SND_DEVICE_IN_QUAD_MIC] = "quad-mic",
Apoorv Raghuvanshi6bd8dbf2013-10-19 18:37:52 -0700220 [SND_DEVICE_IN_HANDSET_STEREO_DMIC] = "handset-stereo-dmic-ef",
221 [SND_DEVICE_IN_SPEAKER_STEREO_DMIC] = "speaker-stereo-dmic-ef",
Gopikrishnaiah Anandanf538cef2013-10-28 14:06:03 -0700222 [SND_DEVICE_IN_CAPTURE_VI_FEEDBACK] = "vi-feedback",
Eric Laurentb23d5282013-05-14 15:27:20 -0700223};
224
225/* ACDB IDs (audio DSP path configuration IDs) for each sound device */
Ben Romberger55886882014-01-10 13:49:02 -0800226static int acdb_device_table[SND_DEVICE_MAX] = {
Eric Laurentb23d5282013-05-14 15:27:20 -0700227 [SND_DEVICE_NONE] = -1,
228 [SND_DEVICE_OUT_HANDSET] = 7,
Vidyakumar Athotac29d4ab2013-11-14 16:58:02 -0800229 [SND_DEVICE_OUT_SPEAKER] = 14,
230 [SND_DEVICE_OUT_SPEAKER_REVERSE] = 14,
Eric Laurentb23d5282013-05-14 15:27:20 -0700231 [SND_DEVICE_OUT_HEADPHONES] = 10,
232 [SND_DEVICE_OUT_SPEAKER_AND_HEADPHONES] = 10,
233 [SND_DEVICE_OUT_VOICE_HANDSET] = 7,
Vidyakumar Athotac29d4ab2013-11-14 16:58:02 -0800234 [SND_DEVICE_OUT_VOICE_SPEAKER] = 14,
Eric Laurentb23d5282013-05-14 15:27:20 -0700235 [SND_DEVICE_OUT_VOICE_HEADPHONES] = 10,
236 [SND_DEVICE_OUT_HDMI] = 18,
Vidyakumar Athotac29d4ab2013-11-14 16:58:02 -0800237 [SND_DEVICE_OUT_SPEAKER_AND_HDMI] = 14,
Eric Laurentb23d5282013-05-14 15:27:20 -0700238 [SND_DEVICE_OUT_BT_SCO] = 22,
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700239 [SND_DEVICE_OUT_BT_SCO_WB] = 39,
Eric Laurentb23d5282013-05-14 15:27:20 -0700240 [SND_DEVICE_OUT_VOICE_TTY_FULL_HEADPHONES] = 17,
241 [SND_DEVICE_OUT_VOICE_TTY_VCO_HEADPHONES] = 17,
242 [SND_DEVICE_OUT_VOICE_TTY_HCO_HANDSET] = 37,
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -0700243 [SND_DEVICE_OUT_AFE_PROXY] = 0,
244 [SND_DEVICE_OUT_USB_HEADSET] = 0,
245 [SND_DEVICE_OUT_SPEAKER_AND_USB_HEADSET] = 14,
Apoorv Raghuvanshi6e262842013-10-06 14:39:35 -0700246 [SND_DEVICE_OUT_TRANSMISSION_FM] = 0,
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -0700247 [SND_DEVICE_OUT_ANC_HEADSET] = 26,
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700248 [SND_DEVICE_OUT_ANC_FB_HEADSET] = 27,
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -0700249 [SND_DEVICE_OUT_VOICE_ANC_HEADSET] = 26,
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700250 [SND_DEVICE_OUT_VOICE_ANC_FB_HEADSET] = 27,
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -0700251 [SND_DEVICE_OUT_SPEAKER_AND_ANC_HEADSET] = 26,
252 [SND_DEVICE_OUT_ANC_HANDSET] = 103,
Gopikrishnaiah Anandanf538cef2013-10-28 14:06:03 -0700253 [SND_DEVICE_OUT_SPEAKER_PROTECTED] = 101,
Eric Laurentb23d5282013-05-14 15:27:20 -0700254
255 [SND_DEVICE_IN_HANDSET_MIC] = 4,
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -0800256 [SND_DEVICE_IN_HANDSET_MIC_AEC] = 106,
257 [SND_DEVICE_IN_HANDSET_MIC_NS] = 107,
258 [SND_DEVICE_IN_HANDSET_MIC_AEC_NS] = 108,
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800259 [SND_DEVICE_IN_HANDSET_DMIC] = 41,
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -0800260 [SND_DEVICE_IN_HANDSET_DMIC_AEC] = 109,
261 [SND_DEVICE_IN_HANDSET_DMIC_NS] = 110,
262 [SND_DEVICE_IN_HANDSET_DMIC_AEC_NS] = 111,
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800263 [SND_DEVICE_IN_SPEAKER_MIC] = 11,
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -0800264 [SND_DEVICE_IN_SPEAKER_MIC_AEC] = 112,
265 [SND_DEVICE_IN_SPEAKER_MIC_NS] = 113,
266 [SND_DEVICE_IN_SPEAKER_MIC_AEC_NS] = 114,
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800267 [SND_DEVICE_IN_SPEAKER_DMIC] = 43,
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -0800268 [SND_DEVICE_IN_SPEAKER_DMIC_AEC] = 115,
269 [SND_DEVICE_IN_SPEAKER_DMIC_NS] = 116,
270 [SND_DEVICE_IN_SPEAKER_DMIC_AEC_NS] = 117,
Eric Laurentb23d5282013-05-14 15:27:20 -0700271 [SND_DEVICE_IN_HEADSET_MIC] = 8,
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -0800272 [SND_DEVICE_IN_HEADSET_MIC_FLUENCE] = 47,
Eric Laurentb23d5282013-05-14 15:27:20 -0700273 [SND_DEVICE_IN_VOICE_SPEAKER_MIC] = 11,
274 [SND_DEVICE_IN_VOICE_HEADSET_MIC] = 8,
275 [SND_DEVICE_IN_HDMI_MIC] = 4,
276 [SND_DEVICE_IN_BT_SCO_MIC] = 21,
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700277 [SND_DEVICE_IN_BT_SCO_MIC_WB] = 38,
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800278 [SND_DEVICE_IN_CAMCORDER_MIC] = 4,
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700279 [SND_DEVICE_IN_VOICE_DMIC] = 41,
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700280 [SND_DEVICE_IN_VOICE_SPEAKER_DMIC] = 43,
Vidyakumar Athotaadfe4e32013-12-13 14:51:26 -0800281 [SND_DEVICE_IN_VOICE_SPEAKER_QMIC] = 19,
Eric Laurentb23d5282013-05-14 15:27:20 -0700282 [SND_DEVICE_IN_VOICE_TTY_FULL_HEADSET_MIC] = 16,
283 [SND_DEVICE_IN_VOICE_TTY_VCO_HANDSET_MIC] = 36,
284 [SND_DEVICE_IN_VOICE_TTY_HCO_HEADSET_MIC] = 16,
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800285 [SND_DEVICE_IN_VOICE_REC_MIC] = 4,
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -0800286 [SND_DEVICE_IN_VOICE_REC_MIC_NS] = 107,
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800287 [SND_DEVICE_IN_VOICE_REC_DMIC_STEREO] = 34,
288 [SND_DEVICE_IN_VOICE_REC_DMIC_FLUENCE] = 41,
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -0700289 [SND_DEVICE_IN_USB_HEADSET_MIC] = 44,
Apoorv Raghuvanshi6e262842013-10-06 14:39:35 -0700290 [SND_DEVICE_IN_CAPTURE_FM] = 0,
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -0700291 [SND_DEVICE_IN_AANC_HANDSET_MIC] = 104,
Apoorv Raghuvanshi6178a3f2013-10-19 12:38:54 -0700292 [SND_DEVICE_IN_QUAD_MIC] = 46,
Apoorv Raghuvanshi6bd8dbf2013-10-19 18:37:52 -0700293 [SND_DEVICE_IN_HANDSET_STEREO_DMIC] = 34,
294 [SND_DEVICE_IN_SPEAKER_STEREO_DMIC] = 35,
Gopikrishnaiah Anandanf538cef2013-10-28 14:06:03 -0700295 [SND_DEVICE_IN_CAPTURE_VI_FEEDBACK] = 102,
Eric Laurentb23d5282013-05-14 15:27:20 -0700296};
297
Haynes Mathew George7ff216f2013-09-11 19:51:41 -0700298#define DEEP_BUFFER_PLATFORM_DELAY (29*1000LL)
299#define LOW_LATENCY_PLATFORM_DELAY (13*1000LL)
300
Eric Laurentb23d5282013-05-14 15:27:20 -0700301static int set_echo_reference(struct mixer *mixer, const char* ec_ref)
302{
303 struct mixer_ctl *ctl;
304 const char *mixer_ctl_name = "EC_REF_RX";
305
306 ctl = mixer_get_ctl_by_name(mixer, mixer_ctl_name);
307 if (!ctl) {
308 ALOGE("%s: Could not get ctl for mixer cmd - %s",
309 __func__, mixer_ctl_name);
310 return -EINVAL;
311 }
312 ALOGV("Setting EC Reference: %s", ec_ref);
313 mixer_ctl_set_enum_by_string(ctl, ec_ref);
314 return 0;
315}
316
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800317static struct csd_data *open_csd_client()
318{
319 struct csd_data *csd = calloc(1, sizeof(struct csd_data));
320
321 csd->csd_client = dlopen(LIB_CSD_CLIENT, RTLD_NOW);
322 if (csd->csd_client == NULL) {
323 ALOGE("%s: DLOPEN failed for %s", __func__, LIB_CSD_CLIENT);
324 goto error;
325 } else {
326 ALOGV("%s: DLOPEN successful for %s", __func__, LIB_CSD_CLIENT);
327
328 csd->deinit = (deinit_t)dlsym(csd->csd_client,
329 "csd_client_deinit");
330 if (csd->deinit == NULL) {
331 ALOGE("%s: dlsym error %s for csd_client_deinit", __func__,
332 dlerror());
333 goto error;
334 }
335 csd->disable_device = (disable_device_t)dlsym(csd->csd_client,
336 "csd_client_disable_device");
337 if (csd->disable_device == NULL) {
338 ALOGE("%s: dlsym error %s for csd_client_disable_device",
339 __func__, dlerror());
340 goto error;
341 }
342 csd->enable_device = (enable_device_t)dlsym(csd->csd_client,
343 "csd_client_enable_device");
344 if (csd->enable_device == NULL) {
345 ALOGE("%s: dlsym error %s for csd_client_enable_device",
346 __func__, dlerror());
347 goto error;
348 }
349 csd->start_voice = (start_voice_t)dlsym(csd->csd_client,
350 "csd_client_start_voice");
351 if (csd->start_voice == NULL) {
352 ALOGE("%s: dlsym error %s for csd_client_start_voice",
353 __func__, dlerror());
354 goto error;
355 }
356 csd->stop_voice = (stop_voice_t)dlsym(csd->csd_client,
357 "csd_client_stop_voice");
358 if (csd->stop_voice == NULL) {
359 ALOGE("%s: dlsym error %s for csd_client_stop_voice",
360 __func__, dlerror());
361 goto error;
362 }
363 csd->volume = (volume_t)dlsym(csd->csd_client,
364 "csd_client_volume");
365 if (csd->volume == NULL) {
366 ALOGE("%s: dlsym error %s for csd_client_volume",
367 __func__, dlerror());
368 goto error;
369 }
370 csd->mic_mute = (mic_mute_t)dlsym(csd->csd_client,
371 "csd_client_mic_mute");
372 if (csd->mic_mute == NULL) {
373 ALOGE("%s: dlsym error %s for csd_client_mic_mute",
374 __func__, dlerror());
375 goto error;
376 }
377 csd->slow_talk = (slow_talk_t)dlsym(csd->csd_client,
378 "csd_client_slow_talk");
379 if (csd->slow_talk == NULL) {
380 ALOGE("%s: dlsym error %s for csd_client_slow_talk",
381 __func__, dlerror());
382 goto error;
383 }
384 csd->start_playback = (start_playback_t)dlsym(csd->csd_client,
385 "csd_client_start_playback");
386 if (csd->start_playback == NULL) {
387 ALOGE("%s: dlsym error %s for csd_client_start_playback",
388 __func__, dlerror());
389 goto error;
390 }
391 csd->stop_playback = (stop_playback_t)dlsym(csd->csd_client,
392 "csd_client_stop_playback");
393 if (csd->stop_playback == NULL) {
394 ALOGE("%s: dlsym error %s for csd_client_stop_playback",
395 __func__, dlerror());
396 goto error;
397 }
398 csd->start_record = (start_record_t)dlsym(csd->csd_client,
399 "csd_client_start_record");
400 if (csd->start_record == NULL) {
401 ALOGE("%s: dlsym error %s for csd_client_start_record",
402 __func__, dlerror());
403 goto error;
404 }
405 csd->stop_record = (stop_record_t)dlsym(csd->csd_client,
406 "csd_client_stop_record");
407 if (csd->stop_record == NULL) {
408 ALOGE("%s: dlsym error %s for csd_client_stop_record",
409 __func__, dlerror());
410 goto error;
411 }
412 csd->init = (init_t)dlsym(csd->csd_client, "csd_client_init");
413
414 if (csd->init == NULL) {
415 ALOGE("%s: dlsym error %s for csd_client_init",
416 __func__, dlerror());
417 goto error;
418 } else {
419 csd->init();
420 }
421 }
422 return csd;
423
424error:
425 free(csd);
426 csd = NULL;
427 return csd;
428}
429
430void close_csd_client(struct csd_data *csd)
431{
432 if (csd != NULL) {
433 csd->deinit();
434 dlclose(csd->csd_client);
435 free(csd);
436 csd = NULL;
437 }
438}
439
Eric Laurentb23d5282013-05-14 15:27:20 -0700440void *platform_init(struct audio_device *adev)
441{
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800442 char platform[PROPERTY_VALUE_MAX];
443 char baseband[PROPERTY_VALUE_MAX];
Eric Laurentb23d5282013-05-14 15:27:20 -0700444 char value[PROPERTY_VALUE_MAX];
Apoorv Raghuvanshi84fa2fe2013-12-04 11:57:47 -0800445 struct platform_data *my_data = NULL;
446 int retry_num = 0, snd_card_num = 0;
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700447 const char *snd_card_name;
sangwoo1b9f4b32013-06-21 18:22:55 -0700448
Eric Laurentb23d5282013-05-14 15:27:20 -0700449 my_data = calloc(1, sizeof(struct platform_data));
450
Apoorv Raghuvanshi84fa2fe2013-12-04 11:57:47 -0800451 while (snd_card_num < MAX_SND_CARD) {
452 adev->mixer = mixer_open(snd_card_num);
453
454 while (!adev->mixer && retry_num < RETRY_NUMBER) {
455 usleep(RETRY_US);
456 adev->mixer = mixer_open(snd_card_num);
457 retry_num++;
458 }
459
460 if (!adev->mixer) {
461 ALOGE("%s: Unable to open the mixer card: %d", __func__,
462 snd_card_num);
463 retry_num = 0;
464 snd_card_num++;
465 continue;
466 }
467
468 snd_card_name = mixer_get_name(adev->mixer);
469 ALOGV("%s: snd_card_name: %s", __func__, snd_card_name);
470
471 my_data->hw_info = hw_info_init(snd_card_name);
472 if (!my_data->hw_info) {
473 ALOGE("%s: Failed to init hardware info", __func__);
474 } else {
475 if (audio_extn_read_xml(adev, snd_card_num, MIXER_XML_PATH,
476 MIXER_XML_PATH_AUXPCM) == -ENOSYS)
477 adev->audio_route = audio_route_init(snd_card_num,
478 MIXER_XML_PATH);
479 if (!adev->audio_route) {
480 ALOGE("%s: Failed to init audio route controls, aborting.",
481 __func__);
482 free(my_data);
483 return NULL;
484 }
485 adev->snd_card = snd_card_num;
486 ALOGD("%s: Opened sound card:%d", __func__, snd_card_num);
487 break;
488 }
489 retry_num = 0;
490 snd_card_num++;
491 }
492
493 if (snd_card_num >= MAX_SND_CARD) {
494 ALOGE("%s: Unable to find correct sound card, aborting.", __func__);
495 free(my_data);
496 return NULL;
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700497 }
498
Eric Laurentb23d5282013-05-14 15:27:20 -0700499 my_data->adev = adev;
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700500 my_data->btsco_sample_rate = SAMPLE_RATE_8KHZ;
Eric Laurentb23d5282013-05-14 15:27:20 -0700501 my_data->fluence_in_spkr_mode = false;
502 my_data->fluence_in_voice_call = false;
503 my_data->fluence_in_voice_rec = false;
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800504 my_data->fluence_in_audio_rec = false;
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700505 my_data->fluence_type = FLUENCE_NONE;
Eric Laurentb23d5282013-05-14 15:27:20 -0700506
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700507 property_get("ro.qc.sdk.audio.fluencetype", value, "");
508 if (!strncmp("fluencepro", value, sizeof("fluencepro"))) {
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800509 my_data->fluence_type = FLUENCE_QUAD_MIC | FLUENCE_DUAL_MIC;
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700510 } else if (!strncmp("fluence", value, sizeof("fluence"))) {
511 my_data->fluence_type = FLUENCE_DUAL_MIC;
512 } else {
513 my_data->fluence_type = FLUENCE_NONE;
Eric Laurentb23d5282013-05-14 15:27:20 -0700514 }
515
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700516 if (my_data->fluence_type != FLUENCE_NONE) {
Eric Laurentb23d5282013-05-14 15:27:20 -0700517 property_get("persist.audio.fluence.voicecall",value,"");
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700518 if (!strncmp("true", value, sizeof("true"))) {
Eric Laurentb23d5282013-05-14 15:27:20 -0700519 my_data->fluence_in_voice_call = true;
520 }
521
522 property_get("persist.audio.fluence.voicerec",value,"");
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700523 if (!strncmp("true", value, sizeof("true"))) {
Eric Laurentb23d5282013-05-14 15:27:20 -0700524 my_data->fluence_in_voice_rec = true;
525 }
526
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -0800527 property_get("persist.audio.fluence.audiorec",value,"");
528 if (!strncmp("true", value, sizeof("true"))) {
529 my_data->fluence_in_audio_rec = true;
530 }
531
Eric Laurentb23d5282013-05-14 15:27:20 -0700532 property_get("persist.audio.fluence.speaker",value,"");
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700533 if (!strncmp("true", value, sizeof("true"))) {
Eric Laurentb23d5282013-05-14 15:27:20 -0700534 my_data->fluence_in_spkr_mode = true;
535 }
536 }
537
Ben Rombergerc1dc70d2013-12-19 15:11:17 -0800538 my_data->voice_feature_set = VOICE_FEATURE_SET_DEFAULT;
Eric Laurentb23d5282013-05-14 15:27:20 -0700539 my_data->acdb_handle = dlopen(LIB_ACDB_LOADER, RTLD_NOW);
540 if (my_data->acdb_handle == NULL) {
541 ALOGE("%s: DLOPEN failed for %s", __func__, LIB_ACDB_LOADER);
542 } else {
543 ALOGV("%s: DLOPEN successful for %s", __func__, LIB_ACDB_LOADER);
544 my_data->acdb_deallocate = (acdb_deallocate_t)dlsym(my_data->acdb_handle,
545 "acdb_loader_deallocate_ACDB");
Ben Rombergerc1dc70d2013-12-19 15:11:17 -0800546 if (!my_data->acdb_deallocate)
547 ALOGE("%s: Could not find the symbol acdb_loader_deallocate_ACDB from %s",
548 __func__, LIB_ACDB_LOADER);
549
Eric Laurentb23d5282013-05-14 15:27:20 -0700550 my_data->acdb_send_audio_cal = (acdb_send_audio_cal_t)dlsym(my_data->acdb_handle,
551 "acdb_loader_send_audio_cal");
552 if (!my_data->acdb_send_audio_cal)
Ben Rombergerc1dc70d2013-12-19 15:11:17 -0800553 ALOGE("%s: Could not find the symbol acdb_send_audio_cal from %s",
Eric Laurentb23d5282013-05-14 15:27:20 -0700554 __func__, LIB_ACDB_LOADER);
Ben Rombergerc1dc70d2013-12-19 15:11:17 -0800555
Eric Laurentb23d5282013-05-14 15:27:20 -0700556 my_data->acdb_send_voice_cal = (acdb_send_voice_cal_t)dlsym(my_data->acdb_handle,
557 "acdb_loader_send_voice_cal");
Ben Rombergerc1dc70d2013-12-19 15:11:17 -0800558 if (!my_data->acdb_send_voice_cal)
559 ALOGE("%s: Could not find the symbol acdb_loader_send_voice_cal from %s",
560 __func__, LIB_ACDB_LOADER);
561
562 my_data->acdb_reload_vocvoltable = (acdb_reload_vocvoltable_t)dlsym(my_data->acdb_handle,
563 "acdb_loader_reload_vocvoltable");
564 if (!my_data->acdb_reload_vocvoltable)
565 ALOGE("%s: Could not find the symbol acdb_loader_reload_vocvoltable from %s",
566 __func__, LIB_ACDB_LOADER);
567
Eric Laurentb23d5282013-05-14 15:27:20 -0700568 my_data->acdb_init = (acdb_init_t)dlsym(my_data->acdb_handle,
569 "acdb_loader_init_ACDB");
570 if (my_data->acdb_init == NULL)
571 ALOGE("%s: dlsym error %s for acdb_loader_init_ACDB", __func__, dlerror());
572 else
573 my_data->acdb_init();
574 }
575
Ben Romberger55886882014-01-10 13:49:02 -0800576 /* Initialize ACDB ID's */
577 platform_info_init();
578
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800579 /* If platform is apq8084 and baseband is MDM, load CSD Client specific
580 * symbols. Voice call is handled by MDM and apps processor talks to
581 * MDM through CSD Client
582 */
583 property_get("ro.board.platform", platform, "");
584 property_get("ro.baseband", baseband, "");
585 if (!strncmp("apq8084", platform, sizeof("apq8084")) &&
586 !strncmp("mdm", baseband, sizeof("mdm"))) {
587 my_data->csd = open_csd_client();
588 }
589
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -0700590 /* init usb */
591 audio_extn_usb_init(adev);
Apoorv Raghuvanshi84fa2fe2013-12-04 11:57:47 -0800592 /* update sound cards appropriately */
593 audio_extn_usb_set_proxy_sound_card(adev->snd_card);
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -0700594
Apoorv Raghuvanshi6178a3f2013-10-19 12:38:54 -0700595 /* Read one time ssr property */
Mingming Yin49be8032013-12-19 12:51:25 -0800596 audio_extn_ssr_update_enabled();
Gopikrishnaiah Anandanf538cef2013-10-28 14:06:03 -0700597 audio_extn_spkr_prot_init(adev);
Eric Laurentb23d5282013-05-14 15:27:20 -0700598 return my_data;
599}
600
601void platform_deinit(void *platform)
602{
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700603 struct platform_data *my_data = (struct platform_data *)platform;
604
605 hw_info_deinit(my_data->hw_info);
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800606 close_csd_client(my_data->csd);
607
Eric Laurentb23d5282013-05-14 15:27:20 -0700608 free(platform);
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -0700609 /* deinit usb */
610 audio_extn_usb_deinit();
Eric Laurentb23d5282013-05-14 15:27:20 -0700611}
612
613const char *platform_get_snd_device_name(snd_device_t snd_device)
614{
615 if (snd_device >= SND_DEVICE_MIN && snd_device < SND_DEVICE_MAX)
616 return device_table[snd_device];
617 else
618 return "";
619}
620
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700621int platform_get_snd_device_name_extn(void *platform, snd_device_t snd_device,
622 char *device_name)
623{
624 struct platform_data *my_data = (struct platform_data *)platform;
625
626 if (snd_device >= SND_DEVICE_MIN && snd_device < SND_DEVICE_MAX) {
627 strlcpy(device_name, device_table[snd_device], DEVICE_NAME_MAX_SIZE);
628 hw_info_append_hw_type(my_data->hw_info, snd_device, device_name);
629 } else {
630 strlcpy(device_name, "", DEVICE_NAME_MAX_SIZE);
631 return -EINVAL;
632 }
633
634 return 0;
635}
636
Eric Laurentb23d5282013-05-14 15:27:20 -0700637void platform_add_backend_name(char *mixer_path, snd_device_t snd_device)
638{
639 if (snd_device == SND_DEVICE_IN_BT_SCO_MIC)
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700640 strlcat(mixer_path, " bt-sco", MIXER_PATH_MAX_LENGTH);
641 else if (snd_device == SND_DEVICE_IN_BT_SCO_MIC_WB)
642 strlcat(mixer_path, " bt-sco-wb", MIXER_PATH_MAX_LENGTH);
Eric Laurentb23d5282013-05-14 15:27:20 -0700643 else if(snd_device == SND_DEVICE_OUT_BT_SCO)
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700644 strlcat(mixer_path, " bt-sco", MIXER_PATH_MAX_LENGTH);
645 else if(snd_device == SND_DEVICE_OUT_BT_SCO_WB)
646 strlcat(mixer_path, " bt-sco-wb", MIXER_PATH_MAX_LENGTH);
Eric Laurentb23d5282013-05-14 15:27:20 -0700647 else if (snd_device == SND_DEVICE_OUT_HDMI)
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700648 strlcat(mixer_path, " hdmi", MIXER_PATH_MAX_LENGTH);
Eric Laurentb23d5282013-05-14 15:27:20 -0700649 else if (snd_device == SND_DEVICE_OUT_SPEAKER_AND_HDMI)
650 strcat(mixer_path, " speaker-and-hdmi");
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -0700651 else if (snd_device == SND_DEVICE_OUT_AFE_PROXY)
652 strlcat(mixer_path, " afe-proxy", MIXER_PATH_MAX_LENGTH);
653 else if (snd_device == SND_DEVICE_OUT_USB_HEADSET)
654 strlcat(mixer_path, " usb-headphones", MIXER_PATH_MAX_LENGTH);
655 else if (snd_device == SND_DEVICE_OUT_SPEAKER_AND_USB_HEADSET)
656 strlcat(mixer_path, " speaker-and-usb-headphones",
657 MIXER_PATH_MAX_LENGTH);
658 else if (snd_device == SND_DEVICE_IN_USB_HEADSET_MIC)
659 strlcat(mixer_path, " usb-headset-mic", MIXER_PATH_MAX_LENGTH);
Apoorv Raghuvanshi6e262842013-10-06 14:39:35 -0700660 else if (snd_device == SND_DEVICE_IN_CAPTURE_FM)
661 strlcat(mixer_path, " capture-fm", MIXER_PATH_MAX_LENGTH);
662 else if (snd_device == SND_DEVICE_OUT_TRANSMISSION_FM)
663 strlcat(mixer_path, " transmission-fm", MIXER_PATH_MAX_LENGTH);
Eric Laurentb23d5282013-05-14 15:27:20 -0700664}
665
666int platform_get_pcm_device_id(audio_usecase_t usecase, int device_type)
667{
668 int device_id;
669 if (device_type == PCM_PLAYBACK)
670 device_id = pcm_device_table[usecase][0];
671 else
672 device_id = pcm_device_table[usecase][1];
673 return device_id;
674}
675
Ben Romberger55886882014-01-10 13:49:02 -0800676int platform_set_snd_device_acdb_id(snd_device_t snd_device, unsigned int acdb_id)
677{
678 int ret = 0;
679
680 if ((snd_device < SND_DEVICE_MIN) || (snd_device >= SND_DEVICE_MAX)) {
681 ALOGE("%s: Invalid snd_device = %d",
682 __func__, snd_device);
683 ret = -EINVAL;
684 goto done;
685 }
686
687 acdb_device_table[snd_device] = acdb_id;
688done:
689 return ret;
690}
691
Eric Laurentb23d5282013-05-14 15:27:20 -0700692int platform_send_audio_calibration(void *platform, snd_device_t snd_device)
693{
694 struct platform_data *my_data = (struct platform_data *)platform;
695 int acdb_dev_id, acdb_dev_type;
696
697 acdb_dev_id = acdb_device_table[snd_device];
698 if (acdb_dev_id < 0) {
699 ALOGE("%s: Could not find acdb id for device(%d)",
700 __func__, snd_device);
701 return -EINVAL;
702 }
703 if (my_data->acdb_send_audio_cal) {
Eric Laurent994a6932013-07-17 11:51:42 -0700704 ("%s: sending audio calibration for snd_device(%d) acdb_id(%d)",
Eric Laurentb23d5282013-05-14 15:27:20 -0700705 __func__, snd_device, acdb_dev_id);
706 if (snd_device >= SND_DEVICE_OUT_BEGIN &&
707 snd_device < SND_DEVICE_OUT_END)
708 acdb_dev_type = ACDB_DEV_TYPE_OUT;
709 else
710 acdb_dev_type = ACDB_DEV_TYPE_IN;
711 my_data->acdb_send_audio_cal(acdb_dev_id, acdb_dev_type);
712 }
713 return 0;
714}
715
716int platform_switch_voice_call_device_pre(void *platform)
717{
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800718 struct platform_data *my_data = (struct platform_data *)platform;
719 int ret = 0;
720
Vidyakumar Athota1fd21792013-11-15 14:50:57 -0800721 if (my_data->csd != NULL &&
722 my_data->adev->mode == AUDIO_MODE_IN_CALL) {
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800723 /* This must be called before disabling mixer controls on APQ side */
724 ret = my_data->csd->disable_device();
725 if (ret < 0) {
726 ALOGE("%s: csd_client_disable_device, failed, error %d",
727 __func__, ret);
728 }
729 }
730 return ret;
Eric Laurentb23d5282013-05-14 15:27:20 -0700731}
732
733int platform_switch_voice_call_device_post(void *platform,
734 snd_device_t out_snd_device,
735 snd_device_t in_snd_device)
736{
737 struct platform_data *my_data = (struct platform_data *)platform;
738 int acdb_rx_id, acdb_tx_id;
739
740 if (my_data->acdb_send_voice_cal == NULL) {
741 ALOGE("%s: dlsym error for acdb_send_voice_call", __func__);
742 } else {
Vidyakumar Athota1fd21792013-11-15 14:50:57 -0800743 acdb_rx_id = acdb_device_table[out_snd_device];
744 acdb_tx_id = acdb_device_table[in_snd_device];
745
Eric Laurentb23d5282013-05-14 15:27:20 -0700746 if (acdb_rx_id > 0 && acdb_tx_id > 0)
747 my_data->acdb_send_voice_cal(acdb_rx_id, acdb_tx_id);
748 else
749 ALOGE("%s: Incorrect ACDB IDs (rx: %d tx: %d)", __func__,
750 acdb_rx_id, acdb_tx_id);
751 }
752
Vidyakumar Athota1fd21792013-11-15 14:50:57 -0800753 return 0;
754}
755
756int platform_switch_voice_call_usecase_route_post(void *platform,
757 snd_device_t out_snd_device,
758 snd_device_t in_snd_device)
759{
760 struct platform_data *my_data = (struct platform_data *)platform;
761 int acdb_rx_id, acdb_tx_id;
762 int ret = 0;
763
764 acdb_rx_id = acdb_device_table[out_snd_device];
765 acdb_tx_id = acdb_device_table[in_snd_device];
766
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800767 if (my_data->csd != NULL) {
Vidyakumar Athota1fd21792013-11-15 14:50:57 -0800768 if (acdb_rx_id > 0 && acdb_tx_id > 0) {
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800769 ret = my_data->csd->enable_device(acdb_rx_id, acdb_tx_id,
770 my_data->adev->acdb_settings);
771 if (ret < 0) {
772 ALOGE("%s: csd_enable_device, failed, error %d",
773 __func__, ret);
774 }
775 } else {
776 ALOGE("%s: Incorrect ACDB IDs (rx: %d tx: %d)", __func__,
777 acdb_rx_id, acdb_tx_id);
778 }
779 }
780 return ret;
Eric Laurentb23d5282013-05-14 15:27:20 -0700781}
782
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800783int platform_start_voice_call(void *platform, uint32_t vsid)
Eric Laurentb23d5282013-05-14 15:27:20 -0700784{
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800785 struct platform_data *my_data = (struct platform_data *)platform;
786 int ret = 0;
787
788 if (my_data->csd != NULL) {
789 ret = my_data->csd->start_voice(vsid);
790 if (ret < 0) {
791 ALOGE("%s: csd_start_voice error %d\n", __func__, ret);
792 }
793 }
794 return ret;
Eric Laurentb23d5282013-05-14 15:27:20 -0700795}
796
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800797int platform_stop_voice_call(void *platform, uint32_t vsid)
Eric Laurentb23d5282013-05-14 15:27:20 -0700798{
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800799 struct platform_data *my_data = (struct platform_data *)platform;
800 int ret = 0;
801
802 if (my_data->csd != NULL) {
803 ret = my_data->csd->stop_voice(vsid);
804 if (ret < 0) {
805 ALOGE("%s: csd_stop_voice error %d\n", __func__, ret);
806 }
807 }
808 return ret;
Eric Laurentb23d5282013-05-14 15:27:20 -0700809}
810
811int platform_set_voice_volume(void *platform, int volume)
812{
813 struct platform_data *my_data = (struct platform_data *)platform;
814 struct audio_device *adev = my_data->adev;
815 struct mixer_ctl *ctl;
sangwoo53b2cf02013-07-25 19:18:44 -0700816 const char *mixer_ctl_name = "Voice Rx Gain";
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800817 int vol_index = 0, ret = 0;
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700818 uint32_t set_values[ ] = {0,
819 ALL_SESSION_VSID,
820 DEFAULT_VOLUME_RAMP_DURATION_MS};
Eric Laurentb23d5282013-05-14 15:27:20 -0700821
822 // Voice volume levels are mapped to adsp volume levels as follows.
823 // 100 -> 5, 80 -> 4, 60 -> 3, 40 -> 2, 20 -> 1 0 -> 0
824 // But this values don't changed in kernel. So, below change is need.
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700825 vol_index = (int)percent_to_index(volume, MIN_VOL_INDEX, MAX_VOL_INDEX);
826 set_values[0] = vol_index;
Eric Laurentb23d5282013-05-14 15:27:20 -0700827
828 ctl = mixer_get_ctl_by_name(adev->mixer, mixer_ctl_name);
829 if (!ctl) {
830 ALOGE("%s: Could not get ctl for mixer cmd - %s",
831 __func__, mixer_ctl_name);
832 return -EINVAL;
833 }
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700834 ALOGV("Setting voice volume index: %d", set_values[0]);
835 mixer_ctl_set_array(ctl, set_values, ARRAY_SIZE(set_values));
Eric Laurentb23d5282013-05-14 15:27:20 -0700836
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800837 if (my_data->csd != NULL) {
838 ret = my_data->csd->volume(ALL_SESSION_VSID, volume);
839 if (ret < 0) {
840 ALOGE("%s: csd_volume error %d", __func__, ret);
841 }
842 }
843 return ret;
Eric Laurentb23d5282013-05-14 15:27:20 -0700844}
845
846int platform_set_mic_mute(void *platform, bool state)
847{
848 struct platform_data *my_data = (struct platform_data *)platform;
849 struct audio_device *adev = my_data->adev;
850 struct mixer_ctl *ctl;
851 const char *mixer_ctl_name = "Voice Tx Mute";
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800852 int ret = 0;
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700853 uint32_t set_values[ ] = {0,
854 ALL_SESSION_VSID,
855 DEFAULT_VOLUME_RAMP_DURATION_MS};
Eric Laurentb23d5282013-05-14 15:27:20 -0700856
Narsinga Rao Chella05573b72013-11-15 15:21:40 -0800857 set_values[0] = state;
858 ctl = mixer_get_ctl_by_name(adev->mixer, mixer_ctl_name);
859 if (!ctl) {
860 ALOGE("%s: Could not get ctl for mixer cmd - %s",
861 __func__, mixer_ctl_name);
862 return -EINVAL;
863 }
864 ALOGV("Setting voice mute state: %d", state);
865 mixer_ctl_set_array(ctl, set_values, ARRAY_SIZE(set_values));
Eric Laurentb23d5282013-05-14 15:27:20 -0700866
Narsinga Rao Chella05573b72013-11-15 15:21:40 -0800867 if (my_data->csd != NULL) {
868 ret = my_data->csd->mic_mute(ALL_SESSION_VSID, state);
869 if (ret < 0) {
870 ALOGE("%s: csd_mic_mute error %d", __func__, ret);
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -0800871 }
872 }
873 return ret;
Eric Laurentb23d5282013-05-14 15:27:20 -0700874}
875
876snd_device_t platform_get_output_snd_device(void *platform, audio_devices_t devices)
877{
878 struct platform_data *my_data = (struct platform_data *)platform;
879 struct audio_device *adev = my_data->adev;
880 audio_mode_t mode = adev->mode;
881 snd_device_t snd_device = SND_DEVICE_NONE;
882
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -0700883 audio_channel_mask_t channel_mask = (adev->active_input == NULL) ?
884 AUDIO_CHANNEL_IN_MONO : adev->active_input->channel_mask;
885 int channel_count = popcount(channel_mask);
886
Eric Laurentb23d5282013-05-14 15:27:20 -0700887 ALOGV("%s: enter: output devices(%#x)", __func__, devices);
888 if (devices == AUDIO_DEVICE_NONE ||
889 devices & AUDIO_DEVICE_BIT_IN) {
890 ALOGV("%s: Invalid output devices (%#x)", __func__, devices);
891 goto exit;
892 }
893
Mingming Yin4a72d652014-01-03 18:54:18 -0800894 if (popcount(devices) == 2) {
895 if (devices == (AUDIO_DEVICE_OUT_WIRED_HEADPHONE |
896 AUDIO_DEVICE_OUT_SPEAKER)) {
897 snd_device = SND_DEVICE_OUT_SPEAKER_AND_HEADPHONES;
898 } else if (devices == (AUDIO_DEVICE_OUT_WIRED_HEADSET |
899 AUDIO_DEVICE_OUT_SPEAKER)) {
900 if (audio_extn_get_anc_enabled())
901 snd_device = SND_DEVICE_OUT_SPEAKER_AND_ANC_HEADSET;
902 else
903 snd_device = SND_DEVICE_OUT_SPEAKER_AND_HEADPHONES;
904 } else if (devices == (AUDIO_DEVICE_OUT_AUX_DIGITAL |
905 AUDIO_DEVICE_OUT_SPEAKER)) {
906 snd_device = SND_DEVICE_OUT_SPEAKER_AND_HDMI;
907 } else if (devices == (AUDIO_DEVICE_OUT_ANLG_DOCK_HEADSET |
908 AUDIO_DEVICE_OUT_SPEAKER)) {
909 snd_device = SND_DEVICE_OUT_SPEAKER_AND_USB_HEADSET;
910 } else {
911 ALOGE("%s: Invalid combo device(%#x)", __func__, devices);
912 goto exit;
913 }
914 if (snd_device != SND_DEVICE_NONE) {
915 goto exit;
916 }
917 }
918
919 if (popcount(devices) != 1) {
920 ALOGE("%s: Invalid output devices(%#x)", __func__, devices);
921 goto exit;
922 }
923
Narsinga Rao Chella05573b72013-11-15 15:21:40 -0800924 if ((mode == AUDIO_MODE_IN_CALL) ||
925 voice_extn_compress_voip_is_active(adev)) {
Eric Laurentb23d5282013-05-14 15:27:20 -0700926 if (devices & AUDIO_DEVICE_OUT_WIRED_HEADPHONE ||
927 devices & AUDIO_DEVICE_OUT_WIRED_HEADSET) {
Narsinga Rao Chella05573b72013-11-15 15:21:40 -0800928 if ((adev->voice.tty_mode != TTY_MODE_OFF) &&
929 !voice_extn_compress_voip_is_active(adev)) {
930 switch (adev->voice.tty_mode) {
931 case TTY_MODE_FULL:
932 snd_device = SND_DEVICE_OUT_VOICE_TTY_FULL_HEADPHONES;
933 break;
934 case TTY_MODE_VCO:
935 snd_device = SND_DEVICE_OUT_VOICE_TTY_VCO_HEADPHONES;
936 break;
937 case TTY_MODE_HCO:
938 snd_device = SND_DEVICE_OUT_VOICE_TTY_HCO_HANDSET;
939 break;
940 default:
941 ALOGE("%s: Invalid TTY mode (%#x)",
942 __func__, adev->voice.tty_mode);
943 }
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700944 } else if (audio_extn_get_anc_enabled()) {
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -0700945 if (audio_extn_should_use_fb_anc())
946 snd_device = SND_DEVICE_OUT_VOICE_ANC_FB_HEADSET;
947 else
948 snd_device = SND_DEVICE_OUT_VOICE_ANC_HEADSET;
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700949 } else {
Eric Laurentb23d5282013-05-14 15:27:20 -0700950 snd_device = SND_DEVICE_OUT_VOICE_HEADPHONES;
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700951 }
Eric Laurentb23d5282013-05-14 15:27:20 -0700952 } else if (devices & AUDIO_DEVICE_OUT_ALL_SCO) {
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700953 if (my_data->btsco_sample_rate == SAMPLE_RATE_16KHZ)
954 snd_device = SND_DEVICE_OUT_BT_SCO_WB;
955 else
956 snd_device = SND_DEVICE_OUT_BT_SCO;
Eric Laurentb23d5282013-05-14 15:27:20 -0700957 } else if (devices & AUDIO_DEVICE_OUT_SPEAKER) {
958 snd_device = SND_DEVICE_OUT_VOICE_SPEAKER;
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -0700959 } else if (devices & AUDIO_DEVICE_OUT_ANLG_DOCK_HEADSET ||
960 devices & AUDIO_DEVICE_OUT_DGTL_DOCK_HEADSET) {
961 snd_device = SND_DEVICE_OUT_USB_HEADSET;
Apoorv Raghuvanshi6e262842013-10-06 14:39:35 -0700962 } else if (devices & AUDIO_DEVICE_OUT_FM_TX) {
963 snd_device = SND_DEVICE_OUT_TRANSMISSION_FM;
Eric Laurentb23d5282013-05-14 15:27:20 -0700964 } else if (devices & AUDIO_DEVICE_OUT_EARPIECE) {
Ravi Kumar Alamandaceb40822013-11-06 11:01:47 -0800965 if (audio_extn_should_use_handset_anc(channel_count))
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -0700966 snd_device = SND_DEVICE_OUT_ANC_HANDSET;
Eric Laurentb23d5282013-05-14 15:27:20 -0700967 else
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700968 snd_device = SND_DEVICE_OUT_VOICE_HANDSET;
Eric Laurentb23d5282013-05-14 15:27:20 -0700969 }
970 if (snd_device != SND_DEVICE_NONE) {
971 goto exit;
972 }
973 }
974
Eric Laurentb23d5282013-05-14 15:27:20 -0700975 if (devices & AUDIO_DEVICE_OUT_WIRED_HEADPHONE ||
976 devices & AUDIO_DEVICE_OUT_WIRED_HEADSET) {
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -0700977 if (devices & AUDIO_DEVICE_OUT_WIRED_HEADSET
978 && audio_extn_get_anc_enabled()) {
979 if (audio_extn_should_use_fb_anc())
980 snd_device = SND_DEVICE_OUT_ANC_FB_HEADSET;
981 else
982 snd_device = SND_DEVICE_OUT_ANC_HEADSET;
983 }
984 else
985 snd_device = SND_DEVICE_OUT_HEADPHONES;
Eric Laurentb23d5282013-05-14 15:27:20 -0700986 } else if (devices & AUDIO_DEVICE_OUT_SPEAKER) {
987 if (adev->speaker_lr_swap)
988 snd_device = SND_DEVICE_OUT_SPEAKER_REVERSE;
989 else
990 snd_device = SND_DEVICE_OUT_SPEAKER;
991 } else if (devices & AUDIO_DEVICE_OUT_ALL_SCO) {
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700992 if (my_data->btsco_sample_rate == SAMPLE_RATE_16KHZ)
993 snd_device = SND_DEVICE_OUT_BT_SCO_WB;
994 else
995 snd_device = SND_DEVICE_OUT_BT_SCO;
Eric Laurentb23d5282013-05-14 15:27:20 -0700996 } else if (devices & AUDIO_DEVICE_OUT_AUX_DIGITAL) {
997 snd_device = SND_DEVICE_OUT_HDMI ;
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -0700998 } else if (devices & AUDIO_DEVICE_OUT_ANLG_DOCK_HEADSET ||
999 devices & AUDIO_DEVICE_OUT_DGTL_DOCK_HEADSET) {
1000 snd_device = SND_DEVICE_OUT_USB_HEADSET;
Apoorv Raghuvanshi6e262842013-10-06 14:39:35 -07001001 } else if (devices & AUDIO_DEVICE_OUT_FM_TX) {
1002 snd_device = SND_DEVICE_OUT_TRANSMISSION_FM;
Eric Laurentb23d5282013-05-14 15:27:20 -07001003 } else if (devices & AUDIO_DEVICE_OUT_EARPIECE) {
1004 snd_device = SND_DEVICE_OUT_HANDSET;
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -07001005 } else if (devices & AUDIO_DEVICE_OUT_PROXY) {
1006 ALOGD("%s: setting sink capability for Proxy", __func__);
1007 audio_extn_set_afe_proxy_channel_mixer(adev);
1008 snd_device = SND_DEVICE_OUT_AFE_PROXY;
Eric Laurentb23d5282013-05-14 15:27:20 -07001009 } else {
1010 ALOGE("%s: Unknown device(s) %#x", __func__, devices);
1011 }
1012exit:
1013 ALOGV("%s: exit: snd_device(%s)", __func__, device_table[snd_device]);
1014 return snd_device;
1015}
1016
1017snd_device_t platform_get_input_snd_device(void *platform, audio_devices_t out_device)
1018{
1019 struct platform_data *my_data = (struct platform_data *)platform;
1020 struct audio_device *adev = my_data->adev;
1021 audio_source_t source = (adev->active_input == NULL) ?
1022 AUDIO_SOURCE_DEFAULT : adev->active_input->source;
1023
1024 audio_mode_t mode = adev->mode;
1025 audio_devices_t in_device = ((adev->active_input == NULL) ?
1026 AUDIO_DEVICE_NONE : adev->active_input->device)
1027 & ~AUDIO_DEVICE_BIT_IN;
1028 audio_channel_mask_t channel_mask = (adev->active_input == NULL) ?
1029 AUDIO_CHANNEL_IN_MONO : adev->active_input->channel_mask;
1030 snd_device_t snd_device = SND_DEVICE_NONE;
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -07001031 int channel_count = popcount(channel_mask);
Eric Laurentb23d5282013-05-14 15:27:20 -07001032
1033 ALOGV("%s: enter: out_device(%#x) in_device(%#x)",
1034 __func__, out_device, in_device);
Helen Zeng067b96b2013-11-26 12:10:29 -08001035 if ((out_device != AUDIO_DEVICE_NONE) && ((mode == AUDIO_MODE_IN_CALL) ||
1036 voice_extn_compress_voip_is_active(adev))) {
Narsinga Rao Chella05573b72013-11-15 15:21:40 -08001037 if ((adev->voice.tty_mode != TTY_MODE_OFF) &&
1038 !voice_extn_compress_voip_is_active(adev)) {
Eric Laurentb23d5282013-05-14 15:27:20 -07001039 if (out_device & AUDIO_DEVICE_OUT_WIRED_HEADPHONE ||
1040 out_device & AUDIO_DEVICE_OUT_WIRED_HEADSET) {
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001041 switch (adev->voice.tty_mode) {
Eric Laurentb23d5282013-05-14 15:27:20 -07001042 case TTY_MODE_FULL:
1043 snd_device = SND_DEVICE_IN_VOICE_TTY_FULL_HEADSET_MIC;
1044 break;
1045 case TTY_MODE_VCO:
1046 snd_device = SND_DEVICE_IN_VOICE_TTY_VCO_HANDSET_MIC;
1047 break;
1048 case TTY_MODE_HCO:
1049 snd_device = SND_DEVICE_IN_VOICE_TTY_HCO_HEADSET_MIC;
1050 break;
1051 default:
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001052 ALOGE("%s: Invalid TTY mode (%#x)",
1053 __func__, adev->voice.tty_mode);
Eric Laurentb23d5282013-05-14 15:27:20 -07001054 }
1055 goto exit;
1056 }
1057 }
1058 if (out_device & AUDIO_DEVICE_OUT_EARPIECE ||
1059 out_device & AUDIO_DEVICE_OUT_WIRED_HEADPHONE) {
Apoorv Raghuvanshi9eaf94e2013-10-04 16:13:44 -07001060 if (out_device & AUDIO_DEVICE_OUT_EARPIECE &&
1061 audio_extn_should_use_handset_anc(channel_count)) {
1062 snd_device = SND_DEVICE_IN_AANC_HANDSET_MIC;
1063 } else if (my_data->fluence_type == FLUENCE_NONE ||
Mingming Yin8e5a4f62013-10-07 15:23:41 -07001064 my_data->fluence_in_voice_call == false) {
Eric Laurentb23d5282013-05-14 15:27:20 -07001065 snd_device = SND_DEVICE_IN_HANDSET_MIC;
Laxminath Kasam7294f522013-12-11 05:07:00 +05301066 set_echo_reference(adev->mixer, EC_REF_RX);
Eric Laurentb23d5282013-05-14 15:27:20 -07001067 } else {
Ravi Kumar Alamandaceb40822013-11-06 11:01:47 -08001068 snd_device = SND_DEVICE_IN_VOICE_DMIC;
Mingming Yin8e5a4f62013-10-07 15:23:41 -07001069 adev->acdb_settings |= DMIC_FLAG;
Eric Laurentb23d5282013-05-14 15:27:20 -07001070 }
1071 } else if (out_device & AUDIO_DEVICE_OUT_WIRED_HEADSET) {
1072 snd_device = SND_DEVICE_IN_VOICE_HEADSET_MIC;
1073 } else if (out_device & AUDIO_DEVICE_OUT_ALL_SCO) {
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001074 if (my_data->btsco_sample_rate == SAMPLE_RATE_16KHZ)
1075 snd_device = SND_DEVICE_IN_BT_SCO_MIC_WB;
1076 else
1077 snd_device = SND_DEVICE_IN_BT_SCO_MIC;
Eric Laurentb23d5282013-05-14 15:27:20 -07001078 } else if (out_device & AUDIO_DEVICE_OUT_SPEAKER) {
Mingming Yin8e5a4f62013-10-07 15:23:41 -07001079 if (my_data->fluence_type != FLUENCE_NONE &&
1080 my_data->fluence_in_voice_call &&
1081 my_data->fluence_in_spkr_mode) {
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -08001082 if(my_data->fluence_type & FLUENCE_QUAD_MIC) {
Mingming Yin8e5a4f62013-10-07 15:23:41 -07001083 adev->acdb_settings |= QMIC_FLAG;
1084 snd_device = SND_DEVICE_IN_VOICE_SPEAKER_QMIC;
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -08001085 } else {
1086 adev->acdb_settings |= DMIC_FLAG;
1087 snd_device = SND_DEVICE_IN_VOICE_SPEAKER_DMIC;
Mingming Yin8e5a4f62013-10-07 15:23:41 -07001088 }
Eric Laurentb23d5282013-05-14 15:27:20 -07001089 } else {
1090 snd_device = SND_DEVICE_IN_VOICE_SPEAKER_MIC;
1091 }
1092 }
1093 } else if (source == AUDIO_SOURCE_CAMCORDER) {
1094 if (in_device & AUDIO_DEVICE_IN_BUILTIN_MIC ||
1095 in_device & AUDIO_DEVICE_IN_BACK_MIC) {
1096 snd_device = SND_DEVICE_IN_CAMCORDER_MIC;
1097 }
1098 } else if (source == AUDIO_SOURCE_VOICE_RECOGNITION) {
1099 if (in_device & AUDIO_DEVICE_IN_BUILTIN_MIC) {
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -08001100 if (channel_count == 2) {
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -08001101 snd_device = SND_DEVICE_IN_VOICE_REC_DMIC_STEREO;
Mingming Yin8e5a4f62013-10-07 15:23:41 -07001102 adev->acdb_settings |= DMIC_FLAG;
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -08001103 } else if (adev->active_input->enable_ns)
1104 snd_device = SND_DEVICE_IN_VOICE_REC_MIC_NS;
1105 else if (my_data->fluence_type != FLUENCE_NONE &&
1106 my_data->fluence_in_voice_rec) {
1107 snd_device = SND_DEVICE_IN_VOICE_REC_DMIC_FLUENCE;
1108 adev->acdb_settings |= DMIC_FLAG;
1109 } else {
1110 snd_device = SND_DEVICE_IN_VOICE_REC_MIC;
1111 }
Eric Laurentb23d5282013-05-14 15:27:20 -07001112 }
1113 } else if (source == AUDIO_SOURCE_VOICE_COMMUNICATION) {
1114 if (out_device & AUDIO_DEVICE_OUT_SPEAKER)
1115 in_device = AUDIO_DEVICE_IN_BACK_MIC;
1116 if (adev->active_input) {
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -08001117 if (adev->active_input->enable_aec &&
1118 adev->active_input->enable_ns) {
Eric Laurentb23d5282013-05-14 15:27:20 -07001119 if (in_device & AUDIO_DEVICE_IN_BACK_MIC) {
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -08001120 if (my_data->fluence_type & FLUENCE_DUAL_MIC &&
1121 my_data->fluence_in_spkr_mode) {
1122 snd_device = SND_DEVICE_IN_SPEAKER_DMIC_AEC_NS;
1123 adev->acdb_settings |= DMIC_FLAG;
1124 } else
1125 snd_device = SND_DEVICE_IN_SPEAKER_MIC_AEC_NS;
Eric Laurentb23d5282013-05-14 15:27:20 -07001126 } else if (in_device & AUDIO_DEVICE_IN_BUILTIN_MIC) {
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -08001127 if (my_data->fluence_type & FLUENCE_DUAL_MIC) {
1128 snd_device = SND_DEVICE_IN_HANDSET_DMIC_AEC_NS;
1129 adev->acdb_settings |= DMIC_FLAG;
1130 } else
1131 snd_device = SND_DEVICE_IN_HANDSET_MIC_AEC_NS;
Eric Laurentb23d5282013-05-14 15:27:20 -07001132 } else if (in_device & AUDIO_DEVICE_IN_WIRED_HEADSET) {
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -08001133 snd_device = SND_DEVICE_IN_HEADSET_MIC_FLUENCE;
Eric Laurentb23d5282013-05-14 15:27:20 -07001134 }
Laxminath Kasam7294f522013-12-11 05:07:00 +05301135 set_echo_reference(adev->mixer, EC_REF_RX);
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -08001136 } else if (adev->active_input->enable_aec) {
1137 if (in_device & AUDIO_DEVICE_IN_BACK_MIC) {
1138 if (my_data->fluence_type & FLUENCE_DUAL_MIC) {
1139 snd_device = SND_DEVICE_IN_SPEAKER_DMIC_AEC;
1140 adev->acdb_settings |= DMIC_FLAG;
1141 } else
1142 snd_device = SND_DEVICE_IN_SPEAKER_MIC_AEC;
1143 } else if (in_device & AUDIO_DEVICE_IN_BUILTIN_MIC) {
1144 if (my_data->fluence_type & FLUENCE_DUAL_MIC) {
1145 snd_device = SND_DEVICE_IN_HANDSET_DMIC_AEC;
1146 adev->acdb_settings |= DMIC_FLAG;
1147 } else
1148 snd_device = SND_DEVICE_IN_HANDSET_MIC_AEC;
1149 } else if (in_device & AUDIO_DEVICE_IN_WIRED_HEADSET) {
1150 snd_device = SND_DEVICE_IN_HEADSET_MIC_FLUENCE;
1151 }
Laxminath Kasam7294f522013-12-11 05:07:00 +05301152 set_echo_reference(adev->mixer, EC_REF_RX);
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -08001153 } else if (adev->active_input->enable_ns) {
1154 if (in_device & AUDIO_DEVICE_IN_BACK_MIC) {
1155 if (my_data->fluence_type & FLUENCE_DUAL_MIC) {
1156 snd_device = SND_DEVICE_IN_SPEAKER_DMIC_NS;
1157 adev->acdb_settings |= DMIC_FLAG;
1158 } else
1159 snd_device = SND_DEVICE_IN_SPEAKER_MIC_NS;
1160 } else if (in_device & AUDIO_DEVICE_IN_BUILTIN_MIC) {
1161 if (my_data->fluence_type & FLUENCE_DUAL_MIC) {
1162 snd_device = SND_DEVICE_IN_HANDSET_DMIC_NS;
1163 adev->acdb_settings |= DMIC_FLAG;
1164 } else
1165 snd_device = SND_DEVICE_IN_HANDSET_MIC_NS;
1166 } else if (in_device & AUDIO_DEVICE_IN_WIRED_HEADSET) {
1167 snd_device = SND_DEVICE_IN_HEADSET_MIC_FLUENCE;
1168 }
1169 set_echo_reference(adev->mixer, "NONE");
Eric Laurentb23d5282013-05-14 15:27:20 -07001170 } else
1171 set_echo_reference(adev->mixer, "NONE");
1172 }
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -08001173 } else if (source == AUDIO_SOURCE_MIC) {
Apoorv Raghuvanshic0536542013-11-14 16:25:59 -08001174 if (in_device & AUDIO_DEVICE_IN_BUILTIN_MIC &&
1175 channel_count == 1 ) {
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -08001176 if(my_data->fluence_type & FLUENCE_DUAL_MIC &&
1177 my_data->fluence_in_audio_rec)
1178 snd_device = SND_DEVICE_IN_HANDSET_DMIC;
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -08001179 }
Mingming Yinab429782013-11-07 11:16:55 -08001180 } else if (source == AUDIO_SOURCE_FM_RX ||
Ravi Kumar Alamanda198185e2013-11-07 15:42:19 -08001181 source == AUDIO_SOURCE_FM_RX_A2DP) {
Preetam Singh Ranawatde84f1a2013-11-01 14:58:16 -07001182 snd_device = SND_DEVICE_IN_CAPTURE_FM;
Eric Laurentb23d5282013-05-14 15:27:20 -07001183 } else if (source == AUDIO_SOURCE_DEFAULT) {
1184 goto exit;
1185 }
1186
1187
1188 if (snd_device != SND_DEVICE_NONE) {
1189 goto exit;
1190 }
1191
1192 if (in_device != AUDIO_DEVICE_NONE &&
1193 !(in_device & AUDIO_DEVICE_IN_VOICE_CALL) &&
1194 !(in_device & AUDIO_DEVICE_IN_COMMUNICATION)) {
1195 if (in_device & AUDIO_DEVICE_IN_BUILTIN_MIC) {
Apoorv Raghuvanshi6178a3f2013-10-19 12:38:54 -07001196 if (audio_extn_ssr_get_enabled() && channel_count == 6)
1197 snd_device = SND_DEVICE_IN_QUAD_MIC;
Ravi Kumar Alamandafae42112013-11-07 23:31:54 -08001198 else if (channel_count == 2)
Apoorv Raghuvanshi6bd8dbf2013-10-19 18:37:52 -07001199 snd_device = SND_DEVICE_IN_HANDSET_STEREO_DMIC;
Apoorv Raghuvanshi6178a3f2013-10-19 12:38:54 -07001200 else
1201 snd_device = SND_DEVICE_IN_HANDSET_MIC;
Eric Laurentb23d5282013-05-14 15:27:20 -07001202 } else if (in_device & AUDIO_DEVICE_IN_BACK_MIC) {
1203 snd_device = SND_DEVICE_IN_SPEAKER_MIC;
1204 } else if (in_device & AUDIO_DEVICE_IN_WIRED_HEADSET) {
1205 snd_device = SND_DEVICE_IN_HEADSET_MIC;
1206 } else if (in_device & AUDIO_DEVICE_IN_BLUETOOTH_SCO_HEADSET) {
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001207 if (my_data->btsco_sample_rate == SAMPLE_RATE_16KHZ)
1208 snd_device = SND_DEVICE_IN_BT_SCO_MIC_WB;
1209 else
1210 snd_device = SND_DEVICE_IN_BT_SCO_MIC;
Eric Laurentb23d5282013-05-14 15:27:20 -07001211 } else if (in_device & AUDIO_DEVICE_IN_AUX_DIGITAL) {
1212 snd_device = SND_DEVICE_IN_HDMI_MIC;
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -07001213 } else if (in_device & AUDIO_DEVICE_IN_ANLG_DOCK_HEADSET ||
1214 in_device & AUDIO_DEVICE_IN_DGTL_DOCK_HEADSET) {
1215 snd_device = SND_DEVICE_IN_USB_HEADSET_MIC;
Apoorv Raghuvanshi6e262842013-10-06 14:39:35 -07001216 } else if (in_device & AUDIO_DEVICE_IN_FM_RX) {
1217 snd_device = SND_DEVICE_IN_CAPTURE_FM;
Eric Laurentb23d5282013-05-14 15:27:20 -07001218 } else {
1219 ALOGE("%s: Unknown input device(s) %#x", __func__, in_device);
1220 ALOGW("%s: Using default handset-mic", __func__);
1221 snd_device = SND_DEVICE_IN_HANDSET_MIC;
1222 }
1223 } else {
1224 if (out_device & AUDIO_DEVICE_OUT_EARPIECE) {
1225 snd_device = SND_DEVICE_IN_HANDSET_MIC;
1226 } else if (out_device & AUDIO_DEVICE_OUT_WIRED_HEADSET) {
1227 snd_device = SND_DEVICE_IN_HEADSET_MIC;
1228 } else if (out_device & AUDIO_DEVICE_OUT_SPEAKER) {
Apoorv Raghuvanshi6bd8dbf2013-10-19 18:37:52 -07001229 if (channel_count > 1)
1230 snd_device = SND_DEVICE_IN_SPEAKER_STEREO_DMIC;
1231 else
1232 snd_device = SND_DEVICE_IN_SPEAKER_MIC;
Eric Laurentb23d5282013-05-14 15:27:20 -07001233 } else if (out_device & AUDIO_DEVICE_OUT_WIRED_HEADPHONE) {
1234 snd_device = SND_DEVICE_IN_HANDSET_MIC;
1235 } else if (out_device & AUDIO_DEVICE_OUT_BLUETOOTH_SCO_HEADSET) {
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001236 if (my_data->btsco_sample_rate == SAMPLE_RATE_16KHZ)
1237 snd_device = SND_DEVICE_IN_BT_SCO_MIC_WB;
1238 else
1239 snd_device = SND_DEVICE_IN_BT_SCO_MIC;
Eric Laurentb23d5282013-05-14 15:27:20 -07001240 } else if (out_device & AUDIO_DEVICE_OUT_AUX_DIGITAL) {
1241 snd_device = SND_DEVICE_IN_HDMI_MIC;
Apoorv Raghuvanshi5792d4b2013-10-07 18:40:05 -07001242 } else if (out_device & AUDIO_DEVICE_OUT_ANLG_DOCK_HEADSET ||
1243 out_device & AUDIO_DEVICE_OUT_DGTL_DOCK_HEADSET) {
1244 snd_device = SND_DEVICE_IN_USB_HEADSET_MIC;
Eric Laurentb23d5282013-05-14 15:27:20 -07001245 } else {
1246 ALOGE("%s: Unknown output device(s) %#x", __func__, out_device);
1247 ALOGW("%s: Using default handset-mic", __func__);
1248 snd_device = SND_DEVICE_IN_HANDSET_MIC;
1249 }
1250 }
1251exit:
1252 ALOGV("%s: exit: in_snd_device(%s)", __func__, device_table[snd_device]);
1253 return snd_device;
1254}
1255
1256int platform_set_hdmi_channels(void *platform, int channel_count)
1257{
1258 struct platform_data *my_data = (struct platform_data *)platform;
1259 struct audio_device *adev = my_data->adev;
1260 struct mixer_ctl *ctl;
1261 const char *channel_cnt_str = NULL;
1262 const char *mixer_ctl_name = "HDMI_RX Channels";
1263 switch (channel_count) {
1264 case 8:
1265 channel_cnt_str = "Eight"; break;
1266 case 7:
1267 channel_cnt_str = "Seven"; break;
1268 case 6:
1269 channel_cnt_str = "Six"; break;
1270 case 5:
1271 channel_cnt_str = "Five"; break;
1272 case 4:
1273 channel_cnt_str = "Four"; break;
1274 case 3:
1275 channel_cnt_str = "Three"; break;
1276 default:
1277 channel_cnt_str = "Two"; break;
1278 }
1279 ctl = mixer_get_ctl_by_name(adev->mixer, mixer_ctl_name);
1280 if (!ctl) {
1281 ALOGE("%s: Could not get ctl for mixer cmd - %s",
1282 __func__, mixer_ctl_name);
1283 return -EINVAL;
1284 }
1285 ALOGV("HDMI channel count: %s", channel_cnt_str);
1286 mixer_ctl_set_enum_by_string(ctl, channel_cnt_str);
1287 return 0;
1288}
1289
Haynes Mathew George47cd4cb2013-07-19 11:58:50 -07001290int platform_edid_get_max_channels(void *platform)
Eric Laurentb23d5282013-05-14 15:27:20 -07001291{
Haynes Mathew George47cd4cb2013-07-19 11:58:50 -07001292 struct platform_data *my_data = (struct platform_data *)platform;
1293 struct audio_device *adev = my_data->adev;
Eric Laurentb23d5282013-05-14 15:27:20 -07001294 char block[MAX_SAD_BLOCKS * SAD_BLOCK_SIZE];
1295 char *sad = block;
1296 int num_audio_blocks;
1297 int channel_count;
1298 int max_channels = 0;
Haynes Mathew George47cd4cb2013-07-19 11:58:50 -07001299 int i, ret, count;
Eric Laurentb23d5282013-05-14 15:27:20 -07001300
Haynes Mathew George47cd4cb2013-07-19 11:58:50 -07001301 struct mixer_ctl *ctl;
1302
1303 ctl = mixer_get_ctl_by_name(adev->mixer, AUDIO_DATA_BLOCK_MIXER_CTL);
1304 if (!ctl) {
1305 ALOGE("%s: Could not get ctl for mixer cmd - %s",
1306 __func__, AUDIO_DATA_BLOCK_MIXER_CTL);
Eric Laurentb23d5282013-05-14 15:27:20 -07001307 return 0;
1308 }
1309
Haynes Mathew George47cd4cb2013-07-19 11:58:50 -07001310 mixer_ctl_update(ctl);
1311
1312 count = mixer_ctl_get_num_values(ctl);
Eric Laurentb23d5282013-05-14 15:27:20 -07001313
1314 /* Read SAD blocks, clamping the maximum size for safety */
Haynes Mathew George47cd4cb2013-07-19 11:58:50 -07001315 if (count > (int)sizeof(block))
1316 count = (int)sizeof(block);
Eric Laurentb23d5282013-05-14 15:27:20 -07001317
Haynes Mathew George47cd4cb2013-07-19 11:58:50 -07001318 ret = mixer_ctl_get_array(ctl, block, count);
1319 if (ret != 0) {
1320 ALOGE("%s: mixer_ctl_get_array() failed to get EDID info", __func__);
1321 return 0;
1322 }
Eric Laurentb23d5282013-05-14 15:27:20 -07001323
1324 /* Calculate the number of SAD blocks */
Haynes Mathew George47cd4cb2013-07-19 11:58:50 -07001325 num_audio_blocks = count / SAD_BLOCK_SIZE;
Eric Laurentb23d5282013-05-14 15:27:20 -07001326
1327 for (i = 0; i < num_audio_blocks; i++) {
1328 /* Only consider LPCM blocks */
Haynes Mathew George47cd4cb2013-07-19 11:58:50 -07001329 if ((sad[0] >> 3) != EDID_FORMAT_LPCM) {
1330 sad += 3;
Eric Laurentb23d5282013-05-14 15:27:20 -07001331 continue;
Haynes Mathew George47cd4cb2013-07-19 11:58:50 -07001332 }
Eric Laurentb23d5282013-05-14 15:27:20 -07001333
1334 channel_count = (sad[0] & 0x7) + 1;
1335 if (channel_count > max_channels)
1336 max_channels = channel_count;
1337
1338 /* Advance to next block */
1339 sad += 3;
1340 }
1341
1342 return max_channels;
1343}
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001344
1345static int platform_set_slowtalk(struct platform_data *my_data, bool state)
1346{
1347 int ret = 0;
1348 struct audio_device *adev = my_data->adev;
1349 struct mixer_ctl *ctl;
1350 const char *mixer_ctl_name = "Slowtalk Enable";
1351 uint32_t set_values[ ] = {0,
1352 ALL_SESSION_VSID};
1353
1354 set_values[0] = state;
1355 ctl = mixer_get_ctl_by_name(adev->mixer, mixer_ctl_name);
1356 if (!ctl) {
1357 ALOGE("%s: Could not get ctl for mixer cmd - %s",
1358 __func__, mixer_ctl_name);
1359 ret = -EINVAL;
1360 } else {
1361 ALOGV("Setting slowtalk state: %d", state);
1362 ret = mixer_ctl_set_array(ctl, set_values, ARRAY_SIZE(set_values));
1363 my_data->slowtalk = state;
1364 }
1365
Vidyakumar Athotad9d9ff32013-11-13 11:46:52 -08001366 if (my_data->csd != NULL) {
1367 ret = my_data->csd->slow_talk(ALL_SESSION_VSID, state);
1368 if (ret < 0) {
1369 ALOGE("%s: csd_client_disable_device, failed, error %d",
1370 __func__, ret);
1371 }
1372 }
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001373 return ret;
1374}
1375
1376int platform_set_parameters(void *platform, struct str_parms *parms)
1377{
1378 struct platform_data *my_data = (struct platform_data *)platform;
1379 char *str;
Vidyakumar Athota3ade2792013-12-02 11:02:20 -08001380 char value[256] = {0};
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001381 int val;
Shiv Maliyappanahalli3e064fd2013-12-16 15:54:40 -08001382 int ret = 0, err;
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001383
1384 ALOGV("%s: enter: %s", __func__, str_parms_to_str(parms));
1385
Shiv Maliyappanahalli3e064fd2013-12-16 15:54:40 -08001386 err = str_parms_get_int(parms, AUDIO_PARAMETER_KEY_BTSCO, &val);
1387 if (err >= 0) {
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001388 str_parms_del(parms, AUDIO_PARAMETER_KEY_BTSCO);
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001389 my_data->btsco_sample_rate = val;
Vidyakumar Athota67c42712013-12-04 14:03:06 -08001390 if (val == SAMPLE_RATE_16KHZ) {
1391 audio_route_apply_path(my_data->adev->audio_route,
1392 "bt-sco-wb-samplerate");
1393 audio_route_update_mixer(my_data->adev->audio_route);
1394 }
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001395 }
1396
Shiv Maliyappanahalli3e064fd2013-12-16 15:54:40 -08001397 err = str_parms_get_str(parms, AUDIO_PARAMETER_KEY_SLOWTALK, value, sizeof(value));
1398 if (err >= 0) {
Vidyakumar Athota3ade2792013-12-02 11:02:20 -08001399 bool state = false;
1400 if (!strncmp("true", value, sizeof("true"))) {
1401 state = true;
1402 }
1403
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001404 str_parms_del(parms, AUDIO_PARAMETER_KEY_SLOWTALK);
Vidyakumar Athota3ade2792013-12-02 11:02:20 -08001405 ret = platform_set_slowtalk(my_data, state);
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001406 if (ret)
1407 ALOGE("%s: Failed to set slow talk err: %d", __func__, ret);
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001408 }
1409
Shiv Maliyappanahalli3e064fd2013-12-16 15:54:40 -08001410 err = str_parms_get_str(parms, AUDIO_PARAMETER_KEY_VOLUME_BOOST,
Ben Rombergerc1dc70d2013-12-19 15:11:17 -08001411 value, sizeof(value));
Shiv Maliyappanahalli3e064fd2013-12-16 15:54:40 -08001412 if (err >= 0) {
Ben Rombergerc1dc70d2013-12-19 15:11:17 -08001413 str_parms_del(parms, AUDIO_PARAMETER_KEY_VOLUME_BOOST);
1414
1415 if (my_data->acdb_reload_vocvoltable == NULL) {
1416 ALOGE("%s: acdb_reload_vocvoltable is NULL", __func__);
1417 } else if (!strcmp(value, "on")) {
1418 if (!my_data->acdb_reload_vocvoltable(VOICE_FEATURE_SET_VOLUME_BOOST)) {
1419 my_data->voice_feature_set = 1;
1420 }
1421 } else {
1422 if (!my_data->acdb_reload_vocvoltable(VOICE_FEATURE_SET_DEFAULT)) {
1423 my_data->voice_feature_set = 0;
1424 }
1425 }
1426 }
1427
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001428 ALOGV("%s: exit with code(%d)", __func__, ret);
1429 return ret;
1430}
1431
Vidyakumar Athota2850d532013-11-19 16:02:12 -08001432int platform_set_incall_recording_session_id(void *platform,
1433 uint32_t session_id, int rec_mode)
Shiv Maliyappanahallida107642013-10-17 11:16:13 -07001434{
1435 int ret = 0;
1436 struct platform_data *my_data = (struct platform_data *)platform;
1437 struct audio_device *adev = my_data->adev;
1438 struct mixer_ctl *ctl;
1439 const char *mixer_ctl_name = "Voc VSID";
1440 int num_ctl_values;
1441 int i;
1442
1443 ctl = mixer_get_ctl_by_name(adev->mixer, mixer_ctl_name);
1444 if (!ctl) {
1445 ALOGE("%s: Could not get ctl for mixer cmd - %s",
1446 __func__, mixer_ctl_name);
1447 ret = -EINVAL;
1448 } else {
1449 num_ctl_values = mixer_ctl_get_num_values(ctl);
1450 for (i = 0; i < num_ctl_values; i++) {
1451 if (mixer_ctl_set_value(ctl, i, session_id)) {
1452 ALOGV("Error: invalid session_id: %x", session_id);
1453 ret = -EINVAL;
1454 break;
1455 }
1456 }
1457 }
1458
Vidyakumar Athota2850d532013-11-19 16:02:12 -08001459 if (my_data->csd != NULL) {
1460 ret = my_data->csd->start_record(ALL_SESSION_VSID, rec_mode);
1461 if (ret < 0) {
1462 ALOGE("%s: csd_client_start_record failed, error %d",
1463 __func__, ret);
1464 }
1465 }
1466
1467 return ret;
1468}
1469
1470int platform_stop_incall_recording_usecase(void *platform)
1471{
1472 int ret = 0;
1473 struct platform_data *my_data = (struct platform_data *)platform;
1474
1475 if (my_data->csd != NULL) {
1476 ret = my_data->csd->stop_record(ALL_SESSION_VSID);
1477 if (ret < 0) {
1478 ALOGE("%s: csd_client_stop_record failed, error %d",
1479 __func__, ret);
1480 }
1481 }
1482
1483 return ret;
1484}
1485
1486int platform_start_incall_music_usecase(void *platform)
1487{
1488 int ret = 0;
1489 struct platform_data *my_data = (struct platform_data *)platform;
1490
1491 if (my_data->csd != NULL) {
1492 ret = my_data->csd->start_playback(ALL_SESSION_VSID);
1493 if (ret < 0) {
1494 ALOGE("%s: csd_client_start_playback failed, error %d",
1495 __func__, ret);
1496 }
1497 }
1498
1499 return ret;
1500}
1501
1502int platform_stop_incall_music_usecase(void *platform)
1503{
1504 int ret = 0;
1505 struct platform_data *my_data = (struct platform_data *)platform;
1506
1507 if (my_data->csd != NULL) {
1508 ret = my_data->csd->stop_playback(ALL_SESSION_VSID);
1509 if (ret < 0) {
1510 ALOGE("%s: csd_client_stop_playback failed, error %d",
1511 __func__, ret);
1512 }
1513 }
1514
Shiv Maliyappanahallida107642013-10-17 11:16:13 -07001515 return ret;
1516}
1517
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001518void platform_get_parameters(void *platform,
1519 struct str_parms *query,
1520 struct str_parms *reply)
1521{
1522 struct platform_data *my_data = (struct platform_data *)platform;
1523 char *str = NULL;
1524 char value[256] = {0};
1525 int ret;
1526 int fluence_type;
1527
1528 ret = str_parms_get_str(query, AUDIO_PARAMETER_KEY_FLUENCE_TYPE,
1529 value, sizeof(value));
1530 if (ret >= 0) {
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -08001531 if (my_data->fluence_type & FLUENCE_QUAD_MIC) {
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001532 strlcpy(value, "fluencepro", sizeof(value));
Ravi Kumar Alamandab034ddb2013-11-06 15:52:18 -08001533 } else if (my_data->fluence_type & FLUENCE_DUAL_MIC) {
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001534 strlcpy(value, "fluence", sizeof(value));
1535 } else {
1536 strlcpy(value, "none", sizeof(value));
1537 }
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001538
1539 str_parms_add_str(reply, AUDIO_PARAMETER_KEY_FLUENCE_TYPE, value);
1540 }
1541
Shiv Maliyappanahalli9d899292013-11-20 14:43:01 -08001542 memset(value, 0, sizeof(value));
1543 ret = str_parms_get_str(query, AUDIO_PARAMETER_KEY_SLOWTALK,
1544 value, sizeof(value));
1545 if (ret >= 0) {
Vidyakumar Athota3ade2792013-12-02 11:02:20 -08001546 str_parms_add_str(reply, AUDIO_PARAMETER_KEY_SLOWTALK,
1547 my_data->slowtalk?"true":"false");
Shiv Maliyappanahalli9d899292013-11-20 14:43:01 -08001548 }
1549
Ben Rombergerc1dc70d2013-12-19 15:11:17 -08001550 ret = str_parms_get_str(query, AUDIO_PARAMETER_KEY_VOLUME_BOOST,
1551 value, sizeof(value));
1552 if (ret >= 0) {
1553 if (my_data->voice_feature_set == VOICE_FEATURE_SET_VOLUME_BOOST) {
1554 strlcpy(value, "on", sizeof(value));
1555 } else {
1556 strlcpy(value, "off", sizeof(value));
1557 }
1558
1559 str_parms_add_str(reply, AUDIO_PARAMETER_KEY_VOLUME_BOOST, value);
1560 }
1561
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07001562 ALOGV("%s: exit: returns - %s", __func__, str_parms_to_str(reply));
1563}
1564
Haynes Mathew George7ff216f2013-09-11 19:51:41 -07001565/* Delay in Us */
1566int64_t platform_render_latency(audio_usecase_t usecase)
1567{
1568 switch (usecase) {
1569 case USECASE_AUDIO_PLAYBACK_DEEP_BUFFER:
1570 return DEEP_BUFFER_PLATFORM_DELAY;
1571 case USECASE_AUDIO_PLAYBACK_LOW_LATENCY:
1572 return LOW_LATENCY_PLATFORM_DELAY;
1573 default:
1574 return 0;
1575 }
1576}
Preetam Singh Ranawatde84f1a2013-11-01 14:58:16 -07001577
Mingming Yine62d7842013-10-25 16:26:03 -07001578int platform_update_usecase_from_source(int source, int usecase)
Preetam Singh Ranawatde84f1a2013-11-01 14:58:16 -07001579{
Mingming Yinab429782013-11-07 11:16:55 -08001580 ALOGV("%s: input source :%d", __func__, source);
1581 if(source == AUDIO_SOURCE_FM_RX_A2DP)
Mingming Yine62d7842013-10-25 16:26:03 -07001582 usecase = USECASE_AUDIO_RECORD_FM_VIRTUAL;
1583 return usecase;
Preetam Singh Ranawatde84f1a2013-11-01 14:58:16 -07001584}
Kiran Kandide144c82013-11-20 15:58:32 -08001585
1586bool platform_listen_update_status(snd_device_t snd_device)
1587{
1588 if ((snd_device >= SND_DEVICE_IN_BEGIN) &&
1589 (snd_device < SND_DEVICE_IN_END) &&
1590 (snd_device != SND_DEVICE_IN_CAPTURE_FM) &&
1591 (snd_device != SND_DEVICE_IN_CAPTURE_VI_FEEDBACK))
1592 return true;
1593 else
1594 return false;
1595}