blob: d59f7270ff34c65d7166f2ee81b8b442c9662a0b [file] [log] [blame]
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -07001/*
2 * Copyright (c) 2013, The Linux Foundation. All rights reserved.
3 *
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are
6 * met:
7 * * Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer.
9 * * Redistributions in binary form must reproduce the above
10 * copyright notice, this list of conditions and the following
11 * disclaimer in the documentation and/or other materials provided
12 * with the distribution.
13 * * Neither the name of The Linux Foundation nor the names of its
14 * contributors may be used to endorse or promote products derived
15 * from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
18 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
19 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
20 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
21 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
22 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
23 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
24 * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
25 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
26 * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
27 * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28 */
29
30#define LOG_TAG "hardware_info"
31/*#define LOG_NDEBUG 0*/
32#define LOG_NDDEBUG 0
33
34#include <stdlib.h>
35#include <dlfcn.h>
36#include <cutils/log.h>
37#include <cutils/str_parms.h>
38#include "audio_hw.h"
39#include "platform.h"
40#include "platform_api.h"
41
42
43struct hardware_info {
44 char name[HW_INFO_ARRAY_MAX_SIZE];
45 char type[HW_INFO_ARRAY_MAX_SIZE];
46 /* variables for handling target variants */
47 uint32_t num_snd_devices;
48 char dev_extn[HW_INFO_ARRAY_MAX_SIZE];
49 snd_device_t *snd_devices;
50};
51
52#define ARRAY_SIZE(a) (sizeof(a) / sizeof((a)[0]))
53
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -070054static const snd_device_t taiko_fluid_variant_devices[] = {
55 SND_DEVICE_OUT_SPEAKER,
56 SND_DEVICE_OUT_SPEAKER_AND_HEADPHONES,
57 SND_DEVICE_OUT_SPEAKER_AND_ANC_HEADSET,
58};
59
60static const snd_device_t taiko_CDP_variant_devices[] = {
61 SND_DEVICE_OUT_SPEAKER,
62 SND_DEVICE_OUT_SPEAKER_AND_HEADPHONES,
63 SND_DEVICE_OUT_SPEAKER_AND_ANC_HEADSET,
Krishnankutty Kolathappillyd801ae32013-11-03 15:48:42 -080064 SND_DEVICE_IN_QUAD_MIC,
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -070065};
66
Banajit Goswamid60ca7f2013-11-16 20:55:49 -080067static const snd_device_t taiko_apq8084_CDP_variant_devices[] = {
68 SND_DEVICE_IN_HANDSET_MIC,
69};
70
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -070071static const snd_device_t taiko_liquid_variant_devices[] = {
72 SND_DEVICE_OUT_SPEAKER,
73 SND_DEVICE_OUT_SPEAKER_AND_HEADPHONES,
74 SND_DEVICE_OUT_SPEAKER_AND_ANC_HEADSET,
75 SND_DEVICE_IN_SPEAKER_MIC,
76 SND_DEVICE_IN_HEADSET_MIC,
Krishnankutty Kolathappillyd801ae32013-11-03 15:48:42 -080077 SND_DEVICE_IN_VOICE_DMIC,
78 SND_DEVICE_IN_VOICE_SPEAKER_DMIC,
79 SND_DEVICE_IN_VOICE_REC_DMIC_STEREO,
80 SND_DEVICE_IN_VOICE_REC_DMIC_FLUENCE,
81 SND_DEVICE_IN_QUAD_MIC,
82 SND_DEVICE_IN_HANDSET_STEREO_DMIC,
83 SND_DEVICE_IN_SPEAKER_STEREO_DMIC,
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -070084};
85
86static const snd_device_t taiko_DB_variant_devices[] = {
87 SND_DEVICE_OUT_SPEAKER,
88 SND_DEVICE_OUT_SPEAKER_AND_HEADPHONES,
89 SND_DEVICE_OUT_SPEAKER_AND_ANC_HEADSET,
90 SND_DEVICE_IN_SPEAKER_MIC,
Krishnankutty Kolathappillyd801ae32013-11-03 15:48:42 -080091 SND_DEVICE_IN_HEADSET_MIC,
92 SND_DEVICE_IN_QUAD_MIC,
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -070093};
94
95static const snd_device_t tapan_lite_variant_devices[] = {
96 SND_DEVICE_OUT_SPEAKER,
Krishnankutty Kolathappillyd801ae32013-11-03 15:48:42 -080097 SND_DEVICE_OUT_HEADPHONES,
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -070098 SND_DEVICE_OUT_SPEAKER_AND_HEADPHONES,
Krishnankutty Kolathappillyd801ae32013-11-03 15:48:42 -080099 SND_DEVICE_OUT_VOICE_HEADPHONES,
100 SND_DEVICE_OUT_VOICE_TTY_FULL_HEADPHONES,
101 SND_DEVICE_OUT_VOICE_TTY_VCO_HEADPHONES,
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700102};
103
104static const snd_device_t tapan_skuf_variant_devices[] = {
105 SND_DEVICE_OUT_SPEAKER,
106 SND_DEVICE_OUT_SPEAKER_AND_HEADPHONES,
107 SND_DEVICE_OUT_SPEAKER_AND_ANC_HEADSET,
Krishnankutty Kolathappillyd801ae32013-11-03 15:48:42 -0800108 /*SND_DEVICE_OUT_SPEAKER_AND_ANC_FB_HEADSET,*/
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700109};
110
111static const snd_device_t tapan_lite_skuf_variant_devices[] = {
112 SND_DEVICE_OUT_SPEAKER,
Krishnankutty Kolathappillyd801ae32013-11-03 15:48:42 -0800113 SND_DEVICE_OUT_HEADPHONES,
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700114 SND_DEVICE_OUT_SPEAKER_AND_HEADPHONES,
Krishnankutty Kolathappillyd801ae32013-11-03 15:48:42 -0800115 SND_DEVICE_OUT_VOICE_HEADPHONES,
116 SND_DEVICE_OUT_VOICE_TTY_FULL_HEADPHONES,
117 SND_DEVICE_OUT_VOICE_TTY_VCO_HEADPHONES,
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700118};
119
120static const snd_device_t helicon_skuab_variant_devices[] = {
121 SND_DEVICE_OUT_SPEAKER,
122 SND_DEVICE_OUT_SPEAKER_AND_HEADPHONES,
123 SND_DEVICE_OUT_SPEAKER_AND_ANC_HEADSET,
124};
125
126static void update_hardware_info_8084(struct hardware_info *hw_info, const char *snd_card_name)
127{
Helen Zeng6a16ad72014-02-23 22:04:44 -0800128 if (!strcmp(snd_card_name, "apq8084-taiko-mtp-snd-card") ||
129 !strncmp(snd_card_name, "apq8084-taiko-i2s-mtp-snd-card",
Vidyakumar Athotab4dbbbe2014-03-06 14:34:40 -0800130 sizeof("apq8084-taiko-i2s-mtp-snd-card")) ||
131 !strncmp(snd_card_name, "apq8084-tomtom-mtp-snd-card",
132 sizeof("apq8084-tomtom-mtp-snd-card"))) {
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700133 strlcpy(hw_info->type, "mtp", sizeof(hw_info->type));
134 strlcpy(hw_info->name, "apq8084", sizeof(hw_info->name));
135 hw_info->snd_devices = NULL;
136 hw_info->num_snd_devices = 0;
137 strlcpy(hw_info->dev_extn, "", sizeof(hw_info->dev_extn));
Vidyakumar Athotab4dbbbe2014-03-06 14:34:40 -0800138 } else if ((!strcmp(snd_card_name, "apq8084-taiko-cdp-snd-card")) ||
139 !strncmp(snd_card_name, "apq8084-tomtom-cdp-snd-card",
140 sizeof("apq8084-tomtom-cdp-snd-card"))) {
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700141 strlcpy(hw_info->type, " cdp", sizeof(hw_info->type));
142 strlcpy(hw_info->name, "apq8084", sizeof(hw_info->name));
Banajit Goswamid60ca7f2013-11-16 20:55:49 -0800143 hw_info->snd_devices = (snd_device_t *)taiko_apq8084_CDP_variant_devices;
144 hw_info->num_snd_devices = ARRAY_SIZE(taiko_apq8084_CDP_variant_devices);
145 strlcpy(hw_info->dev_extn, "-cdp", sizeof(hw_info->dev_extn));
Helen Zeng6a16ad72014-02-23 22:04:44 -0800146 } else if (!strncmp(snd_card_name, "apq8084-taiko-i2s-cdp-snd-card",
147 sizeof("apq8084-taiko-i2s-cdp-snd-card"))) {
148 strlcpy(hw_info->type, " cdp", sizeof(hw_info->type));
149 strlcpy(hw_info->name, "apq8084", sizeof(hw_info->name));
150 hw_info->snd_devices = NULL;
151 hw_info->num_snd_devices = 0;
152 strlcpy(hw_info->dev_extn, "", sizeof(hw_info->dev_extn));
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700153 } else if (!strcmp(snd_card_name, "apq8084-taiko-liquid-snd-card")) {
154 strlcpy(hw_info->type , " liquid", sizeof(hw_info->type));
155 strlcpy(hw_info->name, "apq8084", sizeof(hw_info->type));
156 hw_info->snd_devices = (snd_device_t *)taiko_liquid_variant_devices;
157 hw_info->num_snd_devices = ARRAY_SIZE(taiko_liquid_variant_devices);
Banajit Goswamid60ca7f2013-11-16 20:55:49 -0800158 strlcpy(hw_info->dev_extn, "-liquid", sizeof(hw_info->dev_extn));
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700159 } else {
160 ALOGW("%s: Not an 8084 device", __func__);
161 }
162}
163
164static void update_hardware_info_8974(struct hardware_info *hw_info, const char *snd_card_name)
165{
166 if (!strcmp(snd_card_name, "msm8974-taiko-mtp-snd-card")) {
167 strlcpy(hw_info->type, " mtp", sizeof(hw_info->type));
168 strlcpy(hw_info->name, "msm8974", sizeof(hw_info->name));
169 hw_info->snd_devices = NULL;
170 hw_info->num_snd_devices = 0;
171 strlcpy(hw_info->dev_extn, "", sizeof(hw_info->dev_extn));
172 } else if (!strcmp(snd_card_name, "msm8974-taiko-cdp-snd-card")) {
173 strlcpy(hw_info->type, " cdp", sizeof(hw_info->type));
174 strlcpy(hw_info->name, "msm8974", sizeof(hw_info->name));
175 hw_info->snd_devices = (snd_device_t *)taiko_CDP_variant_devices;
176 hw_info->num_snd_devices = ARRAY_SIZE(taiko_CDP_variant_devices);
Krishnankutty Kolathappillyd801ae32013-11-03 15:48:42 -0800177 strlcpy(hw_info->dev_extn, "-cdp", sizeof(hw_info->dev_extn));
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700178 } else if (!strcmp(snd_card_name, "msm8974-taiko-fluid-snd-card")) {
179 strlcpy(hw_info->type, " fluid", sizeof(hw_info->type));
180 strlcpy(hw_info->name, "msm8974", sizeof(hw_info->name));
181 hw_info->snd_devices = (snd_device_t *) taiko_fluid_variant_devices;
182 hw_info->num_snd_devices = ARRAY_SIZE(taiko_fluid_variant_devices);
183 strlcpy(hw_info->dev_extn, "-fluid", sizeof(hw_info->dev_extn));
184 } else if (!strcmp(snd_card_name, "msm8974-taiko-liquid-snd-card")) {
185 strlcpy(hw_info->type, " liquid", sizeof(hw_info->type));
186 strlcpy(hw_info->name, "msm8974", sizeof(hw_info->name));
187 hw_info->snd_devices = (snd_device_t *)taiko_liquid_variant_devices;
188 hw_info->num_snd_devices = ARRAY_SIZE(taiko_liquid_variant_devices);
189 strlcpy(hw_info->dev_extn, "-liquid", sizeof(hw_info->dev_extn));
190 } else if (!strcmp(snd_card_name, "apq8074-taiko-db-snd-card")) {
191 strlcpy(hw_info->type, " dragon-board", sizeof(hw_info->type));
192 strlcpy(hw_info->name, "msm8974", sizeof(hw_info->name));
193 hw_info->snd_devices = (snd_device_t *)taiko_DB_variant_devices;
194 hw_info->num_snd_devices = ARRAY_SIZE(taiko_DB_variant_devices);
195 strlcpy(hw_info->dev_extn, "-DB", sizeof(hw_info->dev_extn));
196 } else {
197 ALOGW("%s: Not an 8974 device", __func__);
198 }
199}
200
201static void update_hardware_info_8610(struct hardware_info *hw_info, const char *snd_card_name)
202{
203 if (!strcmp(snd_card_name, "msm8x10-snd-card")) {
204 strlcpy(hw_info->type, "", sizeof(hw_info->type));
205 strlcpy(hw_info->name, "msm8x10", sizeof(hw_info->name));
206 hw_info->snd_devices = NULL;
207 hw_info->num_snd_devices = 0;
208 strlcpy(hw_info->dev_extn, "", sizeof(hw_info->dev_extn));
209 } else if (!strcmp(snd_card_name, "msm8x10-skuab-snd-card")) {
210 strlcpy(hw_info->type, "skuab", sizeof(hw_info->type));
211 strlcpy(hw_info->name, "msm8x10", sizeof(hw_info->name));
212 hw_info->snd_devices = (snd_device_t *)helicon_skuab_variant_devices;
213 hw_info->num_snd_devices = ARRAY_SIZE(helicon_skuab_variant_devices);
214 strlcpy(hw_info->dev_extn, "-skuab", sizeof(hw_info->dev_extn));
215 } else if (!strcmp(snd_card_name, "msm8x10-skuaa-snd-card")) {
216 strlcpy(hw_info->type, " skuaa", sizeof(hw_info->type));
217 strlcpy(hw_info->name, "msm8x10", sizeof(hw_info->name));
218 hw_info->snd_devices = NULL;
219 hw_info->num_snd_devices = 0;
220 strlcpy(hw_info->dev_extn, "", sizeof(hw_info->dev_extn));
221 } else {
222 ALOGW("%s: Not an 8x10 device", __func__);
223 }
224}
225
226static void update_hardware_info_8226(struct hardware_info *hw_info, const char *snd_card_name)
227{
228 if (!strcmp(snd_card_name, "msm8226-tapan-snd-card")) {
229 strlcpy(hw_info->type, "", sizeof(hw_info->type));
230 strlcpy(hw_info->name, "msm8226", sizeof(hw_info->name));
231 hw_info->snd_devices = NULL;
232 hw_info->num_snd_devices = 0;
233 strlcpy(hw_info->dev_extn, "", sizeof(hw_info->dev_extn));
234 } else if (!strcmp(snd_card_name, "msm8226-tapan9302-snd-card")) {
235 strlcpy(hw_info->type, "tapan_lite", sizeof(hw_info->type));
236 strlcpy(hw_info->name, "msm8226", sizeof(hw_info->name));
237 hw_info->snd_devices = (snd_device_t *)tapan_lite_variant_devices;
238 hw_info->num_snd_devices = ARRAY_SIZE(tapan_lite_variant_devices);
239 strlcpy(hw_info->dev_extn, "-lite", sizeof(hw_info->dev_extn));
240 } else if (!strcmp(snd_card_name, "msm8226-tapan-skuf-snd-card")) {
241 strlcpy(hw_info->type, " skuf", sizeof(hw_info->type));
242 strlcpy(hw_info->name, "msm8226", sizeof(hw_info->name));
243 hw_info->snd_devices = (snd_device_t *) tapan_skuf_variant_devices;
244 hw_info->num_snd_devices = ARRAY_SIZE(tapan_skuf_variant_devices);
245 strlcpy(hw_info->dev_extn, "-skuf", sizeof(hw_info->dev_extn));
246 } else if (!strcmp(snd_card_name, "msm8226-tapan9302-skuf-snd-card")) {
247 strlcpy(hw_info->type, " tapan9302-skuf", sizeof(hw_info->type));
248 strlcpy(hw_info->name, "msm8226", sizeof(hw_info->name));
249 hw_info->snd_devices = (snd_device_t *)tapan_lite_skuf_variant_devices;
250 hw_info->num_snd_devices = ARRAY_SIZE(tapan_lite_skuf_variant_devices);
251 strlcpy(hw_info->dev_extn, "-skuf-lite", sizeof(hw_info->dev_extn));
252 } else {
253 ALOGW("%s: Not an 8x26 device", __func__);
254 }
255}
256
257void *hw_info_init(const char *snd_card_name)
258{
259 struct hardware_info *hw_info;
260
261 hw_info = malloc(sizeof(struct hardware_info));
Vidyakumar Athotab4dbbbe2014-03-06 14:34:40 -0800262 hw_info->snd_devices = NULL;
263 hw_info->num_snd_devices = 0;
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700264
265 if(strstr(snd_card_name, "msm8974") ||
266 strstr(snd_card_name, "apq8074")) {
267 ALOGV("8974 - variant soundcard");
268 update_hardware_info_8974(hw_info, snd_card_name);
269 } else if(strstr(snd_card_name, "msm8226")) {
270 ALOGV("8x26 - variant soundcard");
271 update_hardware_info_8226(hw_info, snd_card_name);
272 } else if(strstr(snd_card_name, "msm8x10")) {
273 ALOGV("8x10 - variant soundcard");
274 update_hardware_info_8610(hw_info, snd_card_name);
275 } else if(strstr(snd_card_name, "apq8084")) {
276 ALOGV("8084 - variant soundcard");
277 update_hardware_info_8084(hw_info, snd_card_name);
278 } else {
Mingming Yin834543b2013-12-30 15:52:43 -0800279 ALOGE("%s: Unsupported target %s:",__func__, snd_card_name);
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700280 free(hw_info);
281 hw_info = NULL;
282 }
283
284 return hw_info;
285}
286
287void hw_info_deinit(void *hw_info)
288{
289 struct hardware_info *my_data = (struct hardware_info*) hw_info;
290
291 if(!my_data)
292 free(my_data);
293}
294
295void hw_info_append_hw_type(void *hw_info, snd_device_t snd_device,
296 char *device_name)
297{
298 struct hardware_info *my_data = (struct hardware_info*) hw_info;
299 uint32_t i = 0;
300
301 snd_device_t *snd_devices =
302 (snd_device_t *) my_data->snd_devices;
303
304 if(snd_devices != NULL) {
305 for (i = 0; i < my_data->num_snd_devices; i++) {
306 if (snd_device == (snd_device_t)snd_devices[i]) {
307 ALOGV("extract dev_extn device %d, extn = %s",
308 (snd_device_t)snd_devices[i], my_data->dev_extn);
309 CHECK(strlcat(device_name, my_data->dev_extn,
310 DEVICE_NAME_MAX_SIZE) < DEVICE_NAME_MAX_SIZE);
311 break;
312 }
313 }
314 }
315 ALOGD("%s : device_name = %s", __func__,device_name);
316}