summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorArtem Borisov <dedsa2002@gmail.com>2017-12-02 20:19:25 +0300
committerMichael Bestas <mkbestas@lineageos.org>2017-12-31 15:48:59 +0200
commit4eee695f0069d0ad101c4aaffd55604770d98e33 (patch)
tree3ee5d8c090dff803be5043401d1b347e3c0d8009
parent6f168982a4ba9e46df641dfe9114f420717fc73a (diff)
downloadhardware_qcom_audio-staging/lineage-15.1.tar.gz
hardware_qcom_audio-staging/lineage-15.1.tar.bz2
hardware_qcom_audio-staging/lineage-15.1.zip
msm8960: treblize configurationstaging/lineage-15.1
Loosely based on f62e17dbf9e88eae1371b42c59a8f48b736abb8a Change-Id: I63e873b743d2de85d6c44491bf2aed4c8e41e0e5
-rw-r--r--hal/msm8960/platform.c28
1 files changed, 26 insertions, 2 deletions
diff --git a/hal/msm8960/platform.c b/hal/msm8960/platform.c
index d3c0aea8..60dc17c6 100644
--- a/hal/msm8960/platform.c
+++ b/hal/msm8960/platform.c
@@ -38,7 +38,7 @@
* This is the sysfs path for the HDMI audio data block
*/
#define AUDIO_DATA_BLOCK_PATH "/sys/class/graphics/fb1/audio_data_block"
-#define MIXER_XML_PATH "/system/etc/mixer_paths.xml"
+#define MIXER_XML_PATH "mixer_paths.xml"
/*
* This file will have a maximum of 38 bytes:
@@ -264,12 +264,35 @@ static int set_echo_reference(struct mixer *mixer, const char* ec_ref)
return 0;
}
+// Treblized config files will be located in /odm/etc or /vendor/etc.
+static const char *kConfigLocationList[] =
+ {"/odm/etc", "/vendor/etc", "/system/etc"};
+static const int kConfigLocationListSize =
+ (sizeof(kConfigLocationList) / sizeof(kConfigLocationList[0]));
+
+bool resolveConfigFile(char file_name[MIXER_PATH_MAX_LENGTH]) {
+ char full_config_path[MIXER_PATH_MAX_LENGTH];
+ for (int i = 0; i < kConfigLocationListSize; i++) {
+ snprintf(full_config_path,
+ MIXER_PATH_MAX_LENGTH,
+ "%s/%s",
+ kConfigLocationList[i],
+ file_name);
+ if (F_OK == access(full_config_path, 0)) {
+ strcpy(file_name, full_config_path);
+ return true;
+ }
+ }
+ return false;
+}
+
void *platform_init(struct audio_device *adev)
{
char platform[PROPERTY_VALUE_MAX];
char baseband[PROPERTY_VALUE_MAX];
char value[PROPERTY_VALUE_MAX];
struct platform_data *my_data;
+ char mixer_xml_file[MIXER_PATH_MAX_LENGTH] = MIXER_XML_PATH;
adev->mixer = mixer_open(MIXER_CARD);
@@ -278,7 +301,8 @@ void *platform_init(struct audio_device *adev)
return NULL;
}
- adev->audio_route = audio_route_init(MIXER_CARD, MIXER_XML_PATH);
+ resolveConfigFile(mixer_xml_file);
+ adev->audio_route = audio_route_init(MIXER_CARD, mixer_xml_file);
if (!adev->audio_route) {
ALOGE("%s: Failed to init audio route controls, aborting.", __func__);
return NULL;