aboutsummaryrefslogtreecommitdiff
path: root/rootdir/bin/init.class_main.sh
diff options
context:
space:
mode:
authorkleidione Freitas <kleidione@gmail.com>2022-03-24 09:16:43 -0300
committerkleidione <kleidione@gmail.com>2022-11-09 17:29:16 -0300
commit44d5c9e2cf9f1ce0670be5bedd1e415cd5c3e739 (patch)
tree4516fedba0c65fda9e795d8737d08a7746d41e40 /rootdir/bin/init.class_main.sh
parent15eeafbf239f393fcb6ed1a719398e5b7bbd6a19 (diff)
veux: Merge common tree to veux
- Ref: https://github.com/xiaomi-sm6375-devs/android_device_xiaomi_sm6375-common Signed-off-by: kleidione <kleidione@gmail.com>
Diffstat (limited to 'rootdir/bin/init.class_main.sh')
-rwxr-xr-xrootdir/bin/init.class_main.sh155
1 files changed, 155 insertions, 0 deletions
diff --git a/rootdir/bin/init.class_main.sh b/rootdir/bin/init.class_main.sh
new file mode 100755
index 0000000..05c3251
--- /dev/null
+++ b/rootdir/bin/init.class_main.sh
@@ -0,0 +1,155 @@
+#! /vendor/bin/sh
+
+# Copyright (c) 2013-2014, 2019 The Linux Foundation. All rights reserved.
+#
+# Redistribution and use in source and binary forms, with or without
+# modification, are permitted provided that the following conditions are met:
+# * Redistributions of source code must retain the above copyright
+# notice, this list of conditions and the following disclaimer.
+# * Redistributions in binary form must reproduce the above copyright
+# notice, this list of conditions and the following disclaimer in the
+# documentation and/or other materials provided with the distribution.
+# * Neither the name of The Linux Foundation nor
+# the names of its contributors may be used to endorse or promote
+# products derived from this software without specific prior written
+# permission.
+#
+# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+# IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
+# NON-INFRINGEMENT ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
+# CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
+# EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
+# PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
+# OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
+# WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
+# OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
+# ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+#
+
+#
+# start ril-daemon only for targets on which radio is present
+#
+baseband=`getprop ro.baseband`
+sgltecsfb=`getprop persist.vendor.radio.sglte_csfb`
+datamode=`getprop persist.vendor.data.mode`
+low_ram=`getprop ro.config.low_ram`
+qcrild_status=true
+
+case "$baseband" in
+ "apq" | "sda" | "qcs" )
+ setprop ro.vendor.radio.noril yes
+ stop vendor.ril-daemon
+ stop vendor.qcrild
+esac
+
+case "$baseband" in
+ "msm" | "csfb" | "svlte2a" | "mdm" | "mdm2" | "sglte" | "sglte2" | "dsda2" | "unknown" | "dsda3" | "sdm" | "sdx" | "sm6")
+
+ # For older modem packages launch ril-daemon.
+ if [ -f /vendor/firmware_mnt/verinfo/ver_info.txt ]; then
+ modem=`cat /vendor/firmware_mnt/verinfo/ver_info.txt |
+ sed -n 's/^[^:]*modem[^:]*:[[:blank:]]*//p' |
+ sed 's/.*MPSS.\(.*\)/\1/g' | cut -d \. -f 1`
+ if [ "$modem" = "AT" ]; then
+ version=`cat /vendor/firmware_mnt/verinfo/ver_info.txt |
+ sed -n 's/^[^:]*modem[^:]*:[[:blank:]]*//p' |
+ sed 's/.*AT.\(.*\)/\1/g' | cut -d \- -f 1`
+ if [ ! -z $version ]; then
+ if [ "$version" \< "3.1" ]; then
+ qcrild_status=false
+ fi
+ fi
+ elif [ "$modem" = "TA" ]; then
+ version=`cat /vendor/firmware_mnt/verinfo/ver_info.txt |
+ sed -n 's/^[^:]*modem[^:]*:[[:blank:]]*//p' |
+ sed 's/.*TA.\(.*\)/\1/g' | cut -d \- -f 1`
+ if [ ! -z $version ]; then
+ if [ "$version" \< "3.0" ]; then
+ qcrild_status=false
+ fi
+ fi
+ elif [ "$modem" = "JO" ]; then
+ version=`cat /vendor/firmware_mnt/verinfo/ver_info.txt |
+ sed -n 's/^[^:]*modem[^:]*:[[:blank:]]*//p' |
+ sed 's/.*JO.\(.*\)/\1/g' | cut -d \- -f 1`
+ if [ ! -z $version ]; then
+ if [ "$version" \< "3.2" ]; then
+ qcrild_status=false
+ fi
+ fi
+ elif [ "$modem" = "TH" ]; then
+ qcrild_status=false
+ fi
+ fi
+
+ if [ "$qcrild_status" = "true" ]; then
+ # Make sure both rild, qcrild are not running at same time.
+ # This is possible with vanilla aosp system image.
+ stop vendor.ril-daemon
+
+ start vendor.qcrild
+ else
+ start vendor.ril-daemon
+ fi
+
+ case "$baseband" in
+ "svlte2a" | "csfb")
+ start qmiproxy
+ ;;
+ "sglte" | "sglte2" )
+ if [ "x$sgltecsfb" != "xtrue" ]; then
+ start qmiproxy
+ else
+ setprop persist.vendor.radio.voice.modem.index 0
+ fi
+ ;;
+ esac
+
+ multisim=`getprop persist.radio.multisim.config`
+
+ if [ "$multisim" = "dsds" ] || [ "$multisim" = "dsda" ]; then
+ if [ "$qcrild_status" = "true" ]; then
+ start vendor.qcrild2
+ else
+ start vendor.ril-daemon2
+ fi
+ elif [ "$multisim" = "tsts" ]; then
+ if [ "$qcrild_status" = "true" ]; then
+ start vendor.qcrild2
+ start vendor.qcrild3
+ else
+ start vendor.ril-daemon2
+ start vendor.ril-daemon3
+ fi
+ fi
+
+ case "$datamode" in
+ "tethered")
+ start vendor.dataqti
+ if [ "$low_ram" != "true" ]; then
+ start vendor.dataadpl
+ fi
+ ;;
+ "concurrent")
+ start vendor.dataqti
+ if [ "$low_ram" != "true" ]; then
+ start vendor.dataadpl
+ fi
+ ;;
+ *)
+ ;;
+ esac
+esac
+
+#
+# Allow persistent faking of bms
+# User needs to set fake bms charge in persist.vendor.bms.fake_batt_capacity
+#
+fake_batt_capacity=`getprop persist.vendor.bms.fake_batt_capacity`
+case "$fake_batt_capacity" in
+ "") ;; #Do nothing here
+ * )
+ echo "$fake_batt_capacity" > /sys/class/power_supply/battery/capacity
+ ;;
+esac