blob: e2c30f4ba33311db73d60996fbc82bb6cd6bd7c8 [file] [log] [blame]
Eric Laurentb23d5282013-05-14 15:27:20 -07001/*
Ben Romberger55886882014-01-10 13:49:02 -08002 * Copyright (c) 2013-2014, The Linux Foundation. All rights reserved.
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -07003 * 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 "msm8960_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>
28#include <audio_hw.h>
29#include <platform_api.h>
30#include "platform.h"
31
32#define LIB_ACDB_LOADER "libacdbloader.so"
33#define LIB_CSD_CLIENT "libcsd-client.so"
34
Eric Laurentb23d5282013-05-14 15:27:20 -070035/*
36 * This is the sysfs path for the HDMI audio data block
37 */
38#define AUDIO_DATA_BLOCK_PATH "/sys/class/graphics/fb1/audio_data_block"
sangwoo1b9f4b32013-06-21 18:22:55 -070039#define MIXER_XML_PATH "/system/etc/mixer_paths.xml"
Eric Laurentb23d5282013-05-14 15:27:20 -070040
41/*
42 * 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
54struct audio_block_header
55{
56 int reserved;
57 int length;
58};
59
60
61typedef void (*acdb_deallocate_t)();
62typedef int (*acdb_init_t)();
63typedef void (*acdb_send_audio_cal_t)(int, int);
64typedef void (*acdb_send_voice_cal_t)(int, int);
65
66typedef int (*csd_client_init_t)();
67typedef int (*csd_client_deinit_t)();
68typedef int (*csd_disable_device_t)();
69typedef int (*csd_enable_device_t)(int, int, uint32_t);
70typedef int (*csd_volume_t)(int);
71typedef int (*csd_mic_mute_t)(int);
72typedef int (*csd_start_voice_t)();
73typedef int (*csd_stop_voice_t)();
74
75
Eric Laurentb23d5282013-05-14 15:27:20 -070076struct platform_data {
77 struct audio_device *adev;
78 bool fluence_in_spkr_mode;
79 bool fluence_in_voice_call;
80 bool fluence_in_voice_rec;
Mingming Yin8e5a4f62013-10-07 15:23:41 -070081 int fluence_type;
Eric Laurentb23d5282013-05-14 15:27:20 -070082 int dualmic_config;
Venkata Narendra Kumar Gutta1bbbf542014-09-04 19:11:25 +053083 bool ec_ref_enabled;
Eric Laurentb23d5282013-05-14 15:27:20 -070084
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -070085 /* Audio calibration related functions */
Eric Laurentb23d5282013-05-14 15:27:20 -070086 void *acdb_handle;
87 acdb_init_t acdb_init;
88 acdb_deallocate_t acdb_deallocate;
89 acdb_send_audio_cal_t acdb_send_audio_cal;
90 acdb_send_voice_cal_t acdb_send_voice_cal;
91
92 /* CSD Client related functions for voice call */
93 void *csd_client;
94 csd_client_init_t csd_client_init;
95 csd_client_deinit_t csd_client_deinit;
96 csd_disable_device_t csd_disable_device;
97 csd_enable_device_t csd_enable_device;
98 csd_volume_t csd_volume;
99 csd_mic_mute_t csd_mic_mute;
100 csd_start_voice_t csd_start_voice;
101 csd_stop_voice_t csd_stop_voice;
102};
103
104static const int pcm_device_table[AUDIO_USECASE_MAX][2] = {
105 [USECASE_AUDIO_PLAYBACK_DEEP_BUFFER] = {0, 0},
106 [USECASE_AUDIO_PLAYBACK_LOW_LATENCY] = {14, 14},
107 [USECASE_AUDIO_PLAYBACK_MULTI_CH] = {1, 1},
108 [USECASE_AUDIO_RECORD] = {0, 0},
109 [USECASE_AUDIO_RECORD_LOW_LATENCY] = {14, 14},
110 [USECASE_VOICE_CALL] = {12, 12},
111};
112
113/* Array to store sound devices */
114static const char * const device_table[SND_DEVICE_MAX] = {
115 [SND_DEVICE_NONE] = "none",
116 /* Playback sound devices */
117 [SND_DEVICE_OUT_HANDSET] = "handset",
118 [SND_DEVICE_OUT_SPEAKER] = "speaker",
119 [SND_DEVICE_OUT_SPEAKER_REVERSE] = "speaker-reverse",
120 [SND_DEVICE_OUT_HEADPHONES] = "headphones",
121 [SND_DEVICE_OUT_SPEAKER_AND_HEADPHONES] = "speaker-and-headphones",
122 [SND_DEVICE_OUT_VOICE_SPEAKER] = "voice-speaker",
123 [SND_DEVICE_OUT_VOICE_HEADPHONES] = "voice-headphones",
124 [SND_DEVICE_OUT_HDMI] = "hdmi",
125 [SND_DEVICE_OUT_SPEAKER_AND_HDMI] = "speaker-and-hdmi",
126 [SND_DEVICE_OUT_BT_SCO] = "bt-sco-headset",
Mingming Yin514a8bc2014-07-29 15:22:21 -0700127 [SND_DEVICE_OUT_BT_SCO_WB] = "bt-sco-headset-wb",
Eric Laurentb23d5282013-05-14 15:27:20 -0700128 [SND_DEVICE_OUT_VOICE_TTY_FULL_HEADPHONES] = "voice-tty-full-headphones",
129 [SND_DEVICE_OUT_VOICE_TTY_VCO_HEADPHONES] = "voice-tty-vco-headphones",
130 [SND_DEVICE_OUT_VOICE_TTY_HCO_HANDSET] = "voice-tty-hco-handset",
Ravi Kumar Alamandabdf14162014-09-05 16:14:17 -0700131 [SND_DEVICE_OUT_USB_HEADSET] = "usb-headphones",
132 [SND_DEVICE_OUT_SPEAKER_AND_USB_HEADSET] = "speaker-and-usb-headphones",
Eric Laurentb23d5282013-05-14 15:27:20 -0700133
134 /* Capture sound devices */
135 [SND_DEVICE_IN_HANDSET_MIC] = "handset-mic",
136 [SND_DEVICE_IN_SPEAKER_MIC] = "speaker-mic",
137 [SND_DEVICE_IN_HEADSET_MIC] = "headset-mic",
138 [SND_DEVICE_IN_HANDSET_MIC_AEC] = "handset-mic",
139 [SND_DEVICE_IN_SPEAKER_MIC_AEC] = "voice-speaker-mic",
140 [SND_DEVICE_IN_HEADSET_MIC_AEC] = "headset-mic",
141 [SND_DEVICE_IN_VOICE_SPEAKER_MIC] = "voice-speaker-mic",
142 [SND_DEVICE_IN_VOICE_HEADSET_MIC] = "voice-headset-mic",
143 [SND_DEVICE_IN_HDMI_MIC] = "hdmi-mic",
144 [SND_DEVICE_IN_BT_SCO_MIC] = "bt-sco-mic",
Mingming Yin514a8bc2014-07-29 15:22:21 -0700145 [SND_DEVICE_IN_BT_SCO_MIC_WB] = "bt-sco-mic-wb",
Eric Laurentb23d5282013-05-14 15:27:20 -0700146 [SND_DEVICE_IN_CAMCORDER_MIC] = "camcorder-mic",
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700147 [SND_DEVICE_IN_VOICE_DMIC] = "voice-dmic-ef",
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700148 [SND_DEVICE_IN_VOICE_SPEAKER_DMIC] = "voice-speaker-dmic-ef",
Eric Laurentb23d5282013-05-14 15:27:20 -0700149 [SND_DEVICE_IN_VOICE_TTY_FULL_HEADSET_MIC] = "voice-tty-full-headset-mic",
150 [SND_DEVICE_IN_VOICE_TTY_VCO_HANDSET_MIC] = "voice-tty-vco-handset-mic",
151 [SND_DEVICE_IN_VOICE_TTY_HCO_HEADSET_MIC] = "voice-tty-hco-headset-mic",
152 [SND_DEVICE_IN_VOICE_REC_MIC] = "voice-rec-mic",
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700153 [SND_DEVICE_IN_VOICE_REC_DMIC] = "voice-rec-dmic-ef",
154 [SND_DEVICE_IN_VOICE_REC_DMIC_FLUENCE] = "voice-rec-dmic-ef-fluence",
Ravi Kumar Alamandabdf14162014-09-05 16:14:17 -0700155 [SND_DEVICE_IN_USB_HEADSET_MIC] = "usb-headset-mic",
Eric Laurentb23d5282013-05-14 15:27:20 -0700156};
157
158/* ACDB IDs (audio DSP path configuration IDs) for each sound device */
159static const int acdb_device_table[SND_DEVICE_MAX] = {
160 [SND_DEVICE_NONE] = -1,
161 [SND_DEVICE_OUT_HANDSET] = 7,
162 [SND_DEVICE_OUT_SPEAKER] = 14,
163 [SND_DEVICE_OUT_SPEAKER_REVERSE] = 14,
164 [SND_DEVICE_OUT_HEADPHONES] = 10,
165 [SND_DEVICE_OUT_SPEAKER_AND_HEADPHONES] = 10,
166 [SND_DEVICE_OUT_VOICE_SPEAKER] = 14,
167 [SND_DEVICE_OUT_VOICE_HEADPHONES] = 10,
168 [SND_DEVICE_OUT_HDMI] = 18,
169 [SND_DEVICE_OUT_SPEAKER_AND_HDMI] = 14,
170 [SND_DEVICE_OUT_BT_SCO] = 22,
Mingming Yin514a8bc2014-07-29 15:22:21 -0700171 [SND_DEVICE_OUT_BT_SCO_WB] = 39,
Eric Laurentb23d5282013-05-14 15:27:20 -0700172 [SND_DEVICE_OUT_VOICE_TTY_FULL_HEADPHONES] = 17,
173 [SND_DEVICE_OUT_VOICE_TTY_VCO_HEADPHONES] = 17,
174 [SND_DEVICE_OUT_VOICE_TTY_HCO_HANDSET] = 37,
Ravi Kumar Alamandabdf14162014-09-05 16:14:17 -0700175 [SND_DEVICE_OUT_USB_HEADSET] = 45,
176 [SND_DEVICE_OUT_SPEAKER_AND_USB_HEADSET] = 14,
Eric Laurentb23d5282013-05-14 15:27:20 -0700177
178 [SND_DEVICE_IN_HANDSET_MIC] = 4,
179 [SND_DEVICE_IN_SPEAKER_MIC] = 4,
180 [SND_DEVICE_IN_HEADSET_MIC] = 8,
181 [SND_DEVICE_IN_HANDSET_MIC_AEC] = 40,
182 [SND_DEVICE_IN_SPEAKER_MIC_AEC] = 42,
183 [SND_DEVICE_IN_HEADSET_MIC_AEC] = 47,
184 [SND_DEVICE_IN_VOICE_SPEAKER_MIC] = 11,
185 [SND_DEVICE_IN_VOICE_HEADSET_MIC] = 8,
186 [SND_DEVICE_IN_HDMI_MIC] = 4,
187 [SND_DEVICE_IN_BT_SCO_MIC] = 21,
Mingming Yin514a8bc2014-07-29 15:22:21 -0700188 [SND_DEVICE_IN_BT_SCO_MIC_WB] = 38,
Eric Laurentb23d5282013-05-14 15:27:20 -0700189 [SND_DEVICE_IN_CAMCORDER_MIC] = 61,
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700190 [SND_DEVICE_IN_VOICE_DMIC] = 6,
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700191 [SND_DEVICE_IN_VOICE_SPEAKER_DMIC] = 13,
Eric Laurentb23d5282013-05-14 15:27:20 -0700192 [SND_DEVICE_IN_VOICE_TTY_FULL_HEADSET_MIC] = 16,
193 [SND_DEVICE_IN_VOICE_TTY_VCO_HANDSET_MIC] = 36,
194 [SND_DEVICE_IN_VOICE_TTY_HCO_HEADSET_MIC] = 16,
195 [SND_DEVICE_IN_VOICE_REC_MIC] = 62,
Ravi Kumar Alamandabdf14162014-09-05 16:14:17 -0700196 [SND_DEVICE_IN_USB_HEADSET_MIC] = 44,
Eric Laurentb23d5282013-05-14 15:27:20 -0700197 /* TODO: Update with proper acdb ids */
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700198 [SND_DEVICE_IN_VOICE_REC_DMIC] = 62,
199 [SND_DEVICE_IN_VOICE_REC_DMIC_FLUENCE] = 6,
Eric Laurentb23d5282013-05-14 15:27:20 -0700200};
201
Haynes Mathew George7ff216f2013-09-11 19:51:41 -0700202#define DEEP_BUFFER_PLATFORM_DELAY (29*1000LL)
203#define LOW_LATENCY_PLATFORM_DELAY (13*1000LL)
204
Venkata Narendra Kumar Gutta1bbbf542014-09-04 19:11:25 +0530205void platform_set_echo_reference(void *platform, bool enable)
Eric Laurentb23d5282013-05-14 15:27:20 -0700206{
Venkata Narendra Kumar Gutta1bbbf542014-09-04 19:11:25 +0530207 struct platform_data *my_data = (struct platform_data *)platform;
208 struct audio_device *adev = my_data->adev;
209
210 if (enable) {
211 my_data->ec_ref_enabled = enable;
Anish Kumar4980fa12014-04-17 12:42:20 -0700212 audio_route_apply_and_update_path(adev->audio_route, "echo-reference");
Venkata Narendra Kumar Gutta1bbbf542014-09-04 19:11:25 +0530213 } else {
214 if (my_data->ec_ref_enabled) {
215 audio_route_reset_and_update_path(adev->audio_route, "echo-reference");
216 my_data->ec_ref_enabled = enable;
217 } else {
218 ALOGV("EC Reference is already disabled: %d", my_data->ec_ref_enabled);
219 }
220 }
Eric Laurentb23d5282013-05-14 15:27:20 -0700221
Anish Kumar4980fa12014-04-17 12:42:20 -0700222 ALOGV("Setting EC Reference: %d", enable);
Eric Laurentb23d5282013-05-14 15:27:20 -0700223}
224
225void *platform_init(struct audio_device *adev)
226{
227 char platform[PROPERTY_VALUE_MAX];
228 char baseband[PROPERTY_VALUE_MAX];
229 char value[PROPERTY_VALUE_MAX];
230 struct platform_data *my_data;
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700231 const char *snd_card_name;
Eric Laurentb23d5282013-05-14 15:27:20 -0700232
sangwoo1b9f4b32013-06-21 18:22:55 -0700233 adev->mixer = mixer_open(MIXER_CARD);
234
235 if (!adev->mixer) {
236 ALOGE("Unable to open the mixer, aborting.");
237 return NULL;
238 }
239
240 adev->audio_route = audio_route_init(MIXER_CARD, MIXER_XML_PATH);
241 if (!adev->audio_route) {
242 ALOGE("%s: Failed to init audio route controls, aborting.", __func__);
243 return NULL;
244 }
245
Eric Laurentb23d5282013-05-14 15:27:20 -0700246 my_data = calloc(1, sizeof(struct platform_data));
247
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700248 snd_card_name = mixer_get_name(adev->mixer);
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700249
Eric Laurentb23d5282013-05-14 15:27:20 -0700250 my_data->adev = adev;
Eric Laurentb23d5282013-05-14 15:27:20 -0700251 my_data->fluence_in_spkr_mode = false;
252 my_data->fluence_in_voice_call = false;
253 my_data->fluence_in_voice_rec = false;
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700254 my_data->fluence_type = FLUENCE_NONE;
Eric Laurentb23d5282013-05-14 15:27:20 -0700255
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700256 property_get("ro.qc.sdk.audio.fluencetype", value, "");
257 if (!strncmp("fluencepro", value, sizeof("fluencepro"))) {
258 my_data->fluence_type = FLUENCE_QUAD_MIC;
259 } else if (!strncmp("fluence", value, sizeof("fluence"))) {
260 my_data->fluence_type = FLUENCE_DUAL_MIC;
261 } else {
262 my_data->fluence_type = FLUENCE_NONE;
Eric Laurentb23d5282013-05-14 15:27:20 -0700263 }
264
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700265 if (my_data->fluence_type != FLUENCE_NONE) {
Eric Laurentb23d5282013-05-14 15:27:20 -0700266 property_get("persist.audio.fluence.voicecall",value,"");
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700267 if (!strncmp("true", value, sizeof("true"))) {
Eric Laurentb23d5282013-05-14 15:27:20 -0700268 my_data->fluence_in_voice_call = true;
269 }
270
271 property_get("persist.audio.fluence.voicerec",value,"");
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700272 if (!strncmp("true", value, sizeof("true"))) {
Eric Laurentb23d5282013-05-14 15:27:20 -0700273 my_data->fluence_in_voice_rec = true;
274 }
275
276 property_get("persist.audio.fluence.speaker",value,"");
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700277 if (!strncmp("true", value, sizeof("true"))) {
Eric Laurentb23d5282013-05-14 15:27:20 -0700278 my_data->fluence_in_spkr_mode = true;
279 }
280 }
281
282 my_data->acdb_handle = dlopen(LIB_ACDB_LOADER, RTLD_NOW);
283 if (my_data->acdb_handle == NULL) {
284 ALOGE("%s: DLOPEN failed for %s", __func__, LIB_ACDB_LOADER);
285 } else {
286 ALOGV("%s: DLOPEN successful for %s", __func__, LIB_ACDB_LOADER);
287 my_data->acdb_deallocate = (acdb_deallocate_t)dlsym(my_data->acdb_handle,
288 "acdb_loader_deallocate_ACDB");
289 my_data->acdb_send_audio_cal = (acdb_send_audio_cal_t)dlsym(my_data->acdb_handle,
290 "acdb_loader_send_audio_cal");
291 if (!my_data->acdb_send_audio_cal)
292 ALOGW("%s: Could not find the symbol acdb_send_audio_cal from %s",
293 __func__, LIB_ACDB_LOADER);
294 my_data->acdb_send_voice_cal = (acdb_send_voice_cal_t)dlsym(my_data->acdb_handle,
295 "acdb_loader_send_voice_cal");
296 my_data->acdb_init = (acdb_init_t)dlsym(my_data->acdb_handle,
297 "acdb_loader_init_ACDB");
298 if (my_data->acdb_init == NULL)
299 ALOGE("%s: dlsym error %s for acdb_loader_init_ACDB", __func__, dlerror());
300 else
301 my_data->acdb_init();
302 }
303
304 /* If platform is Fusion3, load CSD Client specific symbols
305 * Voice call is handled by MDM and apps processor talks to
306 * MDM through CSD Client
307 */
308 property_get("ro.board.platform", platform, "");
309 property_get("ro.baseband", baseband, "");
310 if (!strcmp("msm8960", platform) && !strcmp("mdm", baseband)) {
311 my_data->csd_client = dlopen(LIB_CSD_CLIENT, RTLD_NOW);
312 if (my_data->csd_client == NULL)
313 ALOGE("%s: DLOPEN failed for %s", __func__, LIB_CSD_CLIENT);
314 }
315
316 if (my_data->csd_client) {
317 ALOGV("%s: DLOPEN successful for %s", __func__, LIB_CSD_CLIENT);
318 my_data->csd_client_deinit = (csd_client_deinit_t)dlsym(my_data->csd_client,
319 "csd_client_deinit");
320 my_data->csd_disable_device = (csd_disable_device_t)dlsym(my_data->csd_client,
321 "csd_client_disable_device");
322 my_data->csd_enable_device = (csd_enable_device_t)dlsym(my_data->csd_client,
323 "csd_client_enable_device");
324 my_data->csd_start_voice = (csd_start_voice_t)dlsym(my_data->csd_client,
325 "csd_client_start_voice");
326 my_data->csd_stop_voice = (csd_stop_voice_t)dlsym(my_data->csd_client,
327 "csd_client_stop_voice");
328 my_data->csd_volume = (csd_volume_t)dlsym(my_data->csd_client,
329 "csd_client_volume");
330 my_data->csd_mic_mute = (csd_mic_mute_t)dlsym(my_data->csd_client,
331 "csd_client_mic_mute");
332 my_data->csd_client_init = (csd_client_init_t)dlsym(my_data->csd_client,
333 "csd_client_init");
334
335 if (my_data->csd_client_init == NULL) {
336 ALOGE("%s: dlsym error %s for csd_client_init", __func__, dlerror());
337 } else {
338 my_data->csd_client_init();
339 }
340 }
341
342 return my_data;
343}
344
345void platform_deinit(void *platform)
346{
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700347 struct platform_data *my_data = (struct platform_data *)platform;
348
Eric Laurentb23d5282013-05-14 15:27:20 -0700349 free(platform);
350}
351
352const char *platform_get_snd_device_name(snd_device_t snd_device)
353{
354 if (snd_device >= SND_DEVICE_MIN && snd_device < SND_DEVICE_MAX)
355 return device_table[snd_device];
356 else
357 return "";
358}
359
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700360int platform_get_snd_device_name_extn(void *platform, snd_device_t snd_device,
361 char *device_name)
362{
363 struct platform_data *my_data = (struct platform_data *)platform;
364
365 if (snd_device >= SND_DEVICE_MIN && snd_device < SND_DEVICE_MAX) {
366 strlcpy(device_name, device_table[snd_device], DEVICE_NAME_MAX_SIZE);
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700367 } else {
368 strlcpy(device_name, "", DEVICE_NAME_MAX_SIZE);
369 return -EINVAL;
370 }
371
372 return 0;
373}
374
Eric Laurentb23d5282013-05-14 15:27:20 -0700375void platform_add_backend_name(char *mixer_path, snd_device_t snd_device)
376{
377 if (snd_device == SND_DEVICE_IN_BT_SCO_MIC)
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700378 strlcat(mixer_path, " bt-sco", MIXER_PATH_MAX_LENGTH);
379 else if (snd_device == SND_DEVICE_IN_BT_SCO_MIC_WB)
380 strlcat(mixer_path, " bt-sco-wb", MIXER_PATH_MAX_LENGTH);
Eric Laurentb23d5282013-05-14 15:27:20 -0700381 else if(snd_device == SND_DEVICE_OUT_BT_SCO)
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700382 strlcat(mixer_path, " bt-sco", MIXER_PATH_MAX_LENGTH);
383 else if(snd_device == SND_DEVICE_OUT_BT_SCO_WB)
384 strlcat(mixer_path, " bt-sco-wb", MIXER_PATH_MAX_LENGTH);
Eric Laurentb23d5282013-05-14 15:27:20 -0700385 else if (snd_device == SND_DEVICE_OUT_HDMI)
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700386 strlcat(mixer_path, " hdmi", MIXER_PATH_MAX_LENGTH);
Eric Laurentb23d5282013-05-14 15:27:20 -0700387 else if (snd_device == SND_DEVICE_OUT_SPEAKER_AND_HDMI)
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700388 strlcat(mixer_path, " speaker-and-hdmi", MIXER_PATH_MAX_LENGTH);
Eric Laurentb23d5282013-05-14 15:27:20 -0700389}
390
391int platform_get_pcm_device_id(audio_usecase_t usecase, int device_type)
392{
393 int device_id;
394 if (device_type == PCM_PLAYBACK)
395 device_id = pcm_device_table[usecase][0];
396 else
397 device_id = pcm_device_table[usecase][1];
398 return device_id;
399}
400
Ravi Kumar Alamandabdf14162014-09-05 16:14:17 -0700401int platform_get_snd_device_index(char *snd_device_index_name __unused)
Ben Romberger61764e32014-01-10 13:49:02 -0800402{
403 return -ENODEV;
404}
405
Ravi Kumar Alamandabdf14162014-09-05 16:14:17 -0700406int platform_set_snd_device_acdb_id(snd_device_t snd_device __unused,
407 unsigned int acdb_id __unused)
Ben Romberger55886882014-01-10 13:49:02 -0800408{
409 return -ENODEV;
410}
411
Ravi Kumar Alamandabdf14162014-09-05 16:14:17 -0700412uint32_t platform_get_compress_offload_buffer_size(audio_offload_info_t* info __unused)
413{
414 ALOGE("%s: Not implemented", __func__);
415 return -ENOSYS;
416}
417
418int platform_get_snd_device_acdb_id(snd_device_t snd_device __unused)
419{
420 ALOGE("%s: Not implemented", __func__);
421 return -ENOSYS;
422}
423
424int platform_switch_voice_call_enable_device_config(void *platform __unused,
425 snd_device_t out_snd_device __unused,
426 snd_device_t in_snd_device __unused)
427{
428 ALOGE("%s: Not implemented", __func__);
429 return -ENOSYS;
430}
431
432int platform_switch_voice_call_usecase_route_post(void *platform __unused,
433 snd_device_t out_snd_device __unused,
434 snd_device_t in_snd_device __unused)
435{
436 ALOGE("%s: Not implemented", __func__);
437 return -ENOSYS;
438}
439
440int platform_set_incall_recording_session_id(void *platform __unused,
441 uint32_t session_id __unused,
442 int rec_mode __unused)
443{
444 ALOGE("%s: Not implemented", __func__);
445 return -ENOSYS;
446}
447
448int platform_stop_incall_recording_usecase(void *platform __unused)
449{
450 ALOGE("%s: Not implemented", __func__);
451 return -ENOSYS;
452}
453
454int platform_get_sample_rate(void *platform __unused, uint32_t *rate __unused)
455{
456 ALOGE("%s: Not implemented", __func__);
457 return -ENOSYS;
458}
459
460int platform_get_default_app_type(void *platform __unused)
461{
462 ALOGE("%s: Not implemented", __func__);
463 return -ENOSYS;
464}
465
466int platform_send_audio_calibration(void *platform, snd_device_t snd_device,
467 int app_type __unused, int sample_rate __unused)
Eric Laurentb23d5282013-05-14 15:27:20 -0700468{
469 struct platform_data *my_data = (struct platform_data *)platform;
470 int acdb_dev_id, acdb_dev_type;
471
472 acdb_dev_id = acdb_device_table[snd_device];
473 if (acdb_dev_id < 0) {
474 ALOGE("%s: Could not find acdb id for device(%d)",
475 __func__, snd_device);
476 return -EINVAL;
477 }
478 if (my_data->acdb_send_audio_cal) {
Eric Laurent994a6932013-07-17 11:51:42 -0700479 ("%s: sending audio calibration for snd_device(%d) acdb_id(%d)",
Eric Laurentb23d5282013-05-14 15:27:20 -0700480 __func__, snd_device, acdb_dev_id);
481 if (snd_device >= SND_DEVICE_OUT_BEGIN &&
482 snd_device < SND_DEVICE_OUT_END)
483 acdb_dev_type = ACDB_DEV_TYPE_OUT;
484 else
485 acdb_dev_type = ACDB_DEV_TYPE_IN;
486 my_data->acdb_send_audio_cal(acdb_dev_id, acdb_dev_type);
487 }
488 return 0;
489}
490
491int platform_switch_voice_call_device_pre(void *platform)
492{
493 struct platform_data *my_data = (struct platform_data *)platform;
494 int ret = 0;
495
496 if (my_data->csd_client != NULL) {
497 /* This must be called before disabling the mixer controls on APQ side */
498 if (my_data->csd_disable_device == NULL) {
499 ALOGE("%s: dlsym error for csd_disable_device", __func__);
500 } else {
501 ret = my_data->csd_disable_device();
502 if (ret < 0) {
503 ALOGE("%s: csd_client_disable_device, failed, error %d",
504 __func__, ret);
505 }
506 }
507 }
508 return ret;
509}
510
511int platform_switch_voice_call_device_post(void *platform,
512 snd_device_t out_snd_device,
513 snd_device_t in_snd_device)
514{
515 struct platform_data *my_data = (struct platform_data *)platform;
516 int acdb_rx_id, acdb_tx_id;
517 int ret = 0;
518
519 if (my_data->csd_client) {
520 if (my_data->csd_enable_device == NULL) {
521 ALOGE("%s: dlsym error for csd_enable_device",
522 __func__);
523 } else {
524 acdb_rx_id = acdb_device_table[out_snd_device];
525 acdb_tx_id = acdb_device_table[in_snd_device];
526
527 if (acdb_rx_id > 0 || acdb_tx_id > 0) {
528 ret = my_data->csd_enable_device(acdb_rx_id, acdb_tx_id,
529 my_data->adev->acdb_settings);
530 if (ret < 0) {
531 ALOGE("%s: csd_enable_device, failed, error %d",
532 __func__, ret);
533 }
534 } else {
535 ALOGE("%s: Incorrect ACDB IDs (rx: %d tx: %d)", __func__,
536 acdb_rx_id, acdb_tx_id);
537 }
538 }
539 }
540
541 return ret;
542}
543
Ravi Kumar Alamandabdf14162014-09-05 16:14:17 -0700544int platform_start_voice_call(void *platform, uint32_t vsid __unused)
Eric Laurentb23d5282013-05-14 15:27:20 -0700545{
546 struct platform_data *my_data = (struct platform_data *)platform;
547 int ret = 0;
548
549 if (my_data->csd_client) {
550 if (my_data->csd_start_voice == NULL) {
551 ALOGE("dlsym error for csd_client_start_voice");
552 ret = -ENOSYS;
553 } else {
554 ret = my_data->csd_start_voice();
555 if (ret < 0) {
556 ALOGE("%s: csd_start_voice error %d\n", __func__, ret);
557 }
558 }
559 }
560
561 return ret;
562}
563
Ravi Kumar Alamandabdf14162014-09-05 16:14:17 -0700564int platform_stop_voice_call(void *platform, uint32_t vsid __unused)
Eric Laurentb23d5282013-05-14 15:27:20 -0700565{
566 struct platform_data *my_data = (struct platform_data *)platform;
567 int ret = 0;
568
569 if (my_data->csd_client) {
570 if (my_data->csd_stop_voice == NULL) {
571 ALOGE("dlsym error for csd_stop_voice");
572 } else {
573 ret = my_data->csd_stop_voice();
574 if (ret < 0) {
575 ALOGE("%s: csd_stop_voice error %d\n", __func__, ret);
576 }
577 }
578 }
579
580 return ret;
581}
582
583int platform_set_voice_volume(void *platform, int volume)
584{
585 struct platform_data *my_data = (struct platform_data *)platform;
586 int ret = 0;
587
588 if (my_data->csd_client) {
589 if (my_data->csd_volume == NULL) {
590 ALOGE("%s: dlsym error for csd_volume", __func__);
591 } else {
592 ret = my_data->csd_volume(volume);
593 if (ret < 0) {
594 ALOGE("%s: csd_volume error %d", __func__, ret);
595 }
596 }
597 } else {
598 ALOGE("%s: No CSD Client present", __func__);
599 }
600
601 return ret;
602}
603
604int platform_set_mic_mute(void *platform, bool state)
605{
606 struct platform_data *my_data = (struct platform_data *)platform;
607 int ret = 0;
608
609 if (my_data->adev->mode == AUDIO_MODE_IN_CALL) {
610 if (my_data->csd_client) {
611 if (my_data->csd_mic_mute == NULL) {
612 ALOGE("%s: dlsym error for csd_mic_mute", __func__);
613 } else {
614 ret = my_data->csd_mic_mute(state);
615 if (ret < 0) {
616 ALOGE("%s: csd_mic_mute error %d", __func__, ret);
617 }
618 }
619 } else {
620 ALOGE("%s: No CSD Client present", __func__);
621 }
622 }
623
624 return ret;
625}
626
Ravi Kumar Alamandabdf14162014-09-05 16:14:17 -0700627int platform_set_device_mute(void *platform __unused, bool state __unused, char *dir __unused)
Shiv Maliyappanahallic6fd8ee2014-03-07 15:31:55 -0800628{
Ravi Kumar Alamandabdf14162014-09-05 16:14:17 -0700629 ALOGE("%s: Not implemented", __func__);
Shiv Maliyappanahallic6fd8ee2014-03-07 15:31:55 -0800630 return -ENOSYS;
631}
632
Eric Laurentb23d5282013-05-14 15:27:20 -0700633snd_device_t platform_get_output_snd_device(void *platform, audio_devices_t devices)
634{
635 struct platform_data *my_data = (struct platform_data *)platform;
636 struct audio_device *adev = my_data->adev;
637 audio_mode_t mode = adev->mode;
638 snd_device_t snd_device = SND_DEVICE_NONE;
639
640 ALOGV("%s: enter: output devices(%#x)", __func__, devices);
641 if (devices == AUDIO_DEVICE_NONE ||
642 devices & AUDIO_DEVICE_BIT_IN) {
643 ALOGV("%s: Invalid output devices (%#x)", __func__, devices);
644 goto exit;
645 }
646
647 if (mode == AUDIO_MODE_IN_CALL) {
648 if (devices & AUDIO_DEVICE_OUT_WIRED_HEADPHONE ||
649 devices & AUDIO_DEVICE_OUT_WIRED_HEADSET) {
Ravi Kumar Alamandabdf14162014-09-05 16:14:17 -0700650 if (adev->voice.tty_mode == TTY_MODE_FULL)
Eric Laurentb23d5282013-05-14 15:27:20 -0700651 snd_device = SND_DEVICE_OUT_VOICE_TTY_FULL_HEADPHONES;
Ravi Kumar Alamandabdf14162014-09-05 16:14:17 -0700652 else if (adev->voice.tty_mode == TTY_MODE_VCO)
Eric Laurentb23d5282013-05-14 15:27:20 -0700653 snd_device = SND_DEVICE_OUT_VOICE_TTY_VCO_HEADPHONES;
Ravi Kumar Alamandabdf14162014-09-05 16:14:17 -0700654 else if (adev->voice.tty_mode == TTY_MODE_HCO)
Eric Laurentb23d5282013-05-14 15:27:20 -0700655 snd_device = SND_DEVICE_OUT_VOICE_TTY_HCO_HANDSET;
656 else
657 snd_device = SND_DEVICE_OUT_VOICE_HEADPHONES;
658 } else if (devices & AUDIO_DEVICE_OUT_ALL_SCO) {
Mingming Yin514a8bc2014-07-29 15:22:21 -0700659 if (adev->bt_wb_speech_enabled)
660 snd_device = SND_DEVICE_OUT_BT_SCO_WB;
661 else
662 snd_device = SND_DEVICE_OUT_BT_SCO;
Eric Laurentb23d5282013-05-14 15:27:20 -0700663 } else if (devices & AUDIO_DEVICE_OUT_SPEAKER) {
664 snd_device = SND_DEVICE_OUT_VOICE_SPEAKER;
665 } else if (devices & AUDIO_DEVICE_OUT_EARPIECE) {
Ravi Kumar Alamandaceb40822013-11-06 11:01:47 -0800666 snd_device = SND_DEVICE_OUT_HANDSET;
Eric Laurentb23d5282013-05-14 15:27:20 -0700667 }
668 if (snd_device != SND_DEVICE_NONE) {
669 goto exit;
670 }
671 }
672
673 if (popcount(devices) == 2) {
674 if (devices == (AUDIO_DEVICE_OUT_WIRED_HEADPHONE |
675 AUDIO_DEVICE_OUT_SPEAKER)) {
676 snd_device = SND_DEVICE_OUT_SPEAKER_AND_HEADPHONES;
677 } else if (devices == (AUDIO_DEVICE_OUT_WIRED_HEADSET |
678 AUDIO_DEVICE_OUT_SPEAKER)) {
679 snd_device = SND_DEVICE_OUT_SPEAKER_AND_HEADPHONES;
680 } else if (devices == (AUDIO_DEVICE_OUT_AUX_DIGITAL |
681 AUDIO_DEVICE_OUT_SPEAKER)) {
682 snd_device = SND_DEVICE_OUT_SPEAKER_AND_HDMI;
683 } else {
684 ALOGE("%s: Invalid combo device(%#x)", __func__, devices);
685 goto exit;
686 }
687 if (snd_device != SND_DEVICE_NONE) {
688 goto exit;
689 }
690 }
691
692 if (popcount(devices) != 1) {
693 ALOGE("%s: Invalid output devices(%#x)", __func__, devices);
694 goto exit;
695 }
696
697 if (devices & AUDIO_DEVICE_OUT_WIRED_HEADPHONE ||
698 devices & AUDIO_DEVICE_OUT_WIRED_HEADSET) {
699 snd_device = SND_DEVICE_OUT_HEADPHONES;
700 } else if (devices & AUDIO_DEVICE_OUT_SPEAKER) {
701 if (adev->speaker_lr_swap)
702 snd_device = SND_DEVICE_OUT_SPEAKER_REVERSE;
703 else
704 snd_device = SND_DEVICE_OUT_SPEAKER;
705 } else if (devices & AUDIO_DEVICE_OUT_ALL_SCO) {
Mingming Yin514a8bc2014-07-29 15:22:21 -0700706 if (adev->bt_wb_speech_enabled)
707 snd_device = SND_DEVICE_OUT_BT_SCO_WB;
708 else
709 snd_device = SND_DEVICE_OUT_BT_SCO;
Eric Laurentb23d5282013-05-14 15:27:20 -0700710 } else if (devices & AUDIO_DEVICE_OUT_AUX_DIGITAL) {
711 snd_device = SND_DEVICE_OUT_HDMI ;
712 } else if (devices & AUDIO_DEVICE_OUT_EARPIECE) {
713 snd_device = SND_DEVICE_OUT_HANDSET;
714 } else {
715 ALOGE("%s: Unknown device(s) %#x", __func__, devices);
716 }
717exit:
718 ALOGV("%s: exit: snd_device(%s)", __func__, device_table[snd_device]);
719 return snd_device;
720}
721
722snd_device_t platform_get_input_snd_device(void *platform, audio_devices_t out_device)
723{
724 struct platform_data *my_data = (struct platform_data *)platform;
725 struct audio_device *adev = my_data->adev;
726 audio_source_t source = (adev->active_input == NULL) ?
727 AUDIO_SOURCE_DEFAULT : adev->active_input->source;
728
729 audio_mode_t mode = adev->mode;
730 audio_devices_t in_device = ((adev->active_input == NULL) ?
731 AUDIO_DEVICE_NONE : adev->active_input->device)
732 & ~AUDIO_DEVICE_BIT_IN;
733 audio_channel_mask_t channel_mask = (adev->active_input == NULL) ?
734 AUDIO_CHANNEL_IN_MONO : adev->active_input->channel_mask;
735 snd_device_t snd_device = SND_DEVICE_NONE;
736
737 ALOGV("%s: enter: out_device(%#x) in_device(%#x)",
738 __func__, out_device, in_device);
739 if (mode == AUDIO_MODE_IN_CALL) {
740 if (out_device == AUDIO_DEVICE_NONE) {
741 ALOGE("%s: No output device set for voice call", __func__);
742 goto exit;
743 }
Ravi Kumar Alamandabdf14162014-09-05 16:14:17 -0700744 if (adev->voice.tty_mode != TTY_MODE_OFF) {
Eric Laurentb23d5282013-05-14 15:27:20 -0700745 if (out_device & AUDIO_DEVICE_OUT_WIRED_HEADPHONE ||
746 out_device & AUDIO_DEVICE_OUT_WIRED_HEADSET) {
Ravi Kumar Alamandabdf14162014-09-05 16:14:17 -0700747 switch (adev->voice.tty_mode) {
Eric Laurentb23d5282013-05-14 15:27:20 -0700748 case TTY_MODE_FULL:
749 snd_device = SND_DEVICE_IN_VOICE_TTY_FULL_HEADSET_MIC;
750 break;
751 case TTY_MODE_VCO:
752 snd_device = SND_DEVICE_IN_VOICE_TTY_VCO_HANDSET_MIC;
753 break;
754 case TTY_MODE_HCO:
755 snd_device = SND_DEVICE_IN_VOICE_TTY_HCO_HEADSET_MIC;
756 break;
757 default:
Ravi Kumar Alamandabdf14162014-09-05 16:14:17 -0700758 ALOGE("%s: Invalid TTY mode (%#x)", __func__, adev->voice.tty_mode);
Eric Laurentb23d5282013-05-14 15:27:20 -0700759 }
760 goto exit;
761 }
762 }
763 if (out_device & AUDIO_DEVICE_OUT_EARPIECE ||
764 out_device & AUDIO_DEVICE_OUT_WIRED_HEADPHONE) {
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700765 if (my_data->fluence_type == FLUENCE_NONE ||
766 my_data->fluence_in_voice_call == false) {
Eric Laurentb23d5282013-05-14 15:27:20 -0700767 snd_device = SND_DEVICE_IN_HANDSET_MIC;
768 } else {
Ravi Kumar Alamandaceb40822013-11-06 11:01:47 -0800769 snd_device = SND_DEVICE_IN_VOICE_DMIC;
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700770 adev->acdb_settings |= DMIC_FLAG;
Eric Laurentb23d5282013-05-14 15:27:20 -0700771 }
772 } else if (out_device & AUDIO_DEVICE_OUT_WIRED_HEADSET) {
773 snd_device = SND_DEVICE_IN_VOICE_HEADSET_MIC;
774 } else if (out_device & AUDIO_DEVICE_OUT_ALL_SCO) {
Mingming Yin514a8bc2014-07-29 15:22:21 -0700775 if (adev->bt_wb_speech_enabled)
776 snd_device = SND_DEVICE_IN_BT_SCO_MIC_WB;
777 else
778 snd_device = SND_DEVICE_IN_BT_SCO_MIC;
Eric Laurentb23d5282013-05-14 15:27:20 -0700779 } else if (out_device & AUDIO_DEVICE_OUT_SPEAKER) {
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700780 if (my_data->fluence_type != FLUENCE_NONE &&
781 my_data->fluence_in_voice_call &&
782 my_data->fluence_in_spkr_mode) {
783 if(my_data->fluence_type == FLUENCE_DUAL_MIC) {
784 adev->acdb_settings |= DMIC_FLAG;
785 snd_device = SND_DEVICE_IN_VOICE_SPEAKER_DMIC;
786 } else {
787 adev->acdb_settings |= QMIC_FLAG;
788 snd_device = SND_DEVICE_IN_VOICE_SPEAKER_QMIC;
789 }
Eric Laurentb23d5282013-05-14 15:27:20 -0700790 } else {
791 snd_device = SND_DEVICE_IN_VOICE_SPEAKER_MIC;
792 }
793 }
794 } else if (source == AUDIO_SOURCE_CAMCORDER) {
795 if (in_device & AUDIO_DEVICE_IN_BUILTIN_MIC ||
796 in_device & AUDIO_DEVICE_IN_BACK_MIC) {
797 snd_device = SND_DEVICE_IN_CAMCORDER_MIC;
798 }
799 } else if (source == AUDIO_SOURCE_VOICE_RECOGNITION) {
800 if (in_device & AUDIO_DEVICE_IN_BUILTIN_MIC) {
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700801 if (channel_mask == AUDIO_CHANNEL_IN_FRONT_BACK)
802 snd_device = SND_DEVICE_IN_VOICE_REC_DMIC;
803 else if (my_data->fluence_in_voice_rec)
804 snd_device = SND_DEVICE_IN_VOICE_REC_DMIC_FLUENCE;
Eric Laurentb23d5282013-05-14 15:27:20 -0700805
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700806 if (snd_device == SND_DEVICE_NONE)
Eric Laurentb23d5282013-05-14 15:27:20 -0700807 snd_device = SND_DEVICE_IN_VOICE_REC_MIC;
Mingming Yin8e5a4f62013-10-07 15:23:41 -0700808 else
809 adev->acdb_settings |= DMIC_FLAG;
Eric Laurentb23d5282013-05-14 15:27:20 -0700810 }
811 } else if (source == AUDIO_SOURCE_VOICE_COMMUNICATION) {
812 if (out_device & AUDIO_DEVICE_OUT_SPEAKER)
813 in_device = AUDIO_DEVICE_IN_BACK_MIC;
814 if (adev->active_input) {
815 if (adev->active_input->enable_aec) {
816 if (in_device & AUDIO_DEVICE_IN_BACK_MIC) {
817 snd_device = SND_DEVICE_IN_SPEAKER_MIC_AEC;
818 } else if (in_device & AUDIO_DEVICE_IN_BUILTIN_MIC) {
819 snd_device = SND_DEVICE_IN_HANDSET_MIC_AEC;
820 } else if (in_device & AUDIO_DEVICE_IN_WIRED_HEADSET) {
821 snd_device = SND_DEVICE_IN_HEADSET_MIC_AEC;
822 }
Venkata Narendra Kumar Gutta1bbbf542014-09-04 19:11:25 +0530823 platform_set_echo_reference(adev->platform, true);
Eric Laurentb23d5282013-05-14 15:27:20 -0700824 } else
Venkata Narendra Kumar Gutta1bbbf542014-09-04 19:11:25 +0530825 platform_set_echo_reference(adev->platform, false);
Eric Laurentb23d5282013-05-14 15:27:20 -0700826 }
827 } else if (source == AUDIO_SOURCE_DEFAULT) {
828 goto exit;
829 }
830
831
832 if (snd_device != SND_DEVICE_NONE) {
833 goto exit;
834 }
835
836 if (in_device != AUDIO_DEVICE_NONE &&
837 !(in_device & AUDIO_DEVICE_IN_VOICE_CALL) &&
838 !(in_device & AUDIO_DEVICE_IN_COMMUNICATION)) {
839 if (in_device & AUDIO_DEVICE_IN_BUILTIN_MIC) {
840 snd_device = SND_DEVICE_IN_HANDSET_MIC;
841 } else if (in_device & AUDIO_DEVICE_IN_BACK_MIC) {
842 snd_device = SND_DEVICE_IN_SPEAKER_MIC;
843 } else if (in_device & AUDIO_DEVICE_IN_WIRED_HEADSET) {
844 snd_device = SND_DEVICE_IN_HEADSET_MIC;
845 } else if (in_device & AUDIO_DEVICE_IN_BLUETOOTH_SCO_HEADSET) {
Mingming Yin514a8bc2014-07-29 15:22:21 -0700846 if (adev->bt_wb_speech_enabled)
847 snd_device = SND_DEVICE_IN_BT_SCO_MIC_WB;
848 else
849 snd_device = SND_DEVICE_IN_BT_SCO_MIC;
Eric Laurentb23d5282013-05-14 15:27:20 -0700850 } else if (in_device & AUDIO_DEVICE_IN_AUX_DIGITAL) {
851 snd_device = SND_DEVICE_IN_HDMI_MIC;
852 } else {
853 ALOGE("%s: Unknown input device(s) %#x", __func__, in_device);
854 ALOGW("%s: Using default handset-mic", __func__);
855 snd_device = SND_DEVICE_IN_HANDSET_MIC;
856 }
857 } else {
858 if (out_device & AUDIO_DEVICE_OUT_EARPIECE) {
859 snd_device = SND_DEVICE_IN_HANDSET_MIC;
860 } else if (out_device & AUDIO_DEVICE_OUT_WIRED_HEADSET) {
861 snd_device = SND_DEVICE_IN_HEADSET_MIC;
862 } else if (out_device & AUDIO_DEVICE_OUT_SPEAKER) {
863 snd_device = SND_DEVICE_IN_SPEAKER_MIC;
864 } else if (out_device & AUDIO_DEVICE_OUT_WIRED_HEADPHONE) {
865 snd_device = SND_DEVICE_IN_HANDSET_MIC;
866 } else if (out_device & AUDIO_DEVICE_OUT_BLUETOOTH_SCO_HEADSET) {
Mingming Yin514a8bc2014-07-29 15:22:21 -0700867 if (adev->bt_wb_speech_enabled)
868 snd_device = SND_DEVICE_IN_BT_SCO_MIC_WB;
869 else
870 snd_device = SND_DEVICE_IN_BT_SCO_MIC;
Eric Laurentb23d5282013-05-14 15:27:20 -0700871 } else if (out_device & AUDIO_DEVICE_OUT_AUX_DIGITAL) {
872 snd_device = SND_DEVICE_IN_HDMI_MIC;
873 } else {
874 ALOGE("%s: Unknown output device(s) %#x", __func__, out_device);
875 ALOGW("%s: Using default handset-mic", __func__);
876 snd_device = SND_DEVICE_IN_HANDSET_MIC;
877 }
878 }
879exit:
880 ALOGV("%s: exit: in_snd_device(%s)", __func__, device_table[snd_device]);
881 return snd_device;
882}
883
884int platform_set_hdmi_channels(void *platform, int channel_count)
885{
886 struct platform_data *my_data = (struct platform_data *)platform;
887 struct audio_device *adev = my_data->adev;
888 struct mixer_ctl *ctl;
889 const char *channel_cnt_str = NULL;
890 const char *mixer_ctl_name = "HDMI_RX Channels";
891 switch (channel_count) {
892 case 8:
893 channel_cnt_str = "Eight"; break;
894 case 7:
895 channel_cnt_str = "Seven"; break;
896 case 6:
897 channel_cnt_str = "Six"; break;
898 case 5:
899 channel_cnt_str = "Five"; break;
900 case 4:
901 channel_cnt_str = "Four"; break;
902 case 3:
903 channel_cnt_str = "Three"; break;
904 default:
905 channel_cnt_str = "Two"; break;
906 }
907 ctl = mixer_get_ctl_by_name(adev->mixer, mixer_ctl_name);
908 if (!ctl) {
909 ALOGE("%s: Could not get ctl for mixer cmd - %s",
910 __func__, mixer_ctl_name);
911 return -EINVAL;
912 }
913 ALOGV("HDMI channel count: %s", channel_cnt_str);
914 mixer_ctl_set_enum_by_string(ctl, channel_cnt_str);
915 return 0;
916}
917
Ravi Kumar Alamandabdf14162014-09-05 16:14:17 -0700918int platform_edid_get_max_channels(void *platform __unused)
Eric Laurentb23d5282013-05-14 15:27:20 -0700919{
920 FILE *file;
921 struct audio_block_header header;
922 char block[MAX_SAD_BLOCKS * SAD_BLOCK_SIZE];
923 char *sad = block;
924 int num_audio_blocks;
925 int channel_count;
926 int max_channels = 0;
927 int i;
928
929 file = fopen(AUDIO_DATA_BLOCK_PATH, "rb");
930 if (file == NULL) {
931 ALOGE("Unable to open '%s'", AUDIO_DATA_BLOCK_PATH);
932 return 0;
933 }
934
935 /* Read audio block header */
936 fread(&header, 1, sizeof(header), file);
937
938 /* Read SAD blocks, clamping the maximum size for safety */
939 if (header.length > (int)sizeof(block))
940 header.length = (int)sizeof(block);
941 fread(&block, header.length, 1, file);
942
943 fclose(file);
944
945 /* Calculate the number of SAD blocks */
946 num_audio_blocks = header.length / SAD_BLOCK_SIZE;
947
948 for (i = 0; i < num_audio_blocks; i++) {
949 /* Only consider LPCM blocks */
950 if ((sad[0] >> 3) != EDID_FORMAT_LPCM)
951 continue;
952
953 channel_count = (sad[0] & 0x7) + 1;
954 if (channel_count > max_channels)
955 max_channels = channel_count;
956
957 /* Advance to next block */
958 sad += 3;
959 }
960
961 return max_channels;
962}
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700963
Ravi Kumar Alamandabdf14162014-09-05 16:14:17 -0700964void platform_get_parameters(void *platform __unused,
965 struct str_parms *query __unused,
966 struct str_parms *reply __unused)
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700967{
Ravi Kumar Alamandabdf14162014-09-05 16:14:17 -0700968 ALOGE("%s: Not implemented", __func__);
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700969}
970
Ravi Kumar Alamandabdf14162014-09-05 16:14:17 -0700971int platform_set_parameters(void *platform __unused, struct str_parms *parms __unused)
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700972{
Ravi Kumar Alamandabdf14162014-09-05 16:14:17 -0700973 ALOGE("%s: Not implemented", __func__);
Shiv Maliyappanahalli34b585f2013-10-01 15:49:05 -0700974 return -ENOSYS;
975}
Shiv Maliyappanahallida107642013-10-17 11:16:13 -0700976
Ravi Kumar Alamandabdf14162014-09-05 16:14:17 -0700977int platform_set_incall_recoding_session_id(void *platform __unused,
978 uint32_t session_id __unused)
Shiv Maliyappanahallida107642013-10-17 11:16:13 -0700979{
Ravi Kumar Alamandabdf14162014-09-05 16:14:17 -0700980 ALOGE("%s: Not implemented", __func__);
Shiv Maliyappanahallida107642013-10-17 11:16:13 -0700981 return -ENOSYS;
982}
Shruthi Krishnaace10852013-10-25 14:32:12 -0700983
Vidyakumar Athota21b3bb92014-04-25 11:08:08 -0700984int platform_update_lch(void *platform __unused,
985 struct voice_session *session __unused,
986 enum voice_lch_mode lch_mode __unused)
987{
Ravi Kumar Alamandabdf14162014-09-05 16:14:17 -0700988 ALOGE("%s: Not implemented", __func__);
989 return -ENOSYS;
990}
991
992int platform_start_incall_music_usecase(void *platform __unused)
993{
994 ALOGE("%s: Not implemented", __func__);
995 return -ENOSYS;
996}
997
998int platform_stop_incall_music_usecase(void *platform __unused)
999{
1000 ALOGE("%s: Not implemented", __func__);
Vidyakumar Athota21b3bb92014-04-25 11:08:08 -07001001 return -ENOSYS;
1002}
1003
Haynes Mathew George7ff216f2013-09-11 19:51:41 -07001004/* Delay in Us */
1005int64_t platform_render_latency(audio_usecase_t usecase)
1006{
1007 switch (usecase) {
1008 case USECASE_AUDIO_PLAYBACK_DEEP_BUFFER:
1009 return DEEP_BUFFER_PLATFORM_DELAY;
1010 case USECASE_AUDIO_PLAYBACK_LOW_LATENCY:
1011 return LOW_LATENCY_PLATFORM_DELAY;
1012 default:
1013 return 0;
1014 }
1015}
Mingming Yine62d7842013-10-25 16:26:03 -07001016
1017int platform_update_usecase_from_source(int source, int usecase)
1018{
1019 ALOGV("%s: input source :%d", __func__, source);
1020 return usecase;
1021}
Kiran Kandide144c82013-11-20 15:58:32 -08001022
Ravi Kumar Alamandabdf14162014-09-05 16:14:17 -07001023bool platform_listen_device_needs_event(snd_device_t snd_device __unused)
Kiran Kandide144c82013-11-20 15:58:32 -08001024{
Dhananjay Kumar45b71742014-05-29 21:47:27 +05301025 return false;
1026}
1027
Ravi Kumar Alamandabdf14162014-09-05 16:14:17 -07001028bool platform_listen_usecase_needs_event(audio_usecase_t uc_id __unused)
Dhananjay Kumar45b71742014-05-29 21:47:27 +05301029{
1030 return false;
Kiran Kandide144c82013-11-20 15:58:32 -08001031}
Mingming Yin3ee55c62014-08-04 14:23:35 -07001032
1033bool platform_check_24_bit_support() {
1034 return false;
1035}
1036
Ravi Kumar Alamandabdf14162014-09-05 16:14:17 -07001037bool platform_check_and_set_codec_backend_cfg(struct audio_device* adev __unused,
1038 struct audio_usecase *usecase __unused)
1039{
Mingming Yin3ee55c62014-08-04 14:23:35 -07001040 return false;
1041}
1042
Haynes Mathew Georgef4da6fe2014-06-20 19:14:25 -07001043int platform_get_usecase_index(const char * usecase __unused)
1044{
1045 return -ENOSYS;
1046}
1047
1048int platform_set_usecase_pcm_id(audio_usecase_t usecase __unused, int32_t type __unused,
1049 int32_t pcm_id __unused)
1050{
1051 return -ENOSYS;
1052}
1053
1054int platform_set_snd_device_backend(snd_device_t snd_device __unused,
1055 const char * backend __unused)
1056{
1057 return -ENOSYS;
1058}
Ravi Kumar Alamanda8fa6b192014-09-09 16:06:42 -07001059
1060bool platform_sound_trigger_device_needs_event(snd_device_t snd_device __unused)
1061{
1062 return false;
1063}
1064
1065bool platform_sound_trigger_usecase_needs_event(audio_usecase_t uc_id __unused)
1066{
1067 return false;
1068}
Ravi Kumar Alamandabdf14162014-09-05 16:14:17 -07001069
1070int platform_set_fluence_type(void *platform __unused, char *value __unused)
1071{
1072 return -ENOSYS;
1073}
1074
1075int platform_get_fluence_type(void *platform __unused, char *value __unused,
1076 uint32_t len __unused)
1077{
1078 return -ENOSYS;
1079}
1080
1081uint32_t platform_get_pcm_offload_buffer_size(audio_offload_info_t* info __unused)
1082{
1083 return 0;
1084}