diff options
author | Artem Borisov <dedsa2002@gmail.com> | 2017-12-02 20:19:25 +0300 |
---|---|---|
committer | Michael Bestas <mkbestas@lineageos.org> | 2017-12-31 15:48:59 +0200 |
commit | 4eee695f0069d0ad101c4aaffd55604770d98e33 (patch) | |
tree | 3ee5d8c090dff803be5043401d1b347e3c0d8009 | |
parent | 6f168982a4ba9e46df641dfe9114f420717fc73a (diff) | |
download | hardware_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.c | 28 |
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; |