blob: 7b955bafbf1694021fbf44178f3a1374f9d62985 [file] [log] [blame]
Naresh Tanniru87dfa982014-03-04 15:03:11 +05301/*
2 * Copyright (c) 2014, 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
Naresh Tanniru87dfa982014-03-04 15:03:11 +053054static 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,
Naresh Tannirudb72d1e2014-03-05 17:33:47 +053064 SND_DEVICE_IN_QUAD_MIC,
65};
66
67static const snd_device_t taiko_apq8084_CDP_variant_devices[] = {
68 SND_DEVICE_IN_HANDSET_MIC,
Naresh Tanniru87dfa982014-03-04 15:03:11 +053069};
70
71static 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,
Naresh Tannirudb72d1e2014-03-05 17:33:47 +053077 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,
Naresh Tanniru87dfa982014-03-04 15:03:11 +053084};
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,
Naresh Tannirudb72d1e2014-03-05 17:33:47 +053091 SND_DEVICE_IN_HEADSET_MIC,
92 SND_DEVICE_IN_QUAD_MIC,
Naresh Tanniru87dfa982014-03-04 15:03:11 +053093};
94
95static const snd_device_t tapan_lite_variant_devices[] = {
96 SND_DEVICE_OUT_SPEAKER,
Naresh Tannirudb72d1e2014-03-05 17:33:47 +053097 SND_DEVICE_OUT_HEADPHONES,
Naresh Tanniru87dfa982014-03-04 15:03:11 +053098 SND_DEVICE_OUT_SPEAKER_AND_HEADPHONES,
Naresh Tannirudb72d1e2014-03-05 17:33:47 +053099 SND_DEVICE_OUT_VOICE_HEADPHONES,
100 SND_DEVICE_OUT_VOICE_TTY_FULL_HEADPHONES,
101 SND_DEVICE_OUT_VOICE_TTY_VCO_HEADPHONES,
Naresh Tanniru87dfa982014-03-04 15:03:11 +0530102};
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,
Naresh Tannirudb72d1e2014-03-05 17:33:47 +0530108 /*SND_DEVICE_OUT_SPEAKER_AND_ANC_FB_HEADSET,*/
Naresh Tanniru87dfa982014-03-04 15:03:11 +0530109};
110
111static const snd_device_t tapan_lite_skuf_variant_devices[] = {
112 SND_DEVICE_OUT_SPEAKER,
Naresh Tannirudb72d1e2014-03-05 17:33:47 +0530113 SND_DEVICE_OUT_HEADPHONES,
Naresh Tanniru87dfa982014-03-04 15:03:11 +0530114 SND_DEVICE_OUT_SPEAKER_AND_HEADPHONES,
Naresh Tannirudb72d1e2014-03-05 17:33:47 +0530115 SND_DEVICE_OUT_VOICE_HEADPHONES,
116 SND_DEVICE_OUT_VOICE_TTY_FULL_HEADPHONES,
117 SND_DEVICE_OUT_VOICE_TTY_VCO_HEADPHONES,
Naresh Tanniru87dfa982014-03-04 15:03:11 +0530118};
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
Naresh Tannirudb72d1e2014-03-05 17:33:47 +0530126static void update_hardware_info_8x16(struct hardware_info *hw_info, const char *snd_card_name)
Naresh Tanniru87dfa982014-03-04 15:03:11 +0530127{
Naresh Tannirudb72d1e2014-03-05 17:33:47 +0530128 if (!strcmp(snd_card_name, "msm8x16-snd-card")) {
Naresh Tanniru87dfa982014-03-04 15:03:11 +0530129 strlcpy(hw_info->type, "", sizeof(hw_info->type));
Naresh Tannirudb72d1e2014-03-05 17:33:47 +0530130 strlcpy(hw_info->name, "msm8x16", sizeof(hw_info->name));
Naresh Tanniru87dfa982014-03-04 15:03:11 +0530131 hw_info->snd_devices = NULL;
132 hw_info->num_snd_devices = 0;
133 strlcpy(hw_info->dev_extn, "", sizeof(hw_info->dev_extn));
Walter Yang1cc4d362014-03-20 12:28:55 +0800134 } else if (!strcmp(snd_card_name, "msm8x16-skuh-snd-card")) {
135 strlcpy(hw_info->type, "skuh", sizeof(hw_info->type));
Naresh Tannirudb72d1e2014-03-05 17:33:47 +0530136 strlcpy(hw_info->name, "msm8x16", sizeof(hw_info->name));
Naresh Tanniru87dfa982014-03-04 15:03:11 +0530137 hw_info->snd_devices = NULL;
138 hw_info->num_snd_devices = 0;
139 strlcpy(hw_info->dev_extn, "", sizeof(hw_info->dev_extn));
140 } else {
Naresh Tannirudb72d1e2014-03-05 17:33:47 +0530141 ALOGW("%s: Not an 8x16 device", __func__);
Naresh Tanniru87dfa982014-03-04 15:03:11 +0530142 }
143}
144
145void *hw_info_init(const char *snd_card_name)
146{
147 struct hardware_info *hw_info;
148
149 hw_info = malloc(sizeof(struct hardware_info));
150
Naresh Tannirudb72d1e2014-03-05 17:33:47 +0530151 if(strstr(snd_card_name, "msm8x16")) {
152 ALOGV("8x16 - variant soundcard");
153 update_hardware_info_8x16(hw_info, snd_card_name);
Naresh Tanniru87dfa982014-03-04 15:03:11 +0530154 } else {
Naresh Tannirudb72d1e2014-03-05 17:33:47 +0530155 ALOGE("%s: Unsupported target %s:",__func__, snd_card_name);
Naresh Tanniru87dfa982014-03-04 15:03:11 +0530156 free(hw_info);
157 hw_info = NULL;
158 }
159
160 return hw_info;
161}
162
163void hw_info_deinit(void *hw_info)
164{
165 struct hardware_info *my_data = (struct hardware_info*) hw_info;
166
167 if(!my_data)
168 free(my_data);
169}
170
171void hw_info_append_hw_type(void *hw_info, snd_device_t snd_device,
172 char *device_name)
173{
174 struct hardware_info *my_data = (struct hardware_info*) hw_info;
175 uint32_t i = 0;
176
177 snd_device_t *snd_devices =
178 (snd_device_t *) my_data->snd_devices;
179
180 if(snd_devices != NULL) {
181 for (i = 0; i < my_data->num_snd_devices; i++) {
182 if (snd_device == (snd_device_t)snd_devices[i]) {
183 ALOGV("extract dev_extn device %d, extn = %s",
184 (snd_device_t)snd_devices[i], my_data->dev_extn);
185 CHECK(strlcat(device_name, my_data->dev_extn,
186 DEVICE_NAME_MAX_SIZE) < DEVICE_NAME_MAX_SIZE);
187 break;
188 }
189 }
190 }
191 ALOGD("%s : device_name = %s", __func__,device_name);
192}