From 3017c2408c8e3a125f6e4107c3096bb092b7b4e6 Mon Sep 17 00:00:00 2001 From: Michael Bestas Date: Fri, 5 May 2023 20:09:13 +0300 Subject: [PATCH] sm8350-common: Implement xtra-daemon control via property Default to false if the property is not set. Device init scripts will need to be adapted to restart loc_launcher service when property change is detected. Change-Id: Icbda789cd2a9a3391f437af2c07fc5127f2f09ab --- gps/utils/loc_cfg.cpp | 13 +++++++++++++ rootdir/etc/init.qcom.rc | 3 +++ 2 files changed, 16 insertions(+) diff --git a/gps/utils/loc_cfg.cpp b/gps/utils/loc_cfg.cpp index 2a89966..8ab035b 100644 --- a/gps/utils/loc_cfg.cpp +++ b/gps/utils/loc_cfg.cpp @@ -93,6 +93,12 @@ const char LOC_PATH_ANT_CORR[] = LOC_PATH_ANT_CORR_STR; const char LOC_PATH_SLIM_CONF[] = LOC_PATH_SLIM_CONF_STR; const char LOC_PATH_VPE_CONF[] = LOC_PATH_VPE_CONF_STR; +bool isXtraDaemonEnabled() { + bool enabled = property_get_bool("persist.sys.xtra-daemon.enabled", false); + LOC_LOGe("xtra-daemon enabled: %d\n", enabled); + return enabled; +} + bool isVendorEnhanced() { return sVendorEnhanced; } @@ -814,6 +820,13 @@ int loc_read_process_conf(const char* conf_file_name, uint32_t * process_count_p continue; } + if (strcmp(conf.proc_name, "xtra-daemon") == 0 && !isXtraDaemonEnabled()) { + LOC_LOGE("%s:%d]: Process xtra-daemon is disabled via property", + __func__, __LINE__); + child_proc[j].proc_status = DISABLED_FROM_CONF; + continue; + } + if (!isVendorEnhanced() && (conf.vendor_enhanced_process != 0)) { LOC_LOGD("%s:%d]: Process %s is disabled via vendor enhanced process check", __func__, __LINE__, conf.proc_name); diff --git a/rootdir/etc/init.qcom.rc b/rootdir/etc/init.qcom.rc index d13eada..5da9f22 100644 --- a/rootdir/etc/init.qcom.rc +++ b/rootdir/etc/init.qcom.rc @@ -273,6 +273,9 @@ service loc_launcher /system/vendor/bin/loc_launcher user gps group gps +on property:persist.sys.xtra-daemon.enabled=* + restart loc_launcher + service qcom-sh /vendor/bin/init.qcom.sh class late_start user root