blob: 6920efec41442c1b93fb16a4263892d8c06d04ee [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,
Walter Yang1d50ce62014-02-21 11:12:58 +0800124 SND_DEVICE_OUT_VOICE_SPEAKER,
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700125};
126
127static void update_hardware_info_8084(struct hardware_info *hw_info, const char *snd_card_name)
128{
Helen Zeng6a16ad72014-02-23 22:04:44 -0800129 if (!strcmp(snd_card_name, "apq8084-taiko-mtp-snd-card") ||
130 !strncmp(snd_card_name, "apq8084-taiko-i2s-mtp-snd-card",
Vidyakumar Athotab4dbbbe2014-03-06 14:34:40 -0800131 sizeof("apq8084-taiko-i2s-mtp-snd-card")) ||
132 !strncmp(snd_card_name, "apq8084-tomtom-mtp-snd-card",
133 sizeof("apq8084-tomtom-mtp-snd-card"))) {
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700134 strlcpy(hw_info->type, "mtp", sizeof(hw_info->type));
135 strlcpy(hw_info->name, "apq8084", sizeof(hw_info->name));
136 hw_info->snd_devices = NULL;
137 hw_info->num_snd_devices = 0;
138 strlcpy(hw_info->dev_extn, "", sizeof(hw_info->dev_extn));
Vidyakumar Athotab4dbbbe2014-03-06 14:34:40 -0800139 } else if ((!strcmp(snd_card_name, "apq8084-taiko-cdp-snd-card")) ||
140 !strncmp(snd_card_name, "apq8084-tomtom-cdp-snd-card",
141 sizeof("apq8084-tomtom-cdp-snd-card"))) {
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700142 strlcpy(hw_info->type, " cdp", sizeof(hw_info->type));
143 strlcpy(hw_info->name, "apq8084", sizeof(hw_info->name));
Banajit Goswamid60ca7f2013-11-16 20:55:49 -0800144 hw_info->snd_devices = (snd_device_t *)taiko_apq8084_CDP_variant_devices;
145 hw_info->num_snd_devices = ARRAY_SIZE(taiko_apq8084_CDP_variant_devices);
146 strlcpy(hw_info->dev_extn, "-cdp", sizeof(hw_info->dev_extn));
Helen Zeng6a16ad72014-02-23 22:04:44 -0800147 } else if (!strncmp(snd_card_name, "apq8084-taiko-i2s-cdp-snd-card",
148 sizeof("apq8084-taiko-i2s-cdp-snd-card"))) {
149 strlcpy(hw_info->type, " cdp", sizeof(hw_info->type));
150 strlcpy(hw_info->name, "apq8084", sizeof(hw_info->name));
151 hw_info->snd_devices = NULL;
152 hw_info->num_snd_devices = 0;
153 strlcpy(hw_info->dev_extn, "", sizeof(hw_info->dev_extn));
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700154 } else if (!strcmp(snd_card_name, "apq8084-taiko-liquid-snd-card")) {
155 strlcpy(hw_info->type , " liquid", sizeof(hw_info->type));
156 strlcpy(hw_info->name, "apq8084", sizeof(hw_info->type));
157 hw_info->snd_devices = (snd_device_t *)taiko_liquid_variant_devices;
158 hw_info->num_snd_devices = ARRAY_SIZE(taiko_liquid_variant_devices);
Banajit Goswamid60ca7f2013-11-16 20:55:49 -0800159 strlcpy(hw_info->dev_extn, "-liquid", sizeof(hw_info->dev_extn));
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700160 } else {
161 ALOGW("%s: Not an 8084 device", __func__);
162 }
163}
164
165static void update_hardware_info_8974(struct hardware_info *hw_info, const char *snd_card_name)
166{
167 if (!strcmp(snd_card_name, "msm8974-taiko-mtp-snd-card")) {
168 strlcpy(hw_info->type, " mtp", sizeof(hw_info->type));
169 strlcpy(hw_info->name, "msm8974", sizeof(hw_info->name));
170 hw_info->snd_devices = NULL;
171 hw_info->num_snd_devices = 0;
172 strlcpy(hw_info->dev_extn, "", sizeof(hw_info->dev_extn));
173 } else if (!strcmp(snd_card_name, "msm8974-taiko-cdp-snd-card")) {
174 strlcpy(hw_info->type, " cdp", sizeof(hw_info->type));
175 strlcpy(hw_info->name, "msm8974", sizeof(hw_info->name));
176 hw_info->snd_devices = (snd_device_t *)taiko_CDP_variant_devices;
177 hw_info->num_snd_devices = ARRAY_SIZE(taiko_CDP_variant_devices);
Krishnankutty Kolathappillyd801ae32013-11-03 15:48:42 -0800178 strlcpy(hw_info->dev_extn, "-cdp", sizeof(hw_info->dev_extn));
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700179 } else if (!strcmp(snd_card_name, "msm8974-taiko-fluid-snd-card")) {
180 strlcpy(hw_info->type, " fluid", sizeof(hw_info->type));
181 strlcpy(hw_info->name, "msm8974", sizeof(hw_info->name));
182 hw_info->snd_devices = (snd_device_t *) taiko_fluid_variant_devices;
183 hw_info->num_snd_devices = ARRAY_SIZE(taiko_fluid_variant_devices);
184 strlcpy(hw_info->dev_extn, "-fluid", sizeof(hw_info->dev_extn));
185 } else if (!strcmp(snd_card_name, "msm8974-taiko-liquid-snd-card")) {
186 strlcpy(hw_info->type, " liquid", sizeof(hw_info->type));
187 strlcpy(hw_info->name, "msm8974", sizeof(hw_info->name));
188 hw_info->snd_devices = (snd_device_t *)taiko_liquid_variant_devices;
189 hw_info->num_snd_devices = ARRAY_SIZE(taiko_liquid_variant_devices);
190 strlcpy(hw_info->dev_extn, "-liquid", sizeof(hw_info->dev_extn));
191 } else if (!strcmp(snd_card_name, "apq8074-taiko-db-snd-card")) {
192 strlcpy(hw_info->type, " dragon-board", sizeof(hw_info->type));
193 strlcpy(hw_info->name, "msm8974", sizeof(hw_info->name));
194 hw_info->snd_devices = (snd_device_t *)taiko_DB_variant_devices;
195 hw_info->num_snd_devices = ARRAY_SIZE(taiko_DB_variant_devices);
196 strlcpy(hw_info->dev_extn, "-DB", sizeof(hw_info->dev_extn));
197 } else {
198 ALOGW("%s: Not an 8974 device", __func__);
199 }
200}
201
202static void update_hardware_info_8610(struct hardware_info *hw_info, const char *snd_card_name)
203{
204 if (!strcmp(snd_card_name, "msm8x10-snd-card")) {
205 strlcpy(hw_info->type, "", sizeof(hw_info->type));
206 strlcpy(hw_info->name, "msm8x10", sizeof(hw_info->name));
207 hw_info->snd_devices = NULL;
208 hw_info->num_snd_devices = 0;
209 strlcpy(hw_info->dev_extn, "", sizeof(hw_info->dev_extn));
210 } else if (!strcmp(snd_card_name, "msm8x10-skuab-snd-card")) {
211 strlcpy(hw_info->type, "skuab", sizeof(hw_info->type));
212 strlcpy(hw_info->name, "msm8x10", sizeof(hw_info->name));
213 hw_info->snd_devices = (snd_device_t *)helicon_skuab_variant_devices;
214 hw_info->num_snd_devices = ARRAY_SIZE(helicon_skuab_variant_devices);
215 strlcpy(hw_info->dev_extn, "-skuab", sizeof(hw_info->dev_extn));
216 } else if (!strcmp(snd_card_name, "msm8x10-skuaa-snd-card")) {
217 strlcpy(hw_info->type, " skuaa", sizeof(hw_info->type));
218 strlcpy(hw_info->name, "msm8x10", sizeof(hw_info->name));
219 hw_info->snd_devices = NULL;
220 hw_info->num_snd_devices = 0;
221 strlcpy(hw_info->dev_extn, "", sizeof(hw_info->dev_extn));
222 } else {
223 ALOGW("%s: Not an 8x10 device", __func__);
224 }
225}
226
227static void update_hardware_info_8226(struct hardware_info *hw_info, const char *snd_card_name)
228{
229 if (!strcmp(snd_card_name, "msm8226-tapan-snd-card")) {
230 strlcpy(hw_info->type, "", sizeof(hw_info->type));
231 strlcpy(hw_info->name, "msm8226", sizeof(hw_info->name));
232 hw_info->snd_devices = NULL;
233 hw_info->num_snd_devices = 0;
234 strlcpy(hw_info->dev_extn, "", sizeof(hw_info->dev_extn));
235 } else if (!strcmp(snd_card_name, "msm8226-tapan9302-snd-card")) {
236 strlcpy(hw_info->type, "tapan_lite", sizeof(hw_info->type));
237 strlcpy(hw_info->name, "msm8226", sizeof(hw_info->name));
238 hw_info->snd_devices = (snd_device_t *)tapan_lite_variant_devices;
239 hw_info->num_snd_devices = ARRAY_SIZE(tapan_lite_variant_devices);
240 strlcpy(hw_info->dev_extn, "-lite", sizeof(hw_info->dev_extn));
241 } else if (!strcmp(snd_card_name, "msm8226-tapan-skuf-snd-card")) {
242 strlcpy(hw_info->type, " skuf", sizeof(hw_info->type));
243 strlcpy(hw_info->name, "msm8226", sizeof(hw_info->name));
244 hw_info->snd_devices = (snd_device_t *) tapan_skuf_variant_devices;
245 hw_info->num_snd_devices = ARRAY_SIZE(tapan_skuf_variant_devices);
246 strlcpy(hw_info->dev_extn, "-skuf", sizeof(hw_info->dev_extn));
247 } else if (!strcmp(snd_card_name, "msm8226-tapan9302-skuf-snd-card")) {
248 strlcpy(hw_info->type, " tapan9302-skuf", sizeof(hw_info->type));
249 strlcpy(hw_info->name, "msm8226", sizeof(hw_info->name));
250 hw_info->snd_devices = (snd_device_t *)tapan_lite_skuf_variant_devices;
251 hw_info->num_snd_devices = ARRAY_SIZE(tapan_lite_skuf_variant_devices);
252 strlcpy(hw_info->dev_extn, "-skuf-lite", sizeof(hw_info->dev_extn));
253 } else {
254 ALOGW("%s: Not an 8x26 device", __func__);
255 }
256}
257
258void *hw_info_init(const char *snd_card_name)
259{
260 struct hardware_info *hw_info;
261
262 hw_info = malloc(sizeof(struct hardware_info));
Vidyakumar Athotab4dbbbe2014-03-06 14:34:40 -0800263 hw_info->snd_devices = NULL;
264 hw_info->num_snd_devices = 0;
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700265
266 if(strstr(snd_card_name, "msm8974") ||
267 strstr(snd_card_name, "apq8074")) {
268 ALOGV("8974 - variant soundcard");
269 update_hardware_info_8974(hw_info, snd_card_name);
270 } else if(strstr(snd_card_name, "msm8226")) {
271 ALOGV("8x26 - variant soundcard");
272 update_hardware_info_8226(hw_info, snd_card_name);
273 } else if(strstr(snd_card_name, "msm8x10")) {
274 ALOGV("8x10 - variant soundcard");
275 update_hardware_info_8610(hw_info, snd_card_name);
276 } else if(strstr(snd_card_name, "apq8084")) {
277 ALOGV("8084 - variant soundcard");
278 update_hardware_info_8084(hw_info, snd_card_name);
279 } else {
Mingming Yin834543b2013-12-30 15:52:43 -0800280 ALOGE("%s: Unsupported target %s:",__func__, snd_card_name);
Ravi Kumar Alamanda48c921d2013-10-29 06:07:44 -0700281 free(hw_info);
282 hw_info = NULL;
283 }
284
285 return hw_info;
286}
287
288void hw_info_deinit(void *hw_info)
289{
290 struct hardware_info *my_data = (struct hardware_info*) hw_info;
291
292 if(!my_data)
293 free(my_data);
294}
295
296void hw_info_append_hw_type(void *hw_info, snd_device_t snd_device,
297 char *device_name)
298{
299 struct hardware_info *my_data = (struct hardware_info*) hw_info;
300 uint32_t i = 0;
301
302 snd_device_t *snd_devices =
303 (snd_device_t *) my_data->snd_devices;
304
305 if(snd_devices != NULL) {
306 for (i = 0; i < my_data->num_snd_devices; i++) {
307 if (snd_device == (snd_device_t)snd_devices[i]) {
308 ALOGV("extract dev_extn device %d, extn = %s",
309 (snd_device_t)snd_devices[i], my_data->dev_extn);
310 CHECK(strlcat(device_name, my_data->dev_extn,
311 DEVICE_NAME_MAX_SIZE) < DEVICE_NAME_MAX_SIZE);
312 break;
313 }
314 }
315 }
316 ALOGD("%s : device_name = %s", __func__,device_name);
317}