summaryrefslogtreecommitdiff
path: root/rootdir/bin
diff options
context:
space:
mode:
authorIsaac Chen <isaacchen@isaacchen.cn>2018-12-22 17:39:41 +0100
committerIsaac Chen <tingyi364@gmail.com>2019-09-01 13:45:57 +0200
commit52149afc453ca9cb93e1c188e5b5dfb6062aa7e1 (patch)
tree4933b6911e63c1a803d3e9afee002dff6cfb8674 /rootdir/bin
parent6307de29a852c3af01716415b511f5050383fa53 (diff)
wayne-common: Update from jasmine
* jasmine_sprout 9 PKQ1.180904.001 V10.0.9.0.PDIMIXM release-keys * Graphics SDM from LA.UM.7.4.r1-04100-8x98.0 * Cleanup rootdir a bit Signed-off-by: Isaac Chen <isaacchen@isaacchen.cn> Change-Id: I457f9d446b86b856e2cebe85b698403005c58d3e
Diffstat (limited to 'rootdir/bin')
-rwxr-xr-xrootdir/bin/init.class_main.sh102
-rwxr-xr-xrootdir/bin/init.mdm.sh34
-rwxr-xr-xrootdir/bin/init.qcom.early_boot.sh293
-rwxr-xr-xrootdir/bin/init.qcom.post_boot.sh1723
-rwxr-xr-xrootdir/bin/init.qcom.sensors.sh (renamed from rootdir/bin/init.crda.sh)27
-rwxr-xr-xrootdir/bin/init.qcom.sh174
-rwxr-xr-xrootdir/bin/init.qcom.usb.sh382
-rwxr-xr-xrootdir/bin/init.qti.qseecomd.sh2
8 files changed, 1842 insertions, 895 deletions
diff --git a/rootdir/bin/init.class_main.sh b/rootdir/bin/init.class_main.sh
index 074fb9d..9368ac9 100755
--- a/rootdir/bin/init.class_main.sh
+++ b/rootdir/bin/init.class_main.sh
@@ -32,21 +32,84 @@
#
baseband=`getprop ro.baseband`
sgltecsfb=`getprop persist.vendor.radio.sglte_csfb`
-datamode=`getprop persist.data.mode`
+datamode=`getprop persist.vendor.data.mode`
+rild_status=`getprop init.svc.ril-daemon`
+vendor_rild_status=`getprop init.svc.vendor.ril-daemon`
case "$baseband" in
- "apq" | "sda" )
- setprop ro.radio.noril yes
- stop ril-daemon
+ "apq" | "sda" | "qcs" )
+ setprop ro.vendor.radio.noril yes
+ if [ -n "$rild_status" ] || [ -n "$vendor_rild_status" ]; then
+ stop ril-daemon
+ stop vendor.ril-daemon
+ start vendor.ipacm
+ fi
esac
case "$baseband" in
"msm" | "csfb" | "svlte2a" | "mdm" | "mdm2" | "sglte" | "sglte2" | "dsda2" | "unknown" | "dsda3")
- start qmuxd
+ start vendor.qmuxd
esac
case "$baseband" in
- "msm" | "csfb" | "svlte2a" | "mdm" | "mdm2" | "sglte" | "sglte2" | "dsda2" | "unknown" | "dsda3" | "sdm" | "sdx")
+ "msm" | "csfb" | "svlte2a" | "mdm" | "mdm2" | "sglte" | "sglte2" | "dsda2" | "unknown" | "dsda3" | "sdm" | "sdx" | "sm6")
+
+ 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`
+ # Check if this is AT 3.0 or below. If so, start ril-daemon
+ 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
+ # For OTA targets, ril-daemon will be defined and for new vendor.ril-daemon
+ # To keep this script agnostic,start both of them as only valid one will start.
+ start ril-daemon
+ start vendor.ril-daemon
+ fi
+ fi
+ # For older than TA 3.0 start ril-daemon
+ 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
+ # For OTA targets, ril-daemon will be defined and for new vendor.ril-daemon
+ # To keep this script agnostic,start both of them as only valid one will start.
+ start ril-daemon
+ start vendor.ril-daemon
+ fi
+ fi
+ # For older than JO 3.2 start ril-daemon
+ 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
+ # For OTA targets, ril-daemon will be defined and for new vendor.ril-daemon
+ # To keep this script agnostic,start both of them as only valid one will start.
+ start ril-daemon
+ start vendor.ril-daemon
+ fi
+ fi
+ else
+ start ril-daemon
+ start vendor.ril-daemon
+ fi
+ fi
+
+ # Get ril-daemon status again to ensure that we have latest info
+ rild_status=`getprop init.svc.ril-daemon`
+ vendor_rild_status=`getprop init.svc.vendor.ril-daemon`
+
+ if [[ -z "$rild_status" || "$rild_status" = "stopped" ]] && [[ -z "$vendor_rild_status" || "$vendor_rild_status" = "stopped" ]]; then
+ start vendor.qcrild
+ fi
start vendor.ipacm-diag
start vendor.ipacm
case "$baseband" in
@@ -60,26 +123,35 @@ case "$baseband" in
setprop persist.vendor.radio.voice.modem.index 0
fi
;;
- "dsda2")
- setprop persist.radio.multisim.config dsda
esac
multisim=`getprop persist.radio.multisim.config`
if [ "$multisim" = "dsds" ] || [ "$multisim" = "dsda" ]; then
- start vendor.ril-daemon2
+ if [[ -z "$rild_status" || "$rild_status" = "stopped" ]] && [[ -z "$vendor_rild_status" || "$vendor_rild_status" = "stopped" ]]; then
+ start vendor.qcrild2
+ else
+ start vendor.ril-daemon2
+ fi
elif [ "$multisim" = "tsts" ]; then
- start vendor.ril-daemon2
- start vendor.ril-daemon3
+ if [[ -z "$rild_status" || "$rild_status" = "stopped" ]] && [[ -z "$vendor_rild_status" || "$vendor_rild_status" = "stopped" ]]; then
+ start vendor.qcrild2
+ start vendor.qcrild3
+ else
+ start vendor.ril-daemon2
+ start vendor.ril-daemon3
+ fi
fi
case "$datamode" in
"tethered")
- start vendor.qti
+ start vendor.dataqti
+ start vendor.dataadpl
start vendor.port-bridge
;;
"concurrent")
- start vendor.qti
+ start vendor.dataqti
+ start vendor.dataadpl
start vendor.netmgrd
start vendor.port-bridge
;;
@@ -91,9 +163,9 @@ esac
#
# Allow persistent faking of bms
-# User needs to set fake bms charge in persist.bms.fake_batt_capacity
+# User needs to set fake bms charge in persist.vendor.bms.fake_batt_capacity
#
-fake_batt_capacity=`getprop persist.bms.fake_batt_capacity`
+fake_batt_capacity=`getprop persist.vendor.bms.fake_batt_capacity`
case "$fake_batt_capacity" in
"") ;; #Do nothing here
* )
diff --git a/rootdir/bin/init.mdm.sh b/rootdir/bin/init.mdm.sh
deleted file mode 100755
index 840c8cd..0000000
--- a/rootdir/bin/init.mdm.sh
+++ /dev/null
@@ -1,34 +0,0 @@
-#! /vendor/bin/sh
-
-# Copyright (c) 2013, 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 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.
-#
-
-baseband=`getprop ro.baseband`
-if [ "$baseband" = "mdm" ] || [ "$baseband" = "mdm2" ]; then
- start mdm_helper
-fi
-
diff --git a/rootdir/bin/init.qcom.early_boot.sh b/rootdir/bin/init.qcom.early_boot.sh
index 839945a..bba8a5f 100755
--- a/rootdir/bin/init.qcom.early_boot.sh
+++ b/rootdir/bin/init.qcom.early_boot.sh
@@ -1,6 +1,6 @@
#! /vendor/bin/sh
-# Copyright (c) 2012-2013,2016 The Linux Foundation. All rights reserved.
+# Copyright (c) 2012-2013,2016,2018 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:
@@ -46,7 +46,14 @@ else
soc_hwver=`cat /sys/devices/system/soc/soc0/platform_version` 2> /dev/null
fi
-if [ -f /sys/class/graphics/fb0/virtual_size ]; then
+if [ -f /sys/class/drm/card0-DSI-1/modes ]; then
+ echo "detect" > /sys/class/drm/card0-DSI-1/status
+ mode_file=/sys/class/drm/card0-DSI-1/modes
+ while read line; do
+ fb_width=${line%x*};
+ break;
+ done < $mode_file
+elif [ -f /sys/class/graphics/fb0/virtual_size ]; then
res=`cat /sys/class/graphics/fb0/virtual_size` 2> /dev/null
fb_width=${res%,*}
fi
@@ -64,21 +71,24 @@ fi
function set_density_by_fb() {
#put default density based on width
if [ -z $fb_width ]; then
- setprop ro.sf.lcd_density 320
+ setprop vendor.display.lcd_density 320
else
- if [ $fb_width -ge 1440 ]; then
- setprop ro.sf.lcd_density 560
+ if [ $fb_width -ge 1600 ]; then
+ setprop vendor.display.lcd_density 640
+ elif [ $fb_width -ge 1440 ]; then
+ setprop vendor.display.lcd_density 560
elif [ $fb_width -ge 1080 ]; then
- setprop ro.sf.lcd_density 480
+ setprop vendor.display.lcd_density 480
elif [ $fb_width -ge 720 ]; then
- setprop ro.sf.lcd_density 320 #for 720X1280 resolution
+ setprop vendor.display.lcd_density 320 #for 720X1280 resolution
elif [ $fb_width -ge 480 ]; then
- setprop ro.sf.lcd_density 240 #for 480X854 QRD resolution
+ setprop vendor.display.lcd_density 240 #for 480X854 QRD resolution
else
- setprop ro.sf.lcd_density 160
+ setprop vendor.display.lcd_density 160
fi
fi
}
+
target=`getprop ro.board.platform`
case "$target" in
"msm7630_surf" | "msm7630_1x" | "msm7630_fusion")
@@ -89,7 +99,7 @@ case "$target" in
ln -s /system/usr/keychars/surf_keypad_qwerty.kcm.bin /system/usr/keychars/surf_keypad.kcm.bin
;;
"Fluid")
- setprop ro.sf.lcd_density 240
+ setprop vendor.display.lcd_density 240
setprop qcom.bt.dev_power_class 2
;;
*)
@@ -101,7 +111,7 @@ case "$target" in
"msm8660")
case "$soc_hwplatform" in
"Fluid")
- setprop ro.sf.lcd_density 240
+ setprop vendor.display.lcd_density 240
;;
"Dragon")
setprop ro.sound.alsa "WM8903"
@@ -117,18 +127,18 @@ case "$target" in
setprop ro.sf.hwrotation 90
fi
- setprop ro.sf.lcd_density 160
+ setprop vendor.display.lcd_density 160
;;
"MTP")
- setprop ro.sf.lcd_density 240
+ setprop vendor.display.lcd_density 240
;;
*)
case "$soc_hwid" in
"109")
- setprop ro.sf.lcd_density 160
+ setprop vendor.display.lcd_density 160
;;
*)
- setprop ro.sf.lcd_density 240
+ setprop vendor.display.lcd_density 240
;;
esac
;;
@@ -151,16 +161,16 @@ case "$target" in
"msm8974")
case "$soc_hwplatform" in
"Liquid")
- setprop ro.sf.lcd_density 160
+ setprop vendor.display.lcd_density 160
# Liquid do not have hardware navigation keys, so enable
# Android sw navigation bar
setprop ro.hw.nav_keys 0
;;
"Dragon")
- setprop ro.sf.lcd_density 240
+ setprop vendor.display.lcd_density 240
;;
*)
- setprop ro.sf.lcd_density 320
+ setprop vendor.display.lcd_density 320
;;
esac
;;
@@ -168,7 +178,7 @@ case "$target" in
"msm8226")
case "$soc_hwplatform" in
*)
- setprop ro.sf.lcd_density 320
+ setprop vendor.display.lcd_density 320
;;
esac
;;
@@ -176,65 +186,65 @@ case "$target" in
"msm8610" | "apq8084" | "mpq8092")
case "$soc_hwplatform" in
*)
- setprop ro.sf.lcd_density 240
+ setprop vendor.display.lcd_density 240
;;
esac
;;
"apq8084")
case "$soc_hwplatform" in
"Liquid")
- setprop ro.sf.lcd_density 320
+ setprop vendor.display.lcd_density 320
# Liquid do not have hardware navigation keys, so enable
# Android sw navigation bar
setprop ro.hw.nav_keys 0
;;
"SBC")
- setprop ro.sf.lcd_density 200
+ setprop vendor.display.lcd_density 200
# SBC do not have hardware navigation keys, so enable
# Android sw navigation bar
setprop qemu.hw.mainkeys 0
;;
*)
- setprop ro.sf.lcd_density 480
+ setprop vendor.display.lcd_density 480
;;
esac
;;
"msm8996")
case "$soc_hwplatform" in
"Dragon")
- setprop ro.sf.lcd_density 240
+ setprop vendor.display.lcd_density 240
setprop qemu.hw.mainkeys 0
;;
"ADP")
- setprop ro.sf.lcd_density 160
+ setprop vendor.display.lcd_density 160
setprop qemu.hw.mainkeys 0
;;
"SBC")
- setprop ro.sf.lcd_density 240
+ setprop vendor.display.lcd_density 240
setprop qemu.hw.mainkeys 0
;;
*)
- setprop ro.sf.lcd_density 560
+ setprop vendor.display.lcd_density 560
;;
esac
;;
"msm8937" | "msm8940")
- # Set ro.opengles.version based on chip id.
+ # Set vendor.opengles.version based on chip id.
# MSM8937 and MSM8940 variants supports OpenGLES 3.1
# 196608 is decimal for 0x30000 to report version 3.0
# 196609 is decimal for 0x30001 to report version 3.1
# 196610 is decimal for 0x30002 to report version 3.2
case "$soc_hwid" in
- 294|295|296|297|298|313)
- setprop ro.opengles.version 196610
+ 294|295|296|297|298|313|353|354|363|364)
+ setprop vendor.opengles.version 196610
;;
303|307|308|309|320)
# Vulkan is not supported for 8917 variants
- setprop ro.opengles.version 196608
+ setprop vendor.opengles.version 196608
setprop persist.graphics.vulkan.disable true
;;
*)
- setprop ro.opengles.version 196608
+ setprop vendor.opengles.version 196608
;;
esac
;;
@@ -248,161 +258,75 @@ case "$target" in
"msm8998" | "apq8098_latv")
case "$soc_hwplatform" in
*)
- setprop ro.sf.lcd_density 560
- if [ ! -e /dev/kgsl-3d0 ]; then
- setprop persist.sys.force_sw_gles 1
- setprop sdm.idle_time 0
+ setprop vendor.display.lcd_density 560
+ ;;
+ esac
+ ;;
+ "sdm845")
+ case "$soc_hwplatform" in
+ *)
+ if [ $fb_width -le 1600 ]; then
+ setprop vendor.display.lcd_density 560
+ setprop dalvik.vm.heapgrowthlimit 256m
else
- setprop persist.sys.force_sw_gles 0
+ setprop vendor.display.lcd_density 640
+ setprop dalvik.vm.heapgrowthlimit 512m
fi
;;
esac
- case "$soc_hwid" in
- "319") #apq8098_latv
- echo "\n==Loading ALX module==\n"
- insmod /system/lib/modules/alx.ko
- ;;
- esac
;;
- "sdm845")
+ "msmnile")
case "$soc_hwplatform" in
*)
- setprop ro.sf.lcd_density 560
- if [ ! -e /dev/kgsl-3d0 ]; then
- setprop persist.sys.force_sw_gles 1
- setprop sdm.idle_time 0
+ if [ $fb_width -le 1600 ]; then
+ setprop vendor.display.lcd_density 560
+ setprop dalvik.vm.heapgrowthlimit 256m
else
- setprop persist.sys.force_sw_gles 0
+ setprop vendor.display.lcd_density 640
+ setprop dalvik.vm.heapgrowthlimit 512m
+ fi
+ ;;
+ esac
+ ;;
+ "sdm710" | "msmpeafowl")
+ case "$soc_hwplatform" in
+ *)
+ sku_ver=`cat /sys/devices/platform/soc/aa00000.qcom,vidc1/sku_version` 2> /dev/null
+ if [ $sku_ver -eq 1 ]; then
+ setprop vendor.media.sdm710.version 1
fi
;;
esac
;;
"msm8953")
- cap_ver=`cat /sys/devices/soc/1d00000.qcom,vidc/capability_version` 2> /dev/null
- if [ $cap_ver -eq 1 ]; then
- setprop media.msm8953.version 1
- fi
+ cap_ver = 1
+ if [ -e "/sys/devices/platform/soc/1d00000.qcom,vidc/capability_version" ]; then
+ cap_ver=`cat /sys/devices/platform/soc/1d00000.qcom,vidc/capability_version` 2> /dev/null
+ else
+ cap_ver=`cat /sys/devices/soc/1d00000.qcom,vidc/capability_version` 2> /dev/null
+ fi
+
+ if [ $cap_ver -eq 1 ]; then
+ setprop vendor.media.msm8953.version 1
+ fi
+ ;;
+ #Set property to differentiate SDM660 & SDM455
+ #SOC ID for SDM455 is 385
+ "sdm660")
+ case "$soc_hwid" in
+ 385)
+ setprop vendor.media.sdm660.version 1
+ esac
;;
- "msm8952")
- case "$soc_hwid" in
- 278)
- setprop media.msm8956hw 1
- if [ -f /sys/devices/soc0/platform_version ]; then
- hw_ver=`cat /sys/devices/soc.0/1d00000.qcom,vidc/version` 2> /dev/null
- if [ $hw_ver -eq 1 ]; then
- setprop media.msm8956.version 1
- fi
- fi
- ;;
- 266|277)
- setprop media.msm8956hw 1
- if [ -f /sys/devices/soc0/platform_version ]; then
- hw_ver=`cat /sys/devices/soc.0/1d00000.qcom,vidc/version` 2> /dev/null
- if [ $hw_ver -eq 1 ]; then
- setprop media.msm8956.version 1
- fi
- fi
- ;;
- 264)
- setprop persist.graphics.vulkan.disable true
- ;;
- esac
- ;;
esac
-# In mpss AT version is greater than 3.1, need
-# to use the new vendor-ril which supports L+L feature
-# otherwise use the existing old one.
-if [ -f /firmware/verinfo/ver_info.txt ]; then
- modem=`cat /firmware/verinfo/ver_info.txt |
- sed -n 's/^[^:]*modem[^:]*:[[:blank:]]*//p' |
- sed 's/.*AT.\(.*\)/\1/g' | cut -d \- -f 1`
- zygote=`getprop ro.zygote`
- case "$zygote" in
- "zygote64_32")
- if [ "$modem" \< "3.1" ]; then
- setprop vendor.rild.libpath "/vendor/lib64/libril-qc-qmi-1.so"
- else
- setprop vendor.rild.libpath "/vendor/lib64/libril-qc-hal-qmi.so"
- fi
- ;;
- "zygote32")
- if [ "$modem" \< "3.1" ]; then
- setprop vendor.rild.libpath "/vendor/lib/libril-qc-qmi-1.so"
- else
- setprop vendor.rild.libpath "/vendor/lib/libril-qc-hal-qmi.so"
- fi
- ;;
- esac
-fi
-
-if [ -f /firmware/verinfo/ver_info.txt ]; then
- # In mpss AT version is greater than 3.1, need
- # to use the new vendor-ril which supports L+L feature
- # otherwise use the existing old one.
- modem=`cat /firmware/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 /firmware/verinfo/ver_info.txt |
- sed -n 's/^[^:]*modem[^:]*:[[:blank:]]*//p' |
- sed 's/.*AT.\(.*\)/\1/g' | cut -d \- -f 1`
- if [ ! -z $version ]; then
- zygote=`getprop ro.zygote`
- case "$zygote" in
- "zygote64_32")
- if [ "$version" \< "3.1" ]; then
- setprop vendor.rild.libpath "/vendor/lib64/libril-qc-qmi-1.so"
- else
- setprop vendor.rild.libpath "/vendor/lib64/libril-qc-hal-qmi.so"
- fi
- ;;
- "zygote32")
- if [ "$version" \< "3.1" ]; then
- echo "legacy qmi load for TA less than 3.1"
- setprop vendor.rild.libpath "/vendor/lib/libril-qc-qmi-1.so"
- else
- setprop vendor.rild.libpath "/vendor/lib/libril-qc-hal-qmi.so"
- fi
- ;;
- esac
- fi
- # In mpss TA version is greater than 3.0, need
- # to use the new vendor-ril which supports L+L feature
- # otherwise use the existing old one.
- elif [ "$modem" = "TA" ]; then
- version=`cat /firmware/verinfo/ver_info.txt |
- sed -n 's/^[^:]*modem[^:]*:[[:blank:]]*//p' |
- sed 's/.*TA.\(.*\)/\1/g' | cut -d \- -f 1`
- if [ ! -z $version ]; then
- zygote=`getprop ro.zygote`
- case "$zygote" in
- "zygote64_32")
- if [ "$version" \< "3.0" ]; then
- setprop vendor.rild.libpath "/vendor/lib64/libril-qc-qmi-1.so"
- else
- setprop vendor.rild.libpath "/vendor/lib64/libril-qc-hal-qmi.so"
- fi
- ;;
- "zygote32")
- if [ "$version" \< "3.0" ]; then
- setprop vendor.rild.libpath "/vendor/lib/libril-qc-qmi-1.so"
- else
- setprop vendor.rild.libpath "/vendor/lib/libril-qc-hal-qmi.so"
- fi
- ;;
- esac
- fi
- fi;
-fi
-
baseband=`getprop ro.baseband`
#enable atfwd daemon all targets except sda, apq, qcs
case "$baseband" in
"apq" | "sda" | "qcs" )
- setprop persist.radio.atfwd.start false;;
+ setprop persist.vendor.radio.atfwd.start false;;
*)
- setprop persist.radio.atfwd.start true;;
+ setprop persist.vendor.radio.atfwd.start true;;
esac
#set default lcd density
@@ -411,6 +335,18 @@ esac
#property if any target is setting forcefully.
set_density_by_fb
+
+# set Lilliput LCD density for ADP
+product=`getprop ro.build.product`
+
+case "$product" in
+ "msmnile_au")
+ setprop vendor.display.lcd_density 160
+ ;;
+ *)
+ ;;
+esac
+
# Setup display nodes & permissions
# HDMI can be fb1 or fb2
# Loop through the sysfs nodes and determine
@@ -443,10 +379,8 @@ function setHDMIPermission() {
set_perms $file/pa system.graphics 0664
set_perms $file/cec/wr_msg system.graphics 0600
set_perms $file/hdcp/tp system.graphics 0664
+ set_perms $file/hdcp2p2/min_level_change system.graphics 0660
set_perms $file/hdmi_audio_cb audioserver.audio 0600
- set_perms $file/pll_enable system.graphics 0664
- set_perms $file/hdmi_ppm system.graphics 0664
-
ln -s $dev_file $dev_gfx_hdmi
}
@@ -476,12 +410,12 @@ then
file=/sys/class/graphics/fb0/mdp/caps
if [ -f "$file" ]
then
- setprop debug.gralloc.gfx_ubwc_disable 1
+ setprop vendor.gralloc.disable_ubwc 1
cat $file | while read line; do
case "$line" in
*"ubwc"*)
- setprop debug.gralloc.enable_fb_ubwc 1
- setprop debug.gralloc.gfx_ubwc_disable 0
+ setprop vendor.gralloc.enable_fb_ubwc 1
+ setprop vendor.gralloc.disable_ubwc 0
esac
done
fi
@@ -508,23 +442,20 @@ then
set_perms $file/msm_fb_persist_mode system.graphics 0664
fi
done
+else
+ set_perms /sys/devices/virtual/hdcp/msm_hdcp/min_level_change system.graphics 0660
fi
boot_reason=`cat /proc/sys/kernel/boot_reason`
reboot_reason=`getprop ro.boot.alarmboot`
-power_off_alarm_file=`cat /mnt/vendor/persist/alarm/powerOffAlarmSet`
if [ "$boot_reason" = "3" ] || [ "$reboot_reason" = "true" ]; then
- if [ "$power_off_alarm_file" = "1" ]
- then
- setprop ro.alarm_boot true
- setprop debug.sf.nobootanimation 1
- fi
+ setprop ro.vendor.alarm_boot true
else
- setprop ro.alarm_boot false
+ setprop ro.vendor.alarm_boot false
fi
-# copy GPU frequencies to system property
+# copy GPU frequencies to vendor property
if [ -f /sys/class/kgsl/kgsl-3d0/gpu_available_frequencies ]; then
gpu_freq=`cat /sys/class/kgsl/kgsl-3d0/gpu_available_frequencies` 2> /dev/null
- setprop ro.gpu.available_frequencies "$gpu_freq"
+ setprop vendor.gpu.available_frequencies "$gpu_freq"
fi
diff --git a/rootdir/bin/init.qcom.post_boot.sh b/rootdir/bin/init.qcom.post_boot.sh
index a7986ae..12600b0 100755
--- a/rootdir/bin/init.qcom.post_boot.sh
+++ b/rootdir/bin/init.qcom.post_boot.sh
@@ -1,6 +1,6 @@
#! /vendor/bin/sh
-# Copyright (c) 2012-2013, 2016-2017, The Linux Foundation. All rights reserved.
+# Copyright (c) 2012-2013, 2016-2018, 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:
@@ -27,6 +27,199 @@
# ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
#
+function 8953_sched_dcvs_eas()
+{
+ #governor settings
+ echo 1 > /sys/devices/system/cpu/cpu0/online
+ echo "schedutil" > /sys/devices/system/cpu/cpu0/cpufreq/scaling_governor
+ echo 0 > /sys/devices/system/cpu/cpufreq/schedutil/rate_limit_us
+ #set the hispeed_freq
+ echo 1401600 > /sys/devices/system/cpu/cpufreq/schedutil/hispeed_freq
+ #default value for hispeed_load is 90, for 8953 and sdm450 it should be 85
+ echo 85 > /sys/devices/system/cpu/cpufreq/schedutil/hispeed_load
+}
+
+function 8917_sched_dcvs_eas()
+{
+ #governor settings
+ echo 1 > /sys/devices/system/cpu/cpu0/online
+ echo "schedutil" > /sys/devices/system/cpu/cpu0/cpufreq/scaling_governor
+ echo 0 > /sys/devices/system/cpu/cpufreq/schedutil/rate_limit_us
+ #set the hispeed_freq
+ echo 1094400 > /sys/devices/system/cpu/cpufreq/schedutil/hispeed_freq
+ #default value for hispeed_load is 90, for 8917 it should be 85
+ echo 85 > /sys/devices/system/cpu/cpufreq/schedutil/hispeed_load
+}
+
+function 8937_sched_dcvs_eas()
+{
+ # enable governor for perf cluster
+ echo 1 > /sys/devices/system/cpu/cpu0/online
+ echo "schedutil" > /sys/devices/system/cpu/cpu0/cpufreq/scaling_governor
+ echo 0 > /sys/devices/system/cpu/cpu0/cpufreq/schedutil/rate_limit_us
+ #set the hispeed_freq
+ echo 1094400 > /sys/devices/system/cpu/cpu0/cpufreq/schedutil/hispeed_freq
+ #default value for hispeed_load is 90, for 8937 it should be 85
+ echo 85 > /sys/devices/system/cpu/cpu0/cpufreq/schedutil/hispeed_load
+ ## enable governor for power cluster
+ echo 1 > /sys/devices/system/cpu/cpu4/online
+ echo "schedutil" > /sys/devices/system/cpu/cpu4/cpufreq/scaling_governor
+ echo 0 > /sys/devices/system/cpu/cpu4/cpufreq/schedutil/rate_limit_us
+ #set the hispeed_freq
+ echo 768000 > /sys/devices/system/cpu/cpu4/cpufreq/schedutil/hispeed_freq
+ #default value for hispeed_load is 90, for 8937 it should be 85
+ echo 85 > /sys/devices/system/cpu/cpu4/cpufreq/schedutil/hispeed_load
+
+}
+
+function 8953_sched_dcvs_hmp()
+{
+ #scheduler settings
+ echo 3 > /proc/sys/kernel/sched_window_stats_policy
+ echo 3 > /proc/sys/kernel/sched_ravg_hist_size
+ #task packing settings
+ echo 0 > /sys/devices/system/cpu/cpu0/sched_static_cpu_pwr_cost
+ echo 0 > /sys/devices/system/cpu/cpu1/sched_static_cpu_pwr_cost
+ echo 0 > /sys/devices/system/cpu/cpu2/sched_static_cpu_pwr_cost
+ echo 0 > /sys/devices/system/cpu/cpu3/sched_static_cpu_pwr_cost
+ echo 0 > /sys/devices/system/cpu/cpu4/sched_static_cpu_pwr_cost
+ echo 0 > /sys/devices/system/cpu/cpu5/sched_static_cpu_pwr_cost
+ echo 0 > /sys/devices/system/cpu/cpu6/sched_static_cpu_pwr_cost
+ echo 0 > /sys/devices/system/cpu/cpu7/sched_static_cpu_pwr_cost
+ # spill load is set to 100% by default in the kernel
+ echo 3 > /proc/sys/kernel/sched_spill_nr_run
+ # Apply inter-cluster load balancer restrictions
+ echo 1 > /proc/sys/kernel/sched_restrict_cluster_spill
+ # set sync wakee policy tunable
+ echo 1 > /proc/sys/kernel/sched_prefer_sync_wakee_to_waker
+
+ #governor settings
+ echo 1 > /sys/devices/system/cpu/cpu0/online
+ echo "interactive" > /sys/devices/system/cpu/cpu0/cpufreq/scaling_governor
+ echo "19000 1401600:39000" > /sys/devices/system/cpu/cpufreq/interactive/above_hispeed_delay
+ echo 85 > /sys/devices/system/cpu/cpufreq/interactive/go_hispeed_load
+ echo 20000 > /sys/devices/system/cpu/cpufreq/interactive/timer_rate
+ echo 1401600 > /sys/devices/system/cpu/cpufreq/interactive/hispeed_freq
+ echo 0 > /sys/devices/system/cpu/cpufreq/interactive/io_is_busy
+ echo "85 1401600:80" > /sys/devices/system/cpu/cpufreq/interactive/target_loads
+ echo 39000 > /sys/devices/system/cpu/cpufreq/interactive/min_sample_time
+ echo 40000 > /sys/devices/system/cpu/cpufreq/interactive/sampling_down_factor
+ echo 19 > /proc/sys/kernel/sched_upmigrate_min_nice
+ # Enable sched guided freq control
+ echo 1 > /sys/devices/system/cpu/cpufreq/interactive/use_sched_load
+ echo 1 > /sys/devices/system/cpu/cpufreq/interactive/use_migration_notif
+ echo 200000 > /proc/sys/kernel/sched_freq_inc_notify
+ echo 200000 > /proc/sys/kernel/sched_freq_dec_notify
+
+}
+
+function 8917_sched_dcvs_hmp()
+{
+ # HMP scheduler settings
+ echo 3 > /proc/sys/kernel/sched_window_stats_policy
+ echo 3 > /proc/sys/kernel/sched_ravg_hist_size
+ echo 1 > /proc/sys/kernel/sched_restrict_tasks_spread
+ # HMP Task packing settings
+ echo 20 > /proc/sys/kernel/sched_small_task
+ echo 30 > /sys/devices/system/cpu/cpu0/sched_mostly_idle_load
+ echo 30 > /sys/devices/system/cpu/cpu1/sched_mostly_idle_load
+ echo 30 > /sys/devices/system/cpu/cpu2/sched_mostly_idle_load
+ echo 30 > /sys/devices/system/cpu/cpu3/sched_mostly_idle_load
+
+ echo 3 > /sys/devices/system/cpu/cpu0/sched_mostly_idle_nr_run
+ echo 3 > /sys/devices/system/cpu/cpu1/sched_mostly_idle_nr_run
+ echo 3 > /sys/devices/system/cpu/cpu2/sched_mostly_idle_nr_run
+ echo 3 > /sys/devices/system/cpu/cpu3/sched_mostly_idle_nr_run
+
+ echo 0 > /sys/devices/system/cpu/cpu0/sched_prefer_idle
+ echo 0 > /sys/devices/system/cpu/cpu1/sched_prefer_idle
+ echo 0 > /sys/devices/system/cpu/cpu2/sched_prefer_idle
+ echo 0 > /sys/devices/system/cpu/cpu3/sched_prefer_idle
+
+ echo 1 > /sys/devices/system/cpu/cpu0/online
+ echo "interactive" > /sys/devices/system/cpu/cpu0/cpufreq/scaling_governor
+ echo "19000 1094400:39000" > /sys/devices/system/cpu/cpufreq/interactive/above_hispeed_delay
+ echo 85 > /sys/devices/system/cpu/cpufreq/interactive/go_hispeed_load
+ echo 20000 > /sys/devices/system/cpu/cpufreq/interactive/timer_rate
+ echo 1094400 > /sys/devices/system/cpu/cpufreq/interactive/hispeed_freq
+ echo 0 > /sys/devices/system/cpu/cpufreq/interactive/io_is_busy
+ echo "1 960000:85 1094400:90" > /sys/devices/system/cpu/cpufreq/interactive/target_loads
+ echo 40000 > /sys/devices/system/cpu/cpufreq/interactive/min_sample_time
+ echo 40000 > /sys/devices/system/cpu/cpufreq/interactive/sampling_down_factor
+
+ # Enable sched guided freq control
+ echo 1 > /sys/devices/system/cpu/cpufreq/interactive/use_sched_load
+ echo 1 > /sys/devices/system/cpu/cpufreq/interactive/use_migration_notif
+ echo 50000 > /proc/sys/kernel/sched_freq_inc_notify
+ echo 50000 > /proc/sys/kernel/sched_freq_dec_notify
+}
+
+function 8937_sched_dcvs_hmp()
+{
+ # HMP scheduler settings
+ echo 3 > /proc/sys/kernel/sched_window_stats_policy
+ echo 3 > /proc/sys/kernel/sched_ravg_hist_size
+ # HMP Task packing settings
+ echo 20 > /proc/sys/kernel/sched_small_task
+ echo 30 > /sys/devices/system/cpu/cpu0/sched_mostly_idle_load
+ echo 30 > /sys/devices/system/cpu/cpu1/sched_mostly_idle_load
+ echo 30 > /sys/devices/system/cpu/cpu2/sched_mostly_idle_load
+ echo 30 > /sys/devices/system/cpu/cpu3/sched_mostly_idle_load
+ echo 30 > /sys/devices/system/cpu/cpu4/sched_mostly_idle_load
+ echo 30 > /sys/devices/system/cpu/cpu5/sched_mostly_idle_load
+ echo 30 > /sys/devices/system/cpu/cpu6/sched_mostly_idle_load
+ echo 30 > /sys/devices/system/cpu/cpu7/sched_mostly_idle_load
+
+ echo 3 > /sys/devices/system/cpu/cpu0/sched_mostly_idle_nr_run
+ echo 3 > /sys/devices/system/cpu/cpu1/sched_mostly_idle_nr_run
+ echo 3 > /sys/devices/system/cpu/cpu2/sched_mostly_idle_nr_run
+ echo 3 > /sys/devices/system/cpu/cpu3/sched_mostly_idle_nr_run
+ echo 3 > /sys/devices/system/cpu/cpu4/sched_mostly_idle_nr_run
+ echo 3 > /sys/devices/system/cpu/cpu5/sched_mostly_idle_nr_run
+ echo 3 > /sys/devices/system/cpu/cpu6/sched_mostly_idle_nr_run
+ echo 3 > /sys/devices/system/cpu/cpu7/sched_mostly_idle_nr_run
+
+ echo 0 > /sys/devices/system/cpu/cpu0/sched_prefer_idle
+ echo 0 > /sys/devices/system/cpu/cpu1/sched_prefer_idle
+ echo 0 > /sys/devices/system/cpu/cpu2/sched_prefer_idle
+ echo 0 > /sys/devices/system/cpu/cpu3/sched_prefer_idle
+ echo 0 > /sys/devices/system/cpu/cpu4/sched_prefer_idle
+ echo 0 > /sys/devices/system/cpu/cpu5/sched_prefer_idle
+ echo 0 > /sys/devices/system/cpu/cpu6/sched_prefer_idle
+ echo 0 > /sys/devices/system/cpu/cpu7/sched_prefer_idle
+ # enable governor for perf cluster
+ echo 1 > /sys/devices/system/cpu/cpu0/online
+ echo "interactive" > /sys/devices/system/cpu/cpu0/cpufreq/scaling_governor
+ echo "19000 1094400:39000" > /sys/devices/system/cpu/cpu0/cpufreq/interactive/above_hispeed_delay
+ echo 85 > /sys/devices/system/cpu/cpu0/cpufreq/interactive/go_hispeed_load
+ echo 20000 > /sys/devices/system/cpu/cpu0/cpufreq/interactive/timer_rate
+ echo 1094400 > /sys/devices/system/cpu/cpu0/cpufreq/interactive/hispeed_freq
+ echo 0 > /sys/devices/system/cpu/cpu0/cpufreq/interactive/io_is_busy
+ echo "1 960000:85 1094400:90 1344000:80" > /sys/devices/system/cpu/cpu0/cpufreq/interactive/target_loads
+ echo 40000 > /sys/devices/system/cpu/cpu0/cpufreq/interactive/min_sample_time
+ echo 40000 > /sys/devices/system/cpu/cpu0/cpufreq/interactive/sampling_down_factor
+
+ # enable governor for power cluster
+ echo 1 > /sys/devices/system/cpu/cpu4/online
+ echo "interactive" > /sys/devices/system/cpu/cpu4/cpufreq/scaling_governor
+ echo 39000 > /sys/devices/system/cpu/cpu4/cpufreq/interactive/above_hispeed_delay
+ echo 90 > /sys/devices/system/cpu/cpu4/cpufreq/interactive/go_hispeed_load
+ echo 20000 > /sys/devices/system/cpu/cpu4/cpufreq/interactive/timer_rate
+ echo 768000 > /sys/devices/system/cpu/cpu4/cpufreq/interactive/hispeed_freq
+ echo 0 > /sys/devices/system/cpu/cpu4/cpufreq/interactive/io_is_busy
+ echo "1 768000:90" > /sys/devices/system/cpu/cpu4/cpufreq/interactive/target_loads
+ echo 40000 > /sys/devices/system/cpu/cpu4/cpufreq/interactive/min_sample_time
+ echo 40000 > /sys/devices/system/cpu/cpu4/cpufreq/interactive/sampling_down_factor
+
+ # Enable sched guided freq control
+ echo 1 > /sys/devices/system/cpu/cpu0/cpufreq/interactive/use_sched_load
+ echo 1 > /sys/devices/system/cpu/cpu0/cpufreq/interactive/use_migration_notif
+ echo 1 > /sys/devices/system/cpu/cpu4/cpufreq/interactive/use_sched_load
+ echo 1 > /sys/devices/system/cpu/cpu4/cpufreq/interactive/use_migration_notif
+ echo 50000 > /proc/sys/kernel/sched_freq_inc_notify
+ echo 50000 > /proc/sys/kernel/sched_freq_dec_notify
+
+}
target=`getprop ro.board.platform`
function configure_zram_parameters() {
@@ -36,134 +229,207 @@ function configure_zram_parameters() {
low_ram=`getprop ro.config.low_ram`
# Zram disk - 75% for Go devices.
- # For 512MB Go device, size = 384MB
- # For 1GB Go device, size = 768MB
- # Others - 512MB size
- # And enable lz4 zram compression for Go devices
- zram_enable=`getprop ro.vendor.qti.config.zram`
- if [ "$zram_enable" == "true" ]; then
- if [ $MemTotal -le 524288 ] && [ "$low_ram" == "true" ]; then
- echo lz4 > /sys/block/zram0/comp_algorithm
+ # For 512MB Go device, size = 384MB, set same for Non-Go.
+ # For 1GB Go device, size = 768MB, set same for Non-Go.
+ # For 2GB and 3GB Non-Go device, size = 1GB
+ # For 4GB and 6GB Non-Go device, size = 2GB
+ # And enable lz4 zram compression for Go targets.
+
+ if [ "$low_ram" == "true" ]; then
+ echo lz4 > /sys/block/zram0/comp_algorithm
+ fi
+
+ if [ -f /sys/block/zram0/disksize ]; then
+ if [ $MemTotal -le 524288 ]; then
echo 402653184 > /sys/block/zram0/disksize
- elif [ $MemTotal -le 1048576 ] && [ "$low_ram" == "true" ]; then
- echo lz4 > /sys/block/zram0/comp_algorithm
+ elif [ $MemTotal -le 1048576 ]; then
echo 805306368 > /sys/block/zram0/disksize
- else
- echo 536870912 > /sys/block/zram0/disksize
+ elif [ $MemTotal -le 3145728 ]; then
+ echo 1073741824 > /sys/block/zram0/disksize
+ elif [ $MemTotal -le 6291456 ]; then
+ echo 2147483648 > /sys/block/zram0/disksize
fi
mkswap /dev/block/zram0
swapon /dev/block/zram0 -p 32758
fi
}
+function configure_read_ahead_kb_values() {
+ MemTotalStr=`cat /proc/meminfo | grep MemTotal`
+ MemTotal=${MemTotalStr:16:8}
+
+ # Set 128 for <= 3GB &
+ # set 512 for >= 4GB targets.
+ if [ $MemTotal -le 3145728 ]; then
+ echo 128 > /sys/block/mmcblk0/bdi/read_ahead_kb
+ echo 128 > /sys/block/mmcblk0/queue/read_ahead_kb
+ echo 128 > /sys/block/mmcblk0rpmb/bdi/read_ahead_kb
+ echo 128 > /sys/block/mmcblk0rpmb/queue/read_ahead_kb
+ echo 128 > /sys/block/dm-0/queue/read_ahead_kb
+ echo 128 > /sys/block/dm-1/queue/read_ahead_kb
+ else
+ echo 512 > /sys/block/mmcblk0/bdi/read_ahead_kb
+ echo 512 > /sys/block/mmcblk0/queue/read_ahead_kb
+ echo 512 > /sys/block/mmcblk0rpmb/bdi/read_ahead_kb
+ echo 512 > /sys/block/mmcblk0rpmb/queue/read_ahead_kb
+ echo 512 > /sys/block/dm-0/queue/read_ahead_kb
+ echo 512 > /sys/block/dm-1/queue/read_ahead_kb
+ fi
+}
+
+function disable_core_ctl() {
+ if [ -f /sys/devices/system/cpu/cpu0/core_ctl/enable ]; then
+ echo 0 > /sys/devices/system/cpu/cpu0/core_ctl/enable
+ else
+ echo 1 > /sys/devices/system/cpu/cpu0/core_ctl/disable
+ fi
+}
+
+function enable_swap() {
+ MemTotalStr=`cat /proc/meminfo | grep MemTotal`
+ MemTotal=${MemTotalStr:16:8}
+
+ SWAP_ENABLE_THRESHOLD=1048576
+ swap_enable=`getprop ro.vendor.qti.config.swap`
+
+ # Enable swap initially only for 1 GB targets
+ if [ "$MemTotal" -le "$SWAP_ENABLE_THRESHOLD" ] && [ "$swap_enable" == "true" ]; then
+ # Static swiftness
+ echo 1 > /proc/sys/vm/swap_ratio_enable
+ echo 70 > /proc/sys/vm/swap_ratio
+
+ # Swap disk - 200MB size
+ if [ ! -f /data/vendor/swap/swapfile ]; then
+ dd if=/dev/zero of=/data/vendor/swap/swapfile bs=1m count=200
+ fi
+ mkswap /data/vendor/swap/swapfile
+ swapon /data/vendor/swap/swapfile -p 32758
+ fi
+}
+
function configure_memory_parameters() {
- # Set Memory paremeters.
+ # Set Memory parameters.
#
# Set per_process_reclaim tuning parameters
- # 2GB 64-bit will have aggressive settings when compared to 1GB 32-bit
- # 1GB and less will use vmpressure range 50-70, 2GB will use 10-70
- # 1GB and less will use 512 pages swap size, 2GB will use 1024
+ # All targets will use vmpressure range 50-70,
+ # All targets will use 512 pages swap size.
#
# Set Low memory killer minfree parameters
- # 32 bit all memory configurations will use 15K series
- # 64 bit up to 2GB with use 14K, and above 2GB will use 18K
+ # 32 bit Non-Go, all memory configurations will use 15K series
+ # 32 bit Go, all memory configurations will use uLMK + Memcg
+ # 64 bit will use Google default LMK series.
#
# Set ALMK parameters (usually above the highest minfree values)
- # 32 bit will have 53K & 64 bit will have 81K
+ # vmpressure_file_min threshold is always set slightly higher
+ # than LMK minfree's last bin value for all targets. It is calculated as
+ # vmpressure_file_min = (last bin - second last bin ) + last bin
+ #
+ # Set allocstall_threshold to 0 for all targets.
#
ProductName=`getprop ro.product.name`
low_ram=`getprop ro.config.low_ram`
-if [ "$ProductName" == "msm8996" ]; then
- # Enable Adaptive LMK
- echo 1 > /sys/module/lowmemorykiller/parameters/enable_adaptive_lmk
- echo 81250 > /sys/module/lowmemorykiller/parameters/vmpressure_file_min
-
+if [ "$ProductName" == "msmnile" ]; then
+ # Enable ZRAM
configure_zram_parameters
+ configure_read_ahead_kb_values
else
arch_type=`uname -m`
MemTotalStr=`cat /proc/meminfo | grep MemTotal`
MemTotal=${MemTotalStr:16:8}
- # Read adj series and set adj threshold for PPR and ALMK.
- # This is required since adj values change from framework to framework.
- adj_series=`cat /sys/module/lowmemorykiller/parameters/adj`
- adj_1="${adj_series#*,}"
- set_almk_ppr_adj="${adj_1%%,*}"
-
- # PPR and ALMK should not act on HOME adj and below.
- # Normalized ADJ for HOME is 6. Hence multiply by 6
- # ADJ score represented as INT in LMK params, actual score can be in decimal
- # Hence add 6 considering a worst case of 0.9 conversion to INT (0.9*6).
- # For uLMK + Memcg, this will be set as 6 since adj is zero.
- set_almk_ppr_adj=$(((set_almk_ppr_adj * 6) + 6))
- echo $set_almk_ppr_adj > /sys/module/lowmemorykiller/parameters/adj_max_shift
- echo $set_almk_ppr_adj > /sys/module/process_reclaim/parameters/min_score_adj
-
- #Set other memory parameters
- echo 0 > /sys/module/process_reclaim/parameters/enable_process_reclaim
- echo 70 > /sys/module/process_reclaim/parameters/pressure_max
- echo 30 > /sys/module/process_reclaim/parameters/swap_opt_eff
- echo 1 > /sys/module/lowmemorykiller/parameters/enable_adaptive_lmk
- if [ "$arch_type" == "aarch64" ] && [ $MemTotal -gt 4194304 ]; then
- echo 10 > /sys/module/process_reclaim/parameters/pressure_min
- echo 1024 > /sys/module/process_reclaim/parameters/per_swap_size
- echo "18432,23040,27648,32256,55296,80640" > /sys/module/lowmemorykiller/parameters/minfree
- echo 81250 > /sys/module/lowmemorykiller/parameters/vmpressure_file_min
- elif [ "$arch_type" == "aarch64" ] && [ $MemTotal -gt 2097152 ]; then
- echo 10 > /sys/module/process_reclaim/parameters/pressure_min
- echo 1024 > /sys/module/process_reclaim/parameters/per_swap_size
- echo "18432,23040,27648,32256,80640,140640" > /sys/module/lowmemorykiller/parameters/minfree
- echo 81250 > /sys/module/lowmemorykiller/parameters/vmpressure_file_min
- elif [ "$arch_type" == "aarch64" ] && [ $MemTotal -gt 1048576 ]; then
- echo 10 > /sys/module/process_reclaim/parameters/pressure_min
- echo 1024 > /sys/module/process_reclaim/parameters/per_swap_size
- echo "14746,18432,22118,25805,40000,55000" > /sys/module/lowmemorykiller/parameters/minfree
- echo 81250 > /sys/module/lowmemorykiller/parameters/vmpressure_file_min
- elif [ "$arch_type" == "aarch64" ]; then
- echo 50 > /sys/module/process_reclaim/parameters/pressure_min
- echo 512 > /sys/module/process_reclaim/parameters/per_swap_size
- echo "14746,18432,22118,25805,40000,55000" > /sys/module/lowmemorykiller/parameters/minfree
- echo 81250 > /sys/module/lowmemorykiller/parameters/vmpressure_file_min
+ # Set parameters for 32-bit Go targets.
+ if [ $MemTotal -le 1048576 ] && [ "$low_ram" == "true" ]; then
+ # Disable KLMK, ALMK, PPR & Core Control for Go devices
+ echo 0 > /sys/module/lowmemorykiller/parameters/enable_lmk
+ echo 0 > /sys/module/lowmemorykiller/parameters/enable_adaptive_lmk
+ echo 0 > /sys/module/process_reclaim/parameters/enable_process_reclaim
+ disable_core_ctl
else
- if [ $MemTotal -le 1048576 ] && [ "$low_ram" == "true" ]; then
- # Disable KLMK, ALMK & PPR for Go devices
- echo 0 > /sys/module/lowmemorykiller/parameters/enable_lmk
- echo 0 > /sys/module/lowmemorykiller/parameters/enable_adaptive_lmk
- echo 0 > /sys/module/process_reclaim/parameters/enable_process_reclaim
+
+ # Read adj series and set adj threshold for PPR and ALMK.
+ # This is required since adj values change from framework to framework.
+ adj_series=`cat /sys/module/lowmemorykiller/parameters/adj`
+ adj_1="${adj_series#*,}"
+ set_almk_ppr_adj="${adj_1%%,*}"
+
+ # PPR and ALMK should not act on HOME adj and below.
+ # Normalized ADJ for HOME is 6. Hence multiply by 6
+ # ADJ score represented as INT in LMK params, actual score can be in decimal
+ # Hence add 6 considering a worst case of 0.9 conversion to INT (0.9*6).
+ # For uLMK + Memcg, this will be set as 6 since adj is zero.
+ set_almk_ppr_adj=$(((set_almk_ppr_adj * 6) + 6))
+ echo $set_almk_ppr_adj > /sys/module/lowmemorykiller/parameters/adj_max_shift
+
+ # Calculate vmpressure_file_min as below & set for 64 bit:
+ # vmpressure_file_min = last_lmk_bin + (last_lmk_bin - last_but_one_lmk_bin)
+ if [ "$arch_type" == "aarch64" ]; then
+ minfree_series=`cat /sys/module/lowmemorykiller/parameters/minfree`
+ minfree_1="${minfree_series#*,}" ; rem_minfree_1="${minfree_1%%,*}"
+ minfree_2="${minfree_1#*,}" ; rem_minfree_2="${minfree_2%%,*}"
+ minfree_3="${minfree_2#*,}" ; rem_minfree_3="${minfree_3%%,*}"
+ minfree_4="${minfree_3#*,}" ; rem_minfree_4="${minfree_4%%,*}"
+ minfree_5="${minfree_4#*,}"
+
+ vmpres_file_min=$((minfree_5 + (minfree_5 - rem_minfree_4)))
+ echo $vmpres_file_min > /sys/module/lowmemorykiller/parameters/vmpressure_file_min
else
- echo 50 > /sys/module/process_reclaim/parameters/pressure_min
- echo 512 > /sys/module/process_reclaim/parameters/per_swap_size
- echo "15360,19200,23040,26880,34415,43737" > /sys/module/lowmemorykiller/parameters/minfree
- echo 53059 > /sys/module/lowmemorykiller/parameters/vmpressure_file_min
+ # Set LMK series, vmpressure_file_min for 32 bit non-go targets.
+ # Disable Core Control, enable KLMK for non-go 8909.
+ if [ "$ProductName" == "msm8909" ]; then
+ disable_core_ctl
+ echo 1 > /sys/module/lowmemorykiller/parameters/enable_lmk
+ fi
+ echo "15360,19200,23040,26880,34415,43737" > /sys/module/lowmemorykiller/parameters/minfree
+ echo 53059 > /sys/module/lowmemorykiller/parameters/vmpressure_file_min
fi
- fi
- configure_zram_parameters
+ # Enable adaptive LMK for all targets &
+ # use Google default LMK series for all 64-bit targets >=2GB.
+ echo 1 > /sys/module/lowmemorykiller/parameters/enable_adaptive_lmk
- SWAP_ENABLE_THRESHOLD=1048576
- swap_enable=`getprop ro.vendor.qti.config.swap`
+ # Enable oom_reaper
+ if [ -f /sys/module/lowmemorykiller/parameters/oom_reaper ]; then
+ echo 1 > /sys/module/lowmemorykiller/parameters/oom_reaper
+ fi
- if [ -f /sys/devices/soc0/soc_id ]; then
- soc_id=`cat /sys/devices/soc0/soc_id`
- else
- soc_id=`cat /sys/devices/system/soc/soc0/id`
+ # Set PPR parameters
+ if [ -f /sys/devices/soc0/soc_id ]; then
+ soc_id=`cat /sys/devices/soc0/soc_id`
+ else
+ soc_id=`cat /sys/devices/system/soc/soc0/id`
+ fi
+
+ case "$soc_id" in
+ # Do not set PPR parameters for premium targets
+ # sdm845 - 321, 341
+ # msm8998 - 292, 319
+ # msm8996 - 246, 291, 305, 312
+ "321" | "341" | "292" | "319" | "246" | "291" | "305" | "312")
+ ;;
+ *)
+ #Set PPR parameters for all other targets.
+ echo $set_almk_ppr_adj > /sys/module/process_reclaim/parameters/min_score_adj
+ echo 0 > /sys/module/process_reclaim/parameters/enable_process_reclaim
+ echo 50 > /sys/module/process_reclaim/parameters/pressure_min
+ echo 70 > /sys/module/process_reclaim/parameters/pressure_max
+ echo 30 > /sys/module/process_reclaim/parameters/swap_opt_eff
+ echo 512 > /sys/module/process_reclaim/parameters/per_swap_size
+ ;;
+ esac
fi
- # Enable swap initially only for 1 GB targets
- if [ "$MemTotal" -le "$SWAP_ENABLE_THRESHOLD" ] && [ "$swap_enable" == "true" ]; then
- # Static swiftness
- echo 1 > /proc/sys/vm/swap_ratio_enable
- echo 70 > /proc/sys/vm/swap_ratio
+ # Set allocstall_threshold to 0 for all targets.
+ # Set swappiness to 100 for all targets
+ echo 0 > /sys/module/vmpressure/parameters/allocstall_threshold
+ echo 100 > /proc/sys/vm/swappiness
- # Swap disk - 200MB size
- if [ ! -f /data/system/swap/swapfile ]; then
- dd if=/dev/zero of=/data/system/swap/swapfile bs=1m count=200
- fi
- mkswap /data/system/swap/swapfile
- swapon /data/system/swap/swapfile -p 32758
- fi
+ configure_zram_parameters
+
+ configure_read_ahead_kb_values
+
+ enable_swap
fi
}
@@ -188,7 +454,7 @@ function start_hbtp()
# Start the Host based Touch processing but not in the power off mode.
bootmode=`getprop ro.bootmode`
if [ "charger" != $bootmode ]; then
- start hbtp
+ start vendor.hbtp
fi
}
@@ -461,7 +727,7 @@ case "$target" in
echo 100000 > /sys/devices/system/cpu/cpufreq/interactive/sampling_down_factor
echo 1497600 > /sys/module/cpu_boost/parameters/input_boost_freq
echo 40 > /sys/module/cpu_boost/parameters/input_boost_ms
- setprop ro.qualcomm.perf.cores_online 2
+ setprop ro.vendor.perf.cores_online 2
;;
*)
echo "ondemand" > /sys/devices/system/cpu/cpu0/cpufreq/scaling_governor
@@ -1336,7 +1602,7 @@ case "$target" in
case "$soc_id" in
"277" | "278")
# Start energy-awareness for 8976
- start vendor.energy-awareness
+ start energy-awareness
;;
esac
@@ -1352,6 +1618,7 @@ case "$target" in
esac
#Enable Memory Features
enable_memory_features
+ restorecon -R /sys/devices/system/cpu
;;
esac
@@ -1370,8 +1637,14 @@ case "$target" in
hw_platform=`cat /sys/devices/system/soc/soc0/hw_platform`
fi
+ if [ -f /sys/devices/soc0/platform_subtype_id ]; then
+ platform_subtype_id=`cat /sys/devices/soc0/platform_subtype_id`
+ fi
+
+ echo 0 > /proc/sys/kernel/sched_boost
+
case "$soc_id" in
- "293" | "304" | "338" | "351" )
+ "293" | "304" | "338" | "351")
# Start Host based Touch processing
case "$hw_platform" in
@@ -1385,28 +1658,18 @@ case "$target" in
;;
esac
- #scheduler settings
- echo 3 > /proc/sys/kernel/sched_window_stats_policy
- echo 3 > /proc/sys/kernel/sched_ravg_hist_size
- #task packing settings
- echo 0 > /sys/devices/system/cpu/cpu0/sched_static_cpu_pwr_cost
- echo 0 > /sys/devices/system/cpu/cpu1/sched_static_cpu_pwr_cost
- echo 0 > /sys/devices/system/cpu/cpu2/sched_static_cpu_pwr_cost
- echo 0 > /sys/devices/system/cpu/cpu3/sched_static_cpu_pwr_cost
- echo 0 > /sys/devices/system/cpu/cpu4/sched_static_cpu_pwr_cost
- echo 0 > /sys/devices/system/cpu/cpu5/sched_static_cpu_pwr_cost
- echo 0 > /sys/devices/system/cpu/cpu6/sched_static_cpu_pwr_cost
- echo 0 > /sys/devices/system/cpu/cpu7/sched_static_cpu_pwr_cost
+ if [ $soc_id -eq "338" ]; then
+ case "$hw_platform" in
+ "QRD" )
+ if [ $platform_subtype_id -eq "1" ]; then
+ start_hbtp
+ fi
+ ;;
+ esac
+ fi
#init task load, restrict wakeups to preferred cluster
echo 15 > /proc/sys/kernel/sched_init_task_load
- # spill load is set to 100% by default in the kernel
- echo 3 > /proc/sys/kernel/sched_spill_nr_run
- # Apply inter-cluster load balancer restrictions
- echo 1 > /proc/sys/kernel/sched_restrict_cluster_spill
-
- # set sync wakee policy tunable
- echo 1 > /proc/sys/kernel/sched_prefer_sync_wakee_to_waker
for devfreq_gov in /sys/class/devfreq/qcom,mincpubw*/governor
do
@@ -1467,29 +1730,6 @@ case "$target" in
echo 40 > $gpu_bimc_io_percent
done
- # Configure DCC module to capture critical register contents when device crashes
- for DCC_PATH in /sys/bus/platform/devices/*.dcc*
- do
- echo 0 > $DCC_PATH/enable
- echo cap > $DCC_PATH/func_type
- echo sram > $DCC_PATH/data_sink
- echo 1 > $DCC_PATH/config_reset
-
- # Register specifies APC CPR closed-loop settled voltage for current voltage corner
- echo 0xb1d2c18 1 > $DCC_PATH/config
-
- # Register specifies SW programmed open-loop voltage for current voltage corner
- echo 0xb1d2900 1 > $DCC_PATH/config
-
- # Register specifies APM switch settings and APM FSM state
- echo 0xb1112b0 1 > $DCC_PATH/config
-
- # Register specifies CPR mode change state and also #online cores input to CPR HW
- echo 0xb018798 1 > $DCC_PATH/config
-
- echo 1 > $DCC_PATH/enable
- done
-
# disable thermal & BCL core_control to update interactive gov settings
echo 0 > /sys/module/msm_thermal/core_control/enabled
for mode in /sys/devices/soc.0/qcom,bcl.*/mode
@@ -1511,19 +1751,30 @@ case "$target" in
echo -n enable > $mode
done
- #governor settings
- echo 1 > /sys/devices/system/cpu/cpu0/online
- echo "interactive" > /sys/devices/system/cpu/cpu0/cpufreq/scaling_governor
- echo "19000 1401600:39000" > /sys/devices/system/cpu/cpufreq/interactive/above_hispeed_delay
- echo 85 > /sys/devices/system/cpu/cpufreq/interactive/go_hispeed_load
- echo 20000 > /sys/devices/system/cpu/cpufreq/interactive/timer_rate
- echo 1401600 > /sys/devices/system/cpu/cpufreq/interactive/hispeed_freq
- echo 0 > /sys/devices/system/cpu/cpufreq/interactive/io_is_busy
- echo "85 1401600:80" > /sys/devices/system/cpu/cpufreq/interactive/target_loads
- echo 39000 > /sys/devices/system/cpu/cpufreq/interactive/min_sample_time
- echo 40000 > /sys/devices/system/cpu/cpufreq/interactive/sampling_down_factor
+ #if the kernel version >=4.9,use the schedutil governor
+ KernelVersionStr=`cat /proc/sys/kernel/osrelease`
+ KernelVersionS=${KernelVersionStr:2:2}
+ KernelVersionA=${KernelVersionStr:0:1}
+ KernelVersionB=${KernelVersionS%.*}
+ if [ $KernelVersionA -ge 4 ] && [ $KernelVersionB -ge 9 ]; then
+ 8953_sched_dcvs_eas
+ else
+ 8953_sched_dcvs_hmp
+ fi
echo 652800 > /sys/devices/system/cpu/cpu0/cpufreq/scaling_min_freq
+ # Bring up all cores online
+ echo 1 > /sys/devices/system/cpu/cpu1/online
+ echo 1 > /sys/devices/system/cpu/cpu2/online
+ echo 1 > /sys/devices/system/cpu/cpu3/online
+ echo 1 > /sys/devices/system/cpu/cpu4/online
+ echo 1 > /sys/devices/system/cpu/cpu5/online
+ echo 1 > /sys/devices/system/cpu/cpu6/online
+ echo 1 > /sys/devices/system/cpu/cpu7/online
+
+ # Enable low power modes
+ echo 0 > /sys/module/lpm_levels/parameters/sleep_disabled
+
# re-enable thermal & BCL core_control now
echo 1 > /sys/module/msm_thermal/core_control/enabled
for mode in /sys/devices/soc.0/qcom,bcl.*/mode
@@ -1543,34 +1794,176 @@ case "$target" in
echo -n enable > $mode
done
- # Bring up all cores online
- echo 1 > /sys/devices/system/cpu/cpu1/online
- echo 1 > /sys/devices/system/cpu/cpu2/online
- echo 1 > /sys/devices/system/cpu/cpu3/online
- echo 1 > /sys/devices/system/cpu/cpu4/online
- echo 1 > /sys/devices/system/cpu/cpu5/online
- echo 1 > /sys/devices/system/cpu/cpu6/online
- echo 1 > /sys/devices/system/cpu/cpu7/online
-
- # Enable low power modes
- echo 0 > /sys/module/lpm_levels/parameters/sleep_disabled
-
# SMP scheduler
echo 85 > /proc/sys/kernel/sched_upmigrate
echo 85 > /proc/sys/kernel/sched_downmigrate
- echo 19 > /proc/sys/kernel/sched_upmigrate_min_nice
-
- # Enable sched guided freq control
- echo 1 > /sys/devices/system/cpu/cpufreq/interactive/use_sched_load
- echo 1 > /sys/devices/system/cpu/cpufreq/interactive/use_migration_notif
- echo 200000 > /proc/sys/kernel/sched_freq_inc_notify
- echo 200000 > /proc/sys/kernel/sched_freq_dec_notify
# Set Memory parameters
configure_memory_parameters
- ;;
- esac
- ;;
+ ;;
+ esac
+ case "$soc_id" in
+ "349" | "350")
+
+ # Start Host based Touch processing
+ case "$hw_platform" in
+ "MTP" | "Surf" | "RCM" | "QRD" )
+ start_hbtp
+ ;;
+ esac
+
+ for devfreq_gov in /sys/class/devfreq/qcom,mincpubw*/governor
+ do
+ echo "cpufreq" > $devfreq_gov
+ done
+ for cpubw in /sys/class/devfreq/*qcom,cpubw*
+ do
+ echo "bw_hwmon" > $cpubw/governor
+ echo 50 > $cpubw/polling_interval
+ echo "1611 3221 5859 6445 7104" > $cpubw/bw_hwmon/mbps_zones
+ echo 4 > $cpubw/bw_hwmon/sample_ms
+ echo 34 > $cpubw/bw_hwmon/io_percent
+ echo 20 > $cpubw/bw_hwmon/hist_memory
+ echo 80 > $cpubw/bw_hwmon/down_thres
+ echo 0 > $cpubw/bw_hwmon/hyst_length
+ echo 0 > $cpubw/bw_hwmon/guard_band_mbps
+ echo 250 > $cpubw/bw_hwmon/up_scale
+ echo 1600 > $cpubw/bw_hwmon/idle_mbps
+ done
+
+ # Configure DCC module to capture critical register contents when device crashes
+ for DCC_PATH in /sys/bus/platform/devices/*.dcc*
+ do
+ echo 0 > $DCC_PATH/enable
+ echo cap > $DCC_PATH/func_type
+ echo sram > $DCC_PATH/data_sink
+ echo 1 > $DCC_PATH/config_reset
+
+ # Register specifies APC CPR closed-loop settled voltage for current voltage corner
+ echo 0xb1d2c18 1 > $DCC_PATH/config
+
+ # Register specifies SW programmed open-loop voltage for current voltage corner
+ echo 0xb1d2900 1 > $DCC_PATH/config
+
+ # Register specifies APM switch settings and APM FSM state
+ echo 0xb1112b0 1 > $DCC_PATH/config
+
+ # Register specifies CPR mode change state and also #online cores input to CPR HW
+ echo 0xb018798 1 > $DCC_PATH/config
+
+ echo 1 > $DCC_PATH/enable
+ done
+
+ # disable thermal & BCL core_control to update interactive gov settings
+ echo 0 > /sys/module/msm_thermal/core_control/enabled
+ for mode in /sys/devices/soc.0/qcom,bcl.*/mode
+ do
+ echo -n disable > $mode
+ done
+ for hotplug_mask in /sys/devices/soc.0/qcom,bcl.*/hotplug_mask
+ do
+ bcl_hotplug_mask=`cat $hotplug_mask`
+ echo 0 > $hotplug_mask
+ done
+ for hotplug_soc_mask in /sys/devices/soc.0/qcom,bcl.*/hotplug_soc_mask
+ do
+ bcl_soc_hotplug_mask=`cat $hotplug_soc_mask`
+ echo 0 > $hotplug_soc_mask
+ done
+ for mode in /sys/devices/soc.0/qcom,bcl.*/mode
+ do
+ echo -n enable > $mode
+ done
+
+ # configure governor settings for little cluster
+ echo 1 > /sys/devices/system/cpu/cpu0/online
+ echo "schedutil" > /sys/devices/system/cpu/cpu0/cpufreq/scaling_governor
+ echo 0 > /sys/devices/system/cpu/cpu0/cpufreq/schedutil/rate_limit_us
+ echo 1363200 > /sys/devices/system/cpu/cpu0/cpufreq/schedutil/hispeed_freq
+ #default value for hispeed_load is 90, for sdm632 it should be 85
+ echo 85 > /sys/devices/system/cpu/cpu0/cpufreq/schedutil/hispeed_load
+ # sched_load_boost as -6 is equivalent to target load as 85.
+ echo -6 > /sys/devices/system/cpu/cpu0/sched_load_boost
+ echo -6 > /sys/devices/system/cpu/cpu1/sched_load_boost
+ echo -6 > /sys/devices/system/cpu/cpu2/sched_load_boost
+ echo -6 > /sys/devices/system/cpu/cpu3/sched_load_boost
+
+ # configure governor settings for big cluster
+ echo 1 > /sys/devices/system/cpu/cpu4/online
+ echo "schedutil" > /sys/devices/system/cpu/cpu4/cpufreq/scaling_governor
+ echo 0 > /sys/devices/system/cpu/cpu4/cpufreq/schedutil/rate_limit_us
+ echo 1401600 > /sys/devices/system/cpu/cpu4/cpufreq/schedutil/hispeed_freq
+ #default value for hispeed_load is 90, for sdm632 it should be 85
+ echo 85 > /sys/devices/system/cpu/cpu4/cpufreq/schedutil/hispeed_load
+ # sched_load_boost as -6 is equivalent to target load as 85.
+ echo -6 > /sys/devices/system/cpu/cpu4/sched_load_boost
+ echo -6 > /sys/devices/system/cpu/cpu5/sched_load_boost
+ echo -6 > /sys/devices/system/cpu/cpu7/sched_load_boost
+ echo -6 > /sys/devices/system/cpu/cpu6/sched_load_boost
+
+ echo 614400 > /sys/devices/system/cpu/cpu0/cpufreq/scaling_min_freq
+ echo 633600 > /sys/devices/system/cpu/cpu4/cpufreq/scaling_min_freq
+
+ # cpuset settings
+ echo 0-3 > /dev/cpuset/background/cpus
+ echo 0-3 > /dev/cpuset/system-background/cpus
+ # choose idle CPU for top app tasks
+ echo 1 > /dev/stune/top-app/schedtune.prefer_idle
+
+ # re-enable thermal & BCL core_control now
+ echo 1 > /sys/module/msm_thermal/core_control/enabled
+ for mode in /sys/devices/soc.0/qcom,bcl.*/mode
+ do
+ echo -n disable > $mode
+ done
+ for hotplug_mask in /sys/devices/soc.0/qcom,bcl.*/hotplug_mask
+ do
+ echo $bcl_hotplug_mask > $hotplug_mask
+ done
+ for hotplug_soc_mask in /sys/devices/soc.0/qcom,bcl.*/hotplug_soc_mask
+ do
+ echo $bcl_soc_hotplug_mask > $hotplug_soc_mask
+ done
+ for mode in /sys/devices/soc.0/qcom,bcl.*/mode
+ do
+ echo -n enable > $mode
+ done
+
+ # Disable Core control
+ echo 0 > /sys/devices/system/cpu/cpu0/core_ctl/enable
+ echo 0 > /sys/devices/system/cpu/cpu4/core_ctl/enable
+
+ # Bring up all cores online
+ echo 1 > /sys/devices/system/cpu/cpu1/online
+ echo 1 > /sys/devices/system/cpu/cpu2/online
+ echo 1 > /sys/devices/system/cpu/cpu3/online
+ echo 1 > /sys/devices/system/cpu/cpu4/online
+ echo 1 > /sys/devices/system/cpu/cpu5/online
+ echo 1 > /sys/devices/system/cpu/cpu6/online
+ echo 1 > /sys/devices/system/cpu/cpu7/online
+
+ # Enable low power modes
+ echo 0 > /sys/module/lpm_levels/parameters/sleep_disabled
+
+ # Set Memory parameters
+ configure_memory_parameters
+
+ # Setting b.L scheduler parameters
+ echo 76 > /proc/sys/kernel/sched_downmigrate
+ echo 86 > /proc/sys/kernel/sched_upmigrate
+ echo 80 > /proc/sys/kernel/sched_group_downmigrate
+ echo 90 > /proc/sys/kernel/sched_group_upmigrate
+ echo 1 > /proc/sys/kernel/sched_walt_rotate_big_tasks
+
+ # Enable min frequency adjustment for big cluster
+ if [ -f /sys/module/big_cluster_min_freq_adjust/parameters/min_freq_cluster ]; then
+ echo "4-7" > /sys/module/big_cluster_min_freq_adjust/parameters/min_freq_cluster
+ fi
+ echo 1 > /sys/module/big_cluster_min_freq_adjust/parameters/min_freq_adjust
+
+ ;;
+ esac
+ ;;
esac
case "$target" in
@@ -1610,32 +2003,11 @@ case "$target" in
esac
# Apply Scheduler and Governor settings for 8917 / 8920
- # HMP scheduler settings
- echo 3 > /proc/sys/kernel/sched_window_stats_policy
- echo 3 > /proc/sys/kernel/sched_ravg_hist_size
echo 20000000 > /proc/sys/kernel/sched_ravg_window
- echo 1 > /proc/sys/kernel/sched_restrict_tasks_spread
#disable sched_boost in 8917
echo 0 > /proc/sys/kernel/sched_boost
- # HMP Task packing settings
- echo 20 > /proc/sys/kernel/sched_small_task
- echo 30 > /sys/devices/system/cpu/cpu0/sched_mostly_idle_load
- echo 30 > /sys/devices/system/cpu/cpu1/sched_mostly_idle_load
- echo 30 > /sys/devices/system/cpu/cpu2/sched_mostly_idle_load
- echo 30 > /sys/devices/system/cpu/cpu3/sched_mostly_idle_load
-
- echo 3 > /sys/devices/system/cpu/cpu0/sched_mostly_idle_nr_run
- echo 3 > /sys/devices/system/cpu/cpu1/sched_mostly_idle_nr_run
- echo 3 > /sys/devices/system/cpu/cpu2/sched_mostly_idle_nr_run
- echo 3 > /sys/devices/system/cpu/cpu3/sched_mostly_idle_nr_run
-
- echo 0 > /sys/devices/system/cpu/cpu0/sched_prefer_idle
- echo 0 > /sys/devices/system/cpu/cpu1/sched_prefer_idle
- echo 0 > /sys/devices/system/cpu/cpu2/sched_prefer_idle
- echo 0 > /sys/devices/system/cpu/cpu3/sched_prefer_idle
-
# core_ctl is not needed for 8917. Disable it.
echo 1 > /sys/devices/system/cpu/cpu0/core_ctl/disable
@@ -1665,18 +2037,16 @@ case "$target" in
# disable thermal core_control to update interactive gov settings
echo 0 > /sys/module/msm_thermal/core_control/enabled
- echo 1 > /sys/devices/system/cpu/cpu0/online
- echo "interactive" > /sys/devices/system/cpu/cpu0/cpufreq/scaling_governor
- echo "19000 1094400:39000" > /sys/devices/system/cpu/cpufreq/interactive/above_hispeed_delay
- echo 85 > /sys/devices/system/cpu/cpufreq/interactive/go_hispeed_load
- echo 20000 > /sys/devices/system/cpu/cpufreq/interactive/timer_rate
- echo 1094400 > /sys/devices/system/cpu/cpufreq/interactive/hispeed_freq
- echo 0 > /sys/devices/system/cpu/cpufreq/interactive/io_is_busy
- echo "1 960000:85 1094400:90" > /sys/devices/system/cpu/cpufreq/interactive/target_loads
- echo 40000 > /sys/devices/system/cpu/cpufreq/interactive/min_sample_time
- echo 40000 > /sys/devices/system/cpu/cpufreq/interactive/sampling_down_factor
+ KernelVersionStr=`cat /proc/sys/kernel/osrelease`
+ KernelVersionS=${KernelVersionStr:2:2}
+ KernelVersionA=${KernelVersionStr:0:1}
+ KernelVersionB=${KernelVersionS%.*}
+ if [ $KernelVersionA -ge 4 ] && [ $KernelVersionB -ge 9 ]; then
+ 8917_sched_dcvs_eas
+ else
+ 8917_sched_dcvs_hmp
+ fi
echo 960000 > /sys/devices/system/cpu/cpu0/cpufreq/scaling_min_freq
-
# re-enable thermal core_control now
echo 1 > /sys/module/msm_thermal/core_control/enabled
@@ -1692,12 +2062,6 @@ case "$target" in
# Enable low power modes
echo 0 > /sys/module/lpm_levels/parameters/sleep_disabled
- # Enable sched guided freq control
- echo 1 > /sys/devices/system/cpu/cpufreq/interactive/use_sched_load
- echo 1 > /sys/devices/system/cpu/cpufreq/interactive/use_migration_notif
- echo 50000 > /proc/sys/kernel/sched_freq_inc_notify
- echo 50000 > /proc/sys/kernel/sched_freq_dec_notify
-
# Set rps mask
echo 2 > /sys/class/net/rmnet0/queues/rx-0/rps_cpus
@@ -1732,35 +2096,6 @@ case "$target" in
#disable sched_boost in 8937
echo 0 > /proc/sys/kernel/sched_boost
- # HMP Task packing settings
- echo 20 > /proc/sys/kernel/sched_small_task
- echo 30 > /sys/devices/system/cpu/cpu0/sched_mostly_idle_load
- echo 30 > /sys/devices/system/cpu/cpu1/sched_mostly_idle_load
- echo 30 > /sys/devices/system/cpu/cpu2/sched_mostly_idle_load
- echo 30 > /sys/devices/system/cpu/cpu3/sched_mostly_idle_load
- echo 30 > /sys/devices/system/cpu/cpu4/sched_mostly_idle_load
- echo 30 > /sys/devices/system/cpu/cpu5/sched_mostly_idle_load
- echo 30 > /sys/devices/system/cpu/cpu6/sched_mostly_idle_load
- echo 30 > /sys/devices/system/cpu/cpu7/sched_mostly_idle_load
-
- echo 3 > /sys/devices/system/cpu/cpu0/sched_mostly_idle_nr_run
- echo 3 > /sys/devices/system/cpu/cpu1/sched_mostly_idle_nr_run
- echo 3 > /sys/devices/system/cpu/cpu2/sched_mostly_idle_nr_run
- echo 3 > /sys/devices/system/cpu/cpu3/sched_mostly_idle_nr_run
- echo 3 > /sys/devices/system/cpu/cpu4/sched_mostly_idle_nr_run
- echo 3 > /sys/devices/system/cpu/cpu5/sched_mostly_idle_nr_run
- echo 3 > /sys/devices/system/cpu/cpu6/sched_mostly_idle_nr_run
- echo 3 > /sys/devices/system/cpu/cpu7/sched_mostly_idle_nr_run
-
- echo 0 > /sys/devices/system/cpu/cpu0/sched_prefer_idle
- echo 0 > /sys/devices/system/cpu/cpu1/sched_prefer_idle
- echo 0 > /sys/devices/system/cpu/cpu2/sched_prefer_idle
- echo 0 > /sys/devices/system/cpu/cpu3/sched_prefer_idle
- echo 0 > /sys/devices/system/cpu/cpu4/sched_prefer_idle
- echo 0 > /sys/devices/system/cpu/cpu5/sched_prefer_idle
- echo 0 > /sys/devices/system/cpu/cpu6/sched_prefer_idle
- echo 0 > /sys/devices/system/cpu/cpu7/sched_prefer_idle
-
for devfreq_gov in /sys/class/devfreq/qcom,mincpubw*/governor
do
echo "cpufreq" > $devfreq_gov
@@ -1787,32 +2122,17 @@ case "$target" in
# disable thermal core_control to update interactive gov and core_ctl settings
echo 0 > /sys/module/msm_thermal/core_control/enabled
- # enable governor for perf cluster
- echo 1 > /sys/devices/system/cpu/cpu0/online
- echo "interactive" > /sys/devices/system/cpu/cpu0/cpufreq/scaling_governor
- echo "19000 1094400:39000" > /sys/devices/system/cpu/cpu0/cpufreq/interactive/above_hispeed_delay
- echo 85 > /sys/devices/system/cpu/cpu0/cpufreq/interactive/go_hispeed_load
- echo 20000 > /sys/devices/system/cpu/cpu0/cpufreq/interactive/timer_rate
- echo 1094400 > /sys/devices/system/cpu/cpu0/cpufreq/interactive/hispeed_freq
- echo 0 > /sys/devices/system/cpu/cpu0/cpufreq/interactive/io_is_busy
- echo "1 960000:85 1094400:90 1344000:80" > /sys/devices/system/cpu/cpu0/cpufreq/interactive/target_loads
- echo 40000 > /sys/devices/system/cpu/cpu0/cpufreq/interactive/min_sample_time
- echo 40000 > /sys/devices/system/cpu/cpu0/cpufreq/interactive/sampling_down_factor
+ KernelVersionStr=`cat /proc/sys/kernel/osrelease`
+ KernelVersionS=${KernelVersionStr:2:2}
+ KernelVersionA=${KernelVersionStr:0:1}
+ KernelVersionB=${KernelVersionS%.*}
+ if [ $KernelVersionA -ge 4 ] && [ $KernelVersionB -ge 9 ]; then
+ 8937_sched_dcvs_eas
+ else
+ 8937_sched_dcvs_hmp
+ fi
echo 960000 > /sys/devices/system/cpu/cpu0/cpufreq/scaling_min_freq
-
- # enable governor for power cluster
- echo 1 > /sys/devices/system/cpu/cpu4/online
- echo "interactive" > /sys/devices/system/cpu/cpu4/cpufreq/scaling_governor
- echo 39000 > /sys/devices/system/cpu/cpu4/cpufreq/interactive/above_hispeed_delay
- echo 90 > /sys/devices/system/cpu/cpu4/cpufreq/interactive/go_hispeed_load
- echo 20000 > /sys/devices/system/cpu/cpu4/cpufreq/interactive/timer_rate
- echo 768000 > /sys/devices/system/cpu/cpu4/cpufreq/interactive/hispeed_freq
- echo 0 > /sys/devices/system/cpu/cpu4/cpufreq/interactive/io_is_busy
- echo "1 768000:90" > /sys/devices/system/cpu/cpu4/cpufreq/interactive/target_loads
- echo 40000 > /sys/devices/system/cpu/cpu4/cpufreq/interactive/min_sample_time
- echo 40000 > /sys/devices/system/cpu/cpu4/cpufreq/interactive/sampling_down_factor
echo 768000 > /sys/devices/system/cpu/cpu4/cpufreq/scaling_min_freq
-
# Disable L2-GDHS low power modes
echo N > /sys/module/lpm_levels/system/pwr/pwr-l2-gdhs/idle_enabled
echo N > /sys/module/lpm_levels/system/pwr/pwr-l2-gdhs/suspend_enabled
@@ -1835,14 +2155,6 @@ case "$target" in
echo 93 > /proc/sys/kernel/sched_upmigrate
echo 83 > /proc/sys/kernel/sched_downmigrate
- # Enable sched guided freq control
- echo 1 > /sys/devices/system/cpu/cpu0/cpufreq/interactive/use_sched_load
- echo 1 > /sys/devices/system/cpu/cpu0/cpufreq/interactive/use_migration_notif
- echo 1 > /sys/devices/system/cpu/cpu4/cpufreq/interactive/use_sched_load
- echo 1 > /sys/devices/system/cpu/cpu4/cpufreq/interactive/use_migration_notif
- echo 50000 > /proc/sys/kernel/sched_freq_inc_notify
- echo 50000 > /proc/sys/kernel/sched_freq_dec_notify
-
# Enable core control
echo 2 > /sys/devices/system/cpu/cpu0/core_ctl/min_cpus
echo 4 > /sys/devices/system/cpu/cpu0/core_ctl/max_cpus
@@ -1865,6 +2177,147 @@ case "$target" in
;;
esac
+
+ case "$soc_id" in
+ "354" | "364" | "353" | "363" )
+
+ # Start Host based Touch processing
+ case "$hw_platform" in
+ "MTP" | "Surf" | "RCM" | "QRD" )
+ start_hbtp
+ ;;
+ esac
+
+ # Apply settings for sdm429/sda429/sdm439/sda439
+
+ for cpubw in /sys/class/devfreq/*qcom,mincpubw*
+ do
+ echo "cpufreq" > $cpubw/governor
+ done
+
+ for cpubw in /sys/class/devfreq/*qcom,cpubw*
+ do
+ echo "bw_hwmon" > $cpubw/governor
+ echo 20 > $cpubw/bw_hwmon/io_percent
+ echo 30 > $cpubw/bw_hwmon/guard_band_mbps
+ done
+
+ for gpu_bimc_io_percent in /sys/class/devfreq/soc:qcom,gpubw/bw_hwmon/io_percent
+ do
+ echo 40 > $gpu_bimc_io_percent
+ done
+
+ case "$soc_id" in
+ "353" | "363" )
+ # Apply settings for sdm439/sda439
+ # configure schedutil governor settings
+ # enable governor for perf cluster
+ echo 1 > /sys/devices/system/cpu/cpu0/online
+ echo "schedutil" > /sys/devices/system/cpu/cpu0/cpufreq/scaling_governor
+ echo 0 > /sys/devices/system/cpu/cpu0/cpufreq/schedutil/rate_limit_us
+ #set the hispeed_freq
+ echo 1497600 > /sys/devices/system/cpu/cpu0/cpufreq/schedutil/hispeed_freq
+ echo 80 > /sys/devices/system/cpu/cpu0/cpufreq/schedutil/hispeed_load
+ echo 960000 > /sys/devices/system/cpu/cpu0/cpufreq/scaling_min_freq
+ # sched_load_boost as -6 is equivalent to target load as 85.
+ echo -6 > /sys/devices/system/cpu/cpu0/sched_load_boost
+ echo -6 > /sys/devices/system/cpu/cpu1/sched_load_boost
+ echo -6 > /sys/devices/system/cpu/cpu2/sched_load_boost
+ echo -6 > /sys/devices/system/cpu/cpu3/sched_load_boost
+
+ ## enable governor for power cluster
+ echo 1 > /sys/devices/system/cpu/cpu4/online
+ echo "schedutil" > /sys/devices/system/cpu/cpu4/cpufreq/scaling_governor
+ echo 0 > /sys/devices/system/cpu/cpu4/cpufreq/schedutil/rate_limit_us
+ #set the hispeed_freq
+ echo 998400 > /sys/devices/system/cpu/cpu4/cpufreq/schedutil/hispeed_freq
+ echo 85 > /sys/devices/system/cpu/cpu4/cpufreq/schedutil/hispeed_load
+ echo 768000 > /sys/devices/system/cpu/cpu4/cpufreq/scaling_min_freq
+ # sched_load_boost as -6 is equivalent to target load as 85.
+ echo -6 > /sys/devices/system/cpu/cpu4/sched_load_boost
+ echo -6 > /sys/devices/system/cpu/cpu5/sched_load_boost
+ echo -6 > /sys/devices/system/cpu/cpu6/sched_load_boost
+ echo -6 > /sys/devices/system/cpu/cpu7/sched_load_boost
+
+ # EAS scheduler (big.Little cluster related) settings
+ echo 93 > /proc/sys/kernel/sched_upmigrate
+ echo 83 > /proc/sys/kernel/sched_downmigrate
+ echo 140 > /proc/sys/kernel/sched_group_upmigrate
+ echo 120 > /proc/sys/kernel/sched_group_downmigrate
+
+ # cpuset settings
+ #echo 0-3 > /dev/cpuset/background/cpus
+ #echo 0-3 > /dev/cpuset/system-background/cpus
+
+ # Bring up all cores online
+ echo 1 > /sys/devices/system/cpu/cpu1/online
+ echo 1 > /sys/devices/system/cpu/cpu2/online
+ echo 1 > /sys/devices/system/cpu/cpu3/online
+ echo 1 > /sys/devices/system/cpu/cpu4/online
+ echo 1 > /sys/devices/system/cpu/cpu5/online
+ echo 1 > /sys/devices/system/cpu/cpu6/online
+ echo 1 > /sys/devices/system/cpu/cpu7/online
+
+ # Enable core control
+ echo 2 > /sys/devices/system/cpu/cpu0/core_ctl/min_cpus
+ echo 4 > /sys/devices/system/cpu/cpu0/core_ctl/max_cpus
+ echo 68 > /sys/devices/system/cpu/cpu0/core_ctl/busy_up_thres
+ echo 40 > /sys/devices/system/cpu/cpu0/core_ctl/busy_down_thres
+ echo 100 > /sys/devices/system/cpu/cpu0/core_ctl/offline_delay_ms
+ echo 1 > /sys/devices/system/cpu/cpu0/core_ctl/is_big_cluster
+ echo 4 > /sys/devices/system/cpu/cpu0/core_ctl/task_thres
+
+ # Big cluster min frequency adjust settings
+ if [ -f /sys/module/big_cluster_min_freq_adjust/parameters/min_freq_cluster ]; then
+ echo "0-3" > /sys/module/big_cluster_min_freq_adjust/parameters/min_freq_cluster
+ fi
+ echo 1305600 > /sys/module/big_cluster_min_freq_adjust/parameters/min_freq_floor
+ ;;
+ *)
+ # Apply settings for sdm429/sda429
+ # configure schedutil governor settings
+ echo 1 > /sys/devices/system/cpu/cpu0/online
+ echo "schedutil" > /sys/devices/system/cpu/cpu0/cpufreq/scaling_governor
+ echo 0 > /sys/devices/system/cpu/cpu0/cpufreq/schedutil/rate_limit_us
+ #set the hispeed_freq
+ echo 1305600 > /sys/devices/system/cpu/cpu0/cpufreq/schedutil/hispeed_freq
+ echo 80 > /sys/devices/system/cpu/cpu0/cpufreq/schedutil/hispeed_load
+ echo 960000 > /sys/devices/system/cpu/cpu0/cpufreq/scaling_min_freq
+ # sched_load_boost as -6 is equivalent to target load as 85.
+ echo -6 > /sys/devices/system/cpu/cpu0/sched_load_boost
+ echo -6 > /sys/devices/system/cpu/cpu1/sched_load_boost
+ echo -6 > /sys/devices/system/cpu/cpu2/sched_load_boost
+ echo -6 > /sys/devices/system/cpu/cpu3/sched_load_boost
+
+ # Bring up all cores online
+ echo 1 > /sys/devices/system/cpu/cpu1/online
+ echo 1 > /sys/devices/system/cpu/cpu2/online
+ echo 1 > /sys/devices/system/cpu/cpu3/online
+ ;;
+ esac
+
+ # Set Memory parameters
+ configure_memory_parameters
+
+ #disable sched_boost
+ echo 0 > /proc/sys/kernel/sched_boost
+
+ # Disable L2-GDHS low power modes
+ echo N > /sys/module/lpm_levels/system/pwr/pwr-l2-gdhs/idle_enabled
+ echo N > /sys/module/lpm_levels/system/pwr/pwr-l2-gdhs/suspend_enabled
+ echo N > /sys/module/lpm_levels/system/perf/perf-l2-gdhs/idle_enabled
+ echo N > /sys/module/lpm_levels/system/perf/perf-l2-gdhs/suspend_enabled
+
+ # Enable low power modes
+ echo 0 > /sys/module/lpm_levels/parameters/sleep_disabled
+
+ case "$soc_id" in
+ "353" | "363" )
+ echo 1 > /sys/module/big_cluster_min_freq_adjust/parameters/min_freq_adjust
+ ;;
+ esac
+ ;;
+ esac
;;
esac
@@ -1925,6 +2378,7 @@ case "$target" in
echo 1 > /proc/sys/kernel/sched_restrict_cluster_spill
echo 100000 > /proc/sys/kernel/sched_short_burst_ns
echo 1 > /proc/sys/kernel/sched_prefer_sync_wakee_to_waker
+ echo 20 > /proc/sys/kernel/sched_small_wakee_task_load
# cpuset settings
echo 0-7 > /dev/cpuset/top-app/cpus
@@ -2000,11 +2454,12 @@ case "$target" in
# re-enable thermal and BCL hotplug
echo 1 > /sys/module/msm_thermal/core_control/enabled
- #Add-begin-HMI_L8866_A01-794,lijiang@longcheer.com,2018-01-20
+ #Add-begin-HMI_M6100_A01-422,lijiang@longcheer.com,2018-10-12
#Enable input boost configuration
echo "0:1401600" > /sys/module/cpu_boost/parameters/input_boost_freq
- echo 60 > /sys/module/cpu_boost/parameters/input_boost_ms
- #Add-end-HMI_L8866_A01-794
+ echo 40 > /sys/module/cpu_boost/parameters/input_boost_ms
+ #Add-end-HMI_M6100_A01-422
+
# Set Memory parameters
configure_memory_parameters
@@ -2038,25 +2493,28 @@ case "$target" in
done
echo "cpufreq" > /sys/class/devfreq/soc:qcom,mincpubw/governor
-
- # Start Host based Touch processing
- # case "$hw_platform" in
- # "MTP" | "Surf" | "RCM" | "QRD" )
- # start_hbtp
- # ;;
- # esac
+ # Start cdsprpcd only for sdm660 and disable for sdm630
+ start vendor.cdsprpcd
+##D2SP&F7A has no hbtp feature
+# # Start Host based Touch processing
+# case "$hw_platform" in
+# "MTP" | "Surf" | "RCM" | "QRD" )
+# start_hbtp
+# ;;
+# esac
+#end
;;
esac
- #Apply settings for sdm630
+ #Apply settings for sdm630 and Tahaa
case "$soc_id" in
- "318" | "327" )
+ "318" | "327" | "385" )
# Start Host based Touch processing
- #case "$hw_platform" in
- # "MTP" | "Surf" | "RCM" | "QRD" )
- # start_hbtp
- # ;;
- #esac
+ case "$hw_platform" in
+ "MTP" | "Surf" | "RCM" | "QRD" )
+ start_hbtp
+ ;;
+ esac
# Setting b.L scheduler parameters
echo 85 > /proc/sys/kernel/sched_upmigrate
@@ -2214,6 +2672,388 @@ case "$target" in
esac
case "$target" in
+ "sdm710")
+
+ #Apply settings for sdm710
+ # Set the default IRQ affinity to the silver cluster. When a
+ # CPU is isolated/hotplugged, the IRQ affinity is adjusted
+ # to one of the CPU from the default IRQ affinity mask.
+ echo 3f > /proc/irq/default_smp_affinity
+
+ if [ -f /sys/devices/soc0/soc_id ]; then
+ soc_id=`cat /sys/devices/soc0/soc_id`
+ else
+ soc_id=`cat /sys/devices/system/soc/soc0/id`
+ fi
+
+ if [ -f /sys/devices/soc0/hw_platform ]; then
+ hw_platform=`cat /sys/devices/soc0/hw_platform`
+ else
+ hw_platform=`cat /sys/devices/system/soc/soc0/hw_platform`
+ fi
+
+ case "$soc_id" in
+ "336" | "337" | "347" | "360" )
+
+ # Start Host based Touch processing
+ case "$hw_platform" in
+ "MTP" | "Surf" | "RCM" | "QRD" )
+ start_hbtp
+ ;;
+ esac
+
+ # Core control parameters on silver
+ echo 0 0 0 0 1 1 > /sys/devices/system/cpu/cpu0/core_ctl/not_preferred
+ echo 4 > /sys/devices/system/cpu/cpu0/core_ctl/min_cpus
+ echo 60 > /sys/devices/system/cpu/cpu0/core_ctl/busy_up_thres
+ echo 40 > /sys/devices/system/cpu/cpu0/core_ctl/busy_down_thres
+ echo 100 > /sys/devices/system/cpu/cpu0/core_ctl/offline_delay_ms
+ echo 0 > /sys/devices/system/cpu/cpu0/core_ctl/is_big_cluster
+ echo 8 > /sys/devices/system/cpu/cpu0/core_ctl/task_thres
+
+ # Setting b.L scheduler parameters
+ echo 96 > /proc/sys/kernel/sched_upmigrate
+ echo 90 > /proc/sys/kernel/sched_downmigrate
+ echo 140 > /proc/sys/kernel/sched_group_upmigrate
+ echo 120 > /proc/sys/kernel/sched_group_downmigrate
+ echo 1 > /proc/sys/kernel/sched_walt_rotate_big_tasks
+
+ # configure governor settings for little cluster
+ echo "schedutil" > /sys/devices/system/cpu/cpu0/cpufreq/scaling_governor
+ echo 0 > /sys/devices/system/cpu/cpu0/cpufreq/schedutil/rate_limit_us
+ echo 1209600 > /sys/devices/system/cpu/cpu0/cpufreq/schedutil/hispeed_freq
+ echo 576000 > /sys/devices/system/cpu/cpu0/cpufreq/scaling_min_freq
+
+ # configure governor settings for big cluster
+ echo "schedutil" > /sys/devices/system/cpu/cpu6/cpufreq/scaling_governor
+ echo 0 > /sys/devices/system/cpu/cpu6/cpufreq/schedutil/rate_limit_us
+ echo 1344000 > /sys/devices/system/cpu/cpu6/cpufreq/schedutil/hispeed_freq
+ echo 652800 > /sys/devices/system/cpu/cpu6/cpufreq/scaling_min_freq
+
+ # sched_load_boost as -6 is equivalent to target load as 85. It is per cpu tunable.
+ echo -6 > /sys/devices/system/cpu/cpu6/sched_load_boost
+ echo -6 > /sys/devices/system/cpu/cpu7/sched_load_boost
+ echo 85 > /sys/devices/system/cpu/cpu6/cpufreq/schedutil/hispeed_load
+
+ echo "0:1209600" > /sys/module/cpu_boost/parameters/input_boost_freq
+ echo 40 > /sys/module/cpu_boost/parameters/input_boost_ms
+
+ # Set Memory parameters
+ configure_memory_parameters
+
+ # Enable bus-dcvs
+ for cpubw in /sys/class/devfreq/*qcom,cpubw*
+ do
+ echo "bw_hwmon" > $cpubw/governor
+ echo 50 > $cpubw/polling_interval
+ echo "1144 1720 2086 2929 3879 5931 6881" > $cpubw/bw_hwmon/mbps_zones
+ echo 4 > $cpubw/bw_hwmon/sample_ms
+ echo 68 > $cpubw/bw_hwmon/io_percent
+ echo 20 > $cpubw/bw_hwmon/hist_memory
+ echo 0 > $cpubw/bw_hwmon/hyst_length
+ echo 80 > $cpubw/bw_hwmon/down_thres
+ echo 0 > $cpubw/bw_hwmon/guard_band_mbps
+ echo 250 > $cpubw/bw_hwmon/up_scale
+ echo 1600 > $cpubw/bw_hwmon/idle_mbps
+ done
+
+ #Enable mem_latency governor for DDR scaling
+ for memlat in /sys/class/devfreq/*qcom,memlat-cpu*
+ do
+ echo "mem_latency" > $memlat/governor
+ echo 10 > $memlat/polling_interval
+ echo 400 > $memlat/mem_latency/ratio_ceil
+ done
+
+ #Enable mem_latency governor for L3 scaling
+ for memlat in /sys/class/devfreq/*qcom,l3-cpu*
+ do
+ echo "mem_latency" > $memlat/governor
+ echo 10 > $memlat/polling_interval
+ echo 400 > $memlat/mem_latency/ratio_ceil
+ done
+
+ #Enable userspace governor for L3 cdsp nodes
+ for l3cdsp in /sys/class/devfreq/*qcom,l3-cdsp*
+ do
+ echo "userspace" > $l3cdsp/governor
+ chown -h system $l3cdsp/userspace/set_freq
+ done
+
+ echo "cpufreq" > /sys/class/devfreq/soc:qcom,mincpubw/governor
+
+ # Disable CPU Retention
+ echo N > /sys/module/lpm_levels/L3/cpu0/ret/idle_enabled
+ echo N > /sys/module/lpm_levels/L3/cpu1/ret/idle_enabled
+ echo N > /sys/module/lpm_levels/L3/cpu2/ret/idle_enabled
+ echo N > /sys/module/lpm_levels/L3/cpu3/ret/idle_enabled
+ echo N > /sys/module/lpm_levels/L3/cpu4/ret/idle_enabled
+ echo N > /sys/module/lpm_levels/L3/cpu5/ret/idle_enabled
+ echo N > /sys/module/lpm_levels/L3/cpu6/ret/idle_enabled
+ echo N > /sys/module/lpm_levels/L3/cpu7/ret/idle_enabled
+
+ # cpuset parameters
+ echo 0-5 > /dev/cpuset/background/cpus
+ echo 0-5 > /dev/cpuset/system-background/cpus
+
+ # Turn off scheduler boost at the end
+ echo 0 > /proc/sys/kernel/sched_boost
+
+ # Turn on sleep modes.
+ echo 0 > /sys/module/lpm_levels/parameters/sleep_disabled
+ ;;
+ esac
+ ;;
+esac
+
+case "$target" in
+ "talos")
+
+ #Apply settings for talos
+ # Set the default IRQ affinity to the silver cluster. When a
+ # CPU is isolated/hotplugged, the IRQ affinity is adjusted
+ # to one of the CPU from the default IRQ affinity mask.
+ echo 3f > /proc/irq/default_smp_affinity
+
+ if [ -f /sys/devices/soc0/soc_id ]; then
+ soc_id=`cat /sys/devices/soc0/soc_id`
+ else
+ soc_id=`cat /sys/devices/system/soc/soc0/id`
+ fi
+
+ case "$soc_id" in
+ "355" | "369" )
+
+ # Core control parameters on silver
+ echo 0 0 0 0 1 1 > /sys/devices/system/cpu/cpu0/core_ctl/not_preferred
+ echo 4 > /sys/devices/system/cpu/cpu0/core_ctl/min_cpus
+ echo 60 > /sys/devices/system/cpu/cpu0/core_ctl/busy_up_thres
+ echo 40 > /sys/devices/system/cpu/cpu0/core_ctl/busy_down_thres
+ echo 100 > /sys/devices/system/cpu/cpu0/core_ctl/offline_delay_ms
+ echo 0 > /sys/devices/system/cpu/cpu0/core_ctl/is_big_cluster
+ echo 8 > /sys/devices/system/cpu/cpu0/core_ctl/task_thres
+ echo 0 > /sys/devices/system/cpu/cpu6/core_ctl/enable
+
+
+ # Setting b.L scheduler parameters
+ # default sched up and down migrate values are 90 and 85
+ echo 65 > /proc/sys/kernel/sched_downmigrate
+ echo 71 > /proc/sys/kernel/sched_upmigrate
+ # default sched up and down migrate values are 100 and 95
+ echo 85 > /proc/sys/kernel/sched_group_downmigrate
+ echo 100 > /proc/sys/kernel/sched_group_upmigrate
+ echo 1 > /proc/sys/kernel/sched_walt_rotate_big_tasks
+
+ # configure governor settings for little cluster
+ echo "schedutil" > /sys/devices/system/cpu/cpu0/cpufreq/scaling_governor
+ echo 0 > /sys/devices/system/cpu/cpu0/cpufreq/schedutil/rate_limit_us
+ echo 1209600 > /sys/devices/system/cpu/cpu0/cpufreq/schedutil/hispeed_freq
+ echo 576000 > /sys/devices/system/cpu/cpu0/cpufreq/scaling_min_freq
+
+ # configure governor settings for big cluster
+ echo "schedutil" > /sys/devices/system/cpu/cpu6/cpufreq/scaling_governor
+ echo 0 > /sys/devices/system/cpu/cpu6/cpufreq/schedutil/rate_limit_us
+ echo 1209600 > /sys/devices/system/cpu/cpu6/cpufreq/schedutil/hispeed_freq
+ echo 768000 > /sys/devices/system/cpu/cpu6/cpufreq/scaling_min_freq
+
+ # sched_load_boost as -6 is equivalent to target load as 85. It is per cpu tunable.
+ echo -6 > /sys/devices/system/cpu/cpu6/sched_load_boost
+ echo -6 > /sys/devices/system/cpu/cpu7/sched_load_boost
+ echo 85 > /sys/devices/system/cpu/cpu6/cpufreq/schedutil/hispeed_load
+
+ echo "0:1209600" > /sys/module/cpu_boost/parameters/input_boost_freq
+ echo 40 > /sys/module/cpu_boost/parameters/input_boost_ms
+
+ # Set Memory parameters
+ configure_memory_parameters
+
+ # Enable bus-dcvs
+ for device in /sys/devices/platform/soc
+ do
+ for cpubw in $device/*cpu-cpu-llcc-bw/devfreq/*cpu-cpu-llcc-bw
+ do
+ echo "bw_hwmon" > $cpubw/governor
+ echo 50 > $cpubw/polling_interval
+ echo "2288 4577 7110 9155 12298 14236" > $cpubw/bw_hwmon/mbps_zones
+ echo 4 > $cpubw/bw_hwmon/sample_ms
+ echo 68 > $cpubw/bw_hwmon/io_percent
+ echo 20 > $cpubw/bw_hwmon/hist_memory
+ echo 0 > $cpubw/bw_hwmon/hyst_length
+ echo 80 > $cpubw/bw_hwmon/down_thres
+ echo 0 > $cpubw/bw_hwmon/guard_band_mbps
+ echo 250 > $cpubw/bw_hwmon/up_scale
+ echo 1600 > $cpubw/bw_hwmon/idle_mbps
+ done
+
+ for llccbw in $device/*cpu-llcc-ddr-bw/devfreq/*cpu-llcc-ddr-bw
+ do
+ echo "bw_hwmon" > $llccbw/governor
+ echo 40 > $llccbw/polling_interval
+ echo "1144 1720 2086 2929 3879 5931 6881" > $llccbw/bw_hwmon/mbps_zones
+ echo 4 > $llccbw/bw_hwmon/sample_ms
+ echo 68 > $llccbw/bw_hwmon/io_percent
+ echo 20 > $llccbw/bw_hwmon/hist_memory
+ echo 0 > $llccbw/bw_hwmon/hyst_length
+ echo 80 > $llccbw/bw_hwmon/down_thres
+ echo 0 > $llccbw/bw_hwmon/guard_band_mbps
+ echo 250 > $llccbw/bw_hwmon/up_scale
+ echo 1600 > $llccbw/bw_hwmon/idle_mbps
+ done
+
+ #Enable mem_latency governor for L3, LLCC, and DDR scaling
+ for memlat in $device/*cpu*-lat/devfreq/*cpu*-lat
+ do
+ echo "mem_latency" > $memlat/governor
+ echo 10 > $memlat/polling_interval
+ echo 400 > $memlat/mem_latency/ratio_ceil
+ done
+
+ #Enable compute governor for gold latfloor
+ for latfloor in $device/*cpu*-ddr-latfloor*/devfreq/*cpu-ddr-latfloor*
+ do
+ echo "compute" > $latfloor/governor
+ echo 10 > $latfloor/polling_interval
+ done
+
+ done
+
+
+ # cpuset parameters
+ echo 0-5 > /dev/cpuset/background/cpus
+ echo 0-5 > /dev/cpuset/system-background/cpus
+
+ # Turn off scheduler boost at the end
+ echo 0 > /proc/sys/kernel/sched_boost
+
+ # Turn on sleep modes.
+ echo 0 > /sys/module/lpm_levels/parameters/sleep_disabled
+ ;;
+ esac
+ ;;
+esac
+
+case "$target" in
+ "qcs605")
+
+ #Apply settings for qcs605
+ # Set the default IRQ affinity to the silver cluster. When a
+ # CPU is isolated/hotplugged, the IRQ affinity is adjusted
+ # to one of the CPU from the default IRQ affinity mask.
+ echo 3f > /proc/irq/default_smp_affinity
+
+ if [ -f /sys/devices/soc0/soc_id ]; then
+ soc_id=`cat /sys/devices/soc0/soc_id`
+ else
+ soc_id=`cat /sys/devices/system/soc/soc0/id`
+ fi
+
+ if [ -f /sys/devices/soc0/hw_platform ]; then
+ hw_platform=`cat /sys/devices/soc0/hw_platform`
+ else
+ hw_platform=`cat /sys/devices/system/soc/soc0/hw_platform`
+ fi
+
+ if [ -f /sys/devices/soc0/platform_subtype_id ]; then
+ platform_subtype_id=`cat /sys/devices/soc0/platform_subtype_id`
+ fi
+
+ case "$soc_id" in
+ "347" )
+
+ # Start Host based Touch processing
+ case "$hw_platform" in
+ "Surf" | "RCM" | "QRD" )
+ start_hbtp
+ ;;
+ "MTP" )
+ if [ $platform_subtype_id != 5 ]; then
+ start_hbtp
+ fi
+ ;;
+ esac
+
+ # Core control parameters on silver
+ echo 4 > /sys/devices/system/cpu/cpu0/core_ctl/min_cpus
+ echo 60 > /sys/devices/system/cpu/cpu0/core_ctl/busy_up_thres
+ echo 40 > /sys/devices/system/cpu/cpu0/core_ctl/busy_down_thres
+ echo 100 > /sys/devices/system/cpu/cpu0/core_ctl/offline_delay_ms
+ echo 0 > /sys/devices/system/cpu/cpu0/core_ctl/is_big_cluster
+ echo 8 > /sys/devices/system/cpu/cpu0/core_ctl/task_thres
+
+ # Setting b.L scheduler parameters
+ echo 96 > /proc/sys/kernel/sched_upmigrate
+ echo 90 > /proc/sys/kernel/sched_downmigrate
+ echo 140 > /proc/sys/kernel/sched_group_upmigrate
+ echo 120 > /proc/sys/kernel/sched_group_downmigrate
+
+ # configure governor settings for little cluster
+ echo "schedutil" > /sys/devices/system/cpu/cpu0/cpufreq/scaling_governor
+ echo 0 > /sys/devices/system/cpu/cpu0/cpufreq/schedutil/rate_limit_us
+ echo 1209600 > /sys/devices/system/cpu/cpu0/cpufreq/schedutil/hispeed_freq
+ echo 576000 > /sys/devices/system/cpu/cpu0/cpufreq/scaling_min_freq
+
+ # configure governor settings for big cluster
+ echo "schedutil" > /sys/devices/system/cpu/cpu6/cpufreq/scaling_governor
+ echo 0 > /sys/devices/system/cpu/cpu6/cpufreq/schedutil/rate_limit_us
+ echo 1344000 > /sys/devices/system/cpu/cpu6/cpufreq/schedutil/hispeed_freq
+ echo 825600 > /sys/devices/system/cpu/cpu6/cpufreq/scaling_min_freq
+
+ echo "0:1209600" > /sys/module/cpu_boost/parameters/input_boost_freq
+ echo 40 > /sys/module/cpu_boost/parameters/input_boost_ms
+
+ # Enable bus-dcvs
+ for cpubw in /sys/class/devfreq/*qcom,cpubw*
+ do
+ echo "bw_hwmon" > $cpubw/governor
+ echo 50 > $cpubw/polling_interval
+ echo "1144 1720 2086 2929 3879 5931 6881" > $cpubw/bw_hwmon/mbps_zones
+ echo 4 > $cpubw/bw_hwmon/sample_ms
+ echo 68 > $cpubw/bw_hwmon/io_percent
+ echo 20 > $cpubw/bw_hwmon/hist_memory
+ echo 0 > $cpubw/bw_hwmon/hyst_length
+ echo 80 > $cpubw/bw_hwmon/down_thres
+ echo 0 > $cpubw/bw_hwmon/low_power_ceil_mbps
+ echo 68 > $cpubw/bw_hwmon/low_power_io_percent
+ echo 20 > $cpubw/bw_hwmon/low_power_delay
+ echo 0 > $cpubw/bw_hwmon/guard_band_mbps
+ echo 250 > $cpubw/bw_hwmon/up_scale
+ echo 1600 > $cpubw/bw_hwmon/idle_mbps
+ done
+
+ #Enable mem_latency governor for DDR scaling
+ for memlat in /sys/class/devfreq/*qcom,memlat-cpu*
+ do
+ echo "mem_latency" > $memlat/governor
+ echo 10 > $memlat/polling_interval
+ echo 400 > $memlat/mem_latency/ratio_ceil
+ done
+
+ #Enable mem_latency governor for L3 scaling
+ for memlat in /sys/class/devfreq/*qcom,l3-cpu*
+ do
+ echo "mem_latency" > $memlat/governor
+ echo 10 > $memlat/polling_interval
+ echo 400 > $memlat/mem_latency/ratio_ceil
+ done
+
+ echo "cpufreq" > /sys/class/devfreq/soc:qcom,mincpubw/governor
+
+ # cpuset parameters
+ echo 0-5 > /dev/cpuset/background/cpus
+ echo 0-5 > /dev/cpuset/system-background/cpus
+
+ # Turn off scheduler boost at the end
+ echo 0 > /proc/sys/kernel/sched_boost
+
+ # Turn on sleep modes.
+ echo 0 > /sys/module/lpm_levels/parameters/sleep_disabled
+ echo 100 > /proc/sys/vm/swappiness
+ ;;
+ esac
+ ;;
+esac
+
+case "$target" in
"apq8084")
echo 4 > /sys/module/lpm_levels/enable_low_power/l2
echo 1 > /sys/module/msm_pm/modes/cpu0/power_collapse/suspend_enabled
@@ -2264,7 +3104,7 @@ case "$target" in
echo 300000 > /sys/devices/system/cpu/cpu2/cpufreq/scaling_min_freq
echo 300000 > /sys/devices/system/cpu/cpu3/cpufreq/scaling_min_freq
echo 1 > /sys/module/msm_thermal/core_control/enabled
- setprop ro.qualcomm.perf.cores_online 2
+ setprop ro.vendor.perf.cores_online 2
chown -h system /sys/devices/system/cpu/cpu0/cpufreq/scaling_max_freq
chown -h system /sys/devices/system/cpu/cpu0/cpufreq/scaling_min_freq
chown -h root.system /sys/devices/system/cpu/mfreq
@@ -2620,17 +3460,39 @@ case "$target" in
# to one of the CPU from the default IRQ affinity mask.
echo f > /proc/irq/default_smp_affinity
- if [ -f /sys/devices/soc0/soc_id ]; then
+ if [ -f /sys/devices/soc0/soc_id ]; then
soc_id=`cat /sys/devices/soc0/soc_id`
else
soc_id=`cat /sys/devices/system/soc/soc0/id`
fi
- case "$soc_id" in
- "321") #sdm845
- start_hbtp
- ;;
- esac
+ if [ -f /sys/devices/soc0/hw_platform ]; then
+ hw_platform=`cat /sys/devices/soc0/hw_platform`
+ fi
+
+ if [ -f /sys/devices/soc0/platform_subtype_id ]; then
+ platform_subtype_id=`cat /sys/devices/soc0/platform_subtype_id`
+ fi
+
+ case "$soc_id" in
+ "321" | "341")
+ # Start Host based Touch processing
+ case "$hw_platform" in
+ "QRD" )
+ case "$platform_subtype_id" in
+ "32") #QVR845 do nothing
+ ;;
+ *)
+ start_hbtp
+ ;;
+ esac
+ ;;
+ *)
+ start_hbtp
+ ;;
+ esac
+ ;;
+ esac
# Core control parameters
echo 2 > /sys/devices/system/cpu/cpu4/core_ctl/min_cpus
echo 60 > /sys/devices/system/cpu/cpu4/core_ctl/busy_up_thres
@@ -2644,23 +3506,27 @@ case "$target" in
echo 85 > /proc/sys/kernel/sched_downmigrate
echo 100 > /proc/sys/kernel/sched_group_upmigrate
echo 95 > /proc/sys/kernel/sched_group_downmigrate
- echo 0 > /proc/sys/kernel/sched_select_prev_cpu_us
- echo 400000 > /proc/sys/kernel/sched_freq_inc_notify
- echo 400000 > /proc/sys/kernel/sched_freq_dec_notify
- echo 5 > /proc/sys/kernel/sched_spill_nr_run
- echo 1 > /proc/sys/kernel/sched_restrict_cluster_spill
+ echo 1 > /proc/sys/kernel/sched_walt_rotate_big_tasks
# configure governor settings for little cluster
echo "schedutil" > /sys/devices/system/cpu/cpu0/cpufreq/scaling_governor
echo 0 > /sys/devices/system/cpu/cpu0/cpufreq/schedutil/rate_limit_us
echo 1209600 > /sys/devices/system/cpu/cpu0/cpufreq/schedutil/hispeed_freq
+ echo 1 > /sys/devices/system/cpu/cpu0/cpufreq/schedutil/pl
+ echo 576000 > /sys/devices/system/cpu/cpu0/cpufreq/scaling_min_freq
# configure governor settings for big cluster
echo "schedutil" > /sys/devices/system/cpu/cpu4/cpufreq/scaling_governor
echo 0 > /sys/devices/system/cpu/cpu4/cpufreq/schedutil/rate_limit_us
echo 1574400 > /sys/devices/system/cpu/cpu4/cpufreq/schedutil/hispeed_freq
+ echo 1 > /sys/devices/system/cpu/cpu4/cpufreq/schedutil/pl
echo "0:1324800" > /sys/module/cpu_boost/parameters/input_boost_freq
echo 120 > /sys/module/cpu_boost/parameters/input_boost_ms
+ # Limit the min frequency to 825MHz
+ echo 825000 > /sys/devices/system/cpu/cpu4/cpufreq/scaling_min_freq
+
+ # Enable oom_reaper
+ echo 1 > /sys/module/lowmemorykiller/parameters/oom_reaper
# Enable bus-dcvs
for cpubw in /sys/class/devfreq/*qcom,cpubw*
@@ -2669,12 +3535,9 @@ case "$target" in
echo 50 > $cpubw/polling_interval
echo "2288 4577 6500 8132 9155 10681" > $cpubw/bw_hwmon/mbps_zones
echo 4 > $cpubw/bw_hwmon/sample_ms
- echo 34 > $cpubw/bw_hwmon/io_percent
+ echo 50 > $cpubw/bw_hwmon/io_percent
echo 20 > $cpubw/bw_hwmon/hist_memory
echo 10 > $cpubw/bw_hwmon/hyst_length
- echo 0 > $cpubw/bw_hwmon/low_power_ceil_mbps
- echo 34 > $cpubw/bw_hwmon/low_power_io_percent
- echo 20 > $cpubw/bw_hwmon/low_power_delay
echo 0 > $cpubw/bw_hwmon/guard_band_mbps
echo 250 > $cpubw/bw_hwmon/up_scale
echo 1600 > $cpubw/bw_hwmon/idle_mbps
@@ -2684,14 +3547,11 @@ case "$target" in
do
echo "bw_hwmon" > $llccbw/governor
echo 50 > $llccbw/polling_interval
- echo "1720 2929 4943 5931 6881" > $llccbw/bw_hwmon/mbps_zones
+ echo "1720 2929 3879 5931 6881" > $llccbw/bw_hwmon/mbps_zones
echo 4 > $llccbw/bw_hwmon/sample_ms
- echo 68 > $llccbw/bw_hwmon/io_percent
+ echo 80 > $llccbw/bw_hwmon/io_percent
echo 20 > $llccbw/bw_hwmon/hist_memory
echo 10 > $llccbw/bw_hwmon/hyst_length
- echo 0 > $llccbw/bw_hwmon/low_power_ceil_mbps
- echo 68 > $llccbw/bw_hwmon/low_power_io_percent
- echo 20 > $llccbw/bw_hwmon/low_power_delay
echo 0 > $llccbw/bw_hwmon/guard_band_mbps
echo 250 > $llccbw/bw_hwmon/up_scale
echo 1600 > $llccbw/bw_hwmon/idle_mbps
@@ -2713,10 +3573,18 @@ case "$target" in
echo 400 > $memlat/mem_latency/ratio_ceil
done
+ #Enable userspace governor for L3 cdsp nodes
+ for l3cdsp in /sys/class/devfreq/*qcom,l3-cdsp*
+ do
+ echo "userspace" > $l3cdsp/governor
+ chown -h system $l3cdsp/userspace/set_freq
+ done
+
#Gold L3 ratio ceil
echo 4000 > /sys/class/devfreq/soc:qcom,l3-cpu4/mem_latency/ratio_ceil
- echo "cpufreq" > /sys/class/devfreq/soc:qcom,mincpubw/governor
+ echo "compute" > /sys/class/devfreq/soc:qcom,mincpubw/governor
+ echo 10 > /sys/class/devfreq/soc:qcom,mincpubw/polling_interval
# cpuset parameters
echo 0-3 > /dev/cpuset/background/cpus
@@ -2733,9 +3601,192 @@ case "$target" in
echo N > /sys/module/lpm_levels/L3/cpu5/ret/idle_enabled
echo N > /sys/module/lpm_levels/L3/cpu6/ret/idle_enabled
echo N > /sys/module/lpm_levels/L3/cpu7/ret/idle_enabled
+ echo N > /sys/module/lpm_levels/L3/l3-dyn-ret/idle_enabled
# Turn on sleep modes.
echo 0 > /sys/module/lpm_levels/parameters/sleep_disabled
echo 100 > /proc/sys/vm/swappiness
+ echo 120 > /proc/sys/vm/watermark_scale_factor
+ ;;
+esac
+
+case "$target" in
+ "msmnile")
+ # Core control parameters for gold
+ echo 2 > /sys/devices/system/cpu/cpu4/core_ctl/min_cpus
+ echo 60 > /sys/devices/system/cpu/cpu4/core_ctl/busy_up_thres
+ echo 30 > /sys/devices/system/cpu/cpu4/core_ctl/busy_down_thres
+ echo 100 > /sys/devices/system/cpu/cpu4/core_ctl/offline_delay_ms
+ echo 3 > /sys/devices/system/cpu/cpu4/core_ctl/task_thres
+
+ # Core control parameters for gold+
+ echo 0 > /sys/devices/system/cpu/cpu7/core_ctl/min_cpus
+ echo 60 > /sys/devices/system/cpu/cpu7/core_ctl/busy_up_thres
+ echo 30 > /sys/devices/system/cpu/cpu7/core_ctl/busy_down_thres
+ echo 100 > /sys/devices/system/cpu/cpu7/core_ctl/offline_delay_ms
+ echo 1 > /sys/devices/system/cpu/cpu7/core_ctl/task_thres
+ # Controls how many more tasks should be eligible to run on gold CPUs
+ # w.r.t number of gold CPUs available to trigger assist (max number of
+ # tasks eligible to run on previous cluster minus number of CPUs in
+ # the previous cluster).
+ #
+ # Setting to 3 by default which means there should be at least
+ # 6 tasks eligible to run on gold cluster (tasks running on gold cores
+ # plus misfit tasks on silver cores) to trigger assitance from gold+.
+ echo 3 > /sys/devices/system/cpu/cpu7/core_ctl/nr_prev_assist_thresh
+
+ # Disable Core control on silver
+ echo 0 > /sys/devices/system/cpu/cpu0/core_ctl/enable
+
+ # Setting b.L scheduler parameters
+ echo 95 95 > /proc/sys/kernel/sched_upmigrate
+ echo 85 85 > /proc/sys/kernel/sched_downmigrate
+ echo 100 > /proc/sys/kernel/sched_group_upmigrate
+ echo 95 > /proc/sys/kernel/sched_group_downmigrate
+ echo 1 > /proc/sys/kernel/sched_walt_rotate_big_tasks
+
+ # cpuset parameters
+ echo 0-3 > /dev/cpuset/background/cpus
+ echo 0-3 > /dev/cpuset/system-background/cpus
+
+ # Turn off scheduler boost at the end
+ echo 0 > /proc/sys/kernel/sched_boost
+
+ # configure governor settings for silver cluster
+ echo "schedutil" > /sys/devices/system/cpu/cpufreq/policy0/scaling_governor
+ echo 0 > /sys/devices/system/cpu/cpufreq/policy0/schedutil/rate_limit_us
+ echo 1075200 > /sys/devices/system/cpu/cpufreq/policy0/schedutil/hispeed_freq
+ echo 576000 > /sys/devices/system/cpu/cpufreq/policy0/scaling_min_freq
+ echo 1 > /sys/devices/system/cpu/cpufreq/policy0/schedutil/pl
+
+ # configure governor settings for gold cluster
+ echo "schedutil" > /sys/devices/system/cpu/cpufreq/policy4/scaling_governor
+ echo 0 > /sys/devices/system/cpu/cpufreq/policy4/schedutil/rate_limit_us
+ echo 1248000 > /sys/devices/system/cpu/cpufreq/policy4/schedutil/hispeed_freq
+ echo 1 > /sys/devices/system/cpu/cpufreq/policy4/schedutil/pl
+
+ # configure governor settings for gold+ cluster
+ echo "schedutil" > /sys/devices/system/cpu/cpufreq/policy7/scaling_governor
+ echo 0 > /sys/devices/system/cpu/cpufreq/policy7/schedutil/rate_limit_us
+ echo 1286400 > /sys/devices/system/cpu/cpufreq/policy7/schedutil/hispeed_freq
+ echo 1 > /sys/devices/system/cpu/cpufreq/policy7/schedutil/pl
+
+ # configure input boost settings
+ echo "0:1324800" > /sys/module/cpu_boost/parameters/input_boost_freq
+ echo 120 > /sys/module/cpu_boost/parameters/input_boost_ms
+
+ echo 120 > /proc/sys/vm/watermark_scale_factor
+
+ echo 0-3 > /dev/cpuset/background/cpus
+ echo 0-3 > /dev/cpuset/system-background/cpus
+
+ # Enable oom_reaper
+ if [ -f /sys/module/lowmemorykiller/parameters/oom_reaper ]; then
+ echo 1 > /sys/module/lowmemorykiller/parameters/oom_reaper
+ else
+ echo 1 > /proc/sys/vm/reap_mem_on_sigkill
+ fi
+
+ # Enable bus-dcvs
+ for device in /sys/devices/platform/soc
+ do
+ for cpubw in $device/*cpu-cpu-llcc-bw/devfreq/*cpu-cpu-llcc-bw
+ do
+ echo "bw_hwmon" > $cpubw/governor
+ echo 40 > $cpubw/polling_interval
+ echo "2288 3051 6149 8132 10162 11856" > $cpubw/bw_hwmon/mbps_zones
+ echo 4 > $cpubw/bw_hwmon/sample_ms
+ echo 50 > $cpubw/bw_hwmon/io_percent
+ echo 20 > $cpubw/bw_hwmon/hist_memory
+ echo 10 > $cpubw/bw_hwmon/hyst_length
+ echo 30 > $cpubw/bw_hwmon/down_thres
+ echo 0 > $cpubw/bw_hwmon/guard_band_mbps
+ echo 250 > $cpubw/bw_hwmon/up_scale
+ echo 1600 > $cpubw/bw_hwmon/idle_mbps
+ done
+
+ for llccbw in $device/*cpu-llcc-ddr-bw/devfreq/*cpu-llcc-ddr-bw
+ do
+ echo "bw_hwmon" > $llccbw/governor
+ echo 40 > $llccbw/polling_interval
+ echo "1720 2929 4943 5931 6881 7980" > $llccbw/bw_hwmon/mbps_zones
+ echo 4 > $llccbw/bw_hwmon/sample_ms
+ echo 80 > $llccbw/bw_hwmon/io_percent
+ echo 20 > $llccbw/bw_hwmon/hist_memory
+ echo 10 > $llccbw/bw_hwmon/hyst_length
+ echo 30 > $llccbw/bw_hwmon/down_thres
+ echo 0 > $llccbw/bw_hwmon/guard_band_mbps
+ echo 250 > $llccbw/bw_hwmon/up_scale
+ echo 1600 > $llccbw/bw_hwmon/idle_mbps
+ done
+
+ for npubw in $device/*npu-npu-ddr-bw/devfreq/*npu-npu-ddr-bw
+ do
+ echo 1 > /sys/devices/virtual/npu/msm_npu/pwr
+ echo "bw_hwmon" > $npubw/governor
+ echo 40 > $npubw/polling_interval
+ echo "1720 2929 4943 5931 6881 7980" > $npubw/bw_hwmon/mbps_zones
+ echo 4 > $npubw/bw_hwmon/sample_ms
+ echo 80 > $npubw/bw_hwmon/io_percent
+ echo 20 > $npubw/bw_hwmon/hist_memory
+ echo 10 > $npubw/bw_hwmon/hyst_length
+ echo 30 > $npubw/bw_hwmon/down_thres
+ echo 0 > $npubw/bw_hwmon/guard_band_mbps
+ echo 250 > $npubw/bw_hwmon/up_scale
+ echo 1600 > $npubw/bw_hwmon/idle_mbps
+ echo 0 > /sys/devices/virtual/npu/msm_npu/pwr
+ done
+
+ #Enable mem_latency governor for L3, LLCC, and DDR scaling
+ for memlat in $device/*cpu*-lat/devfreq/*cpu*-lat
+ do
+ echo "mem_latency" > $memlat/governor
+ echo 10 > $memlat/polling_interval
+ echo 400 > $memlat/mem_latency/ratio_ceil
+ done
+
+ #Enable userspace governor for L3 cdsp nodes
+ for l3cdsp in $device/*cdsp-cdsp-l3-lat/devfreq/*cdsp-cdsp-l3-lat
+ do
+ echo "cdspl3" > $l3cdsp/governor
+ done
+
+ #Enable compute governor for gold latfloor
+ for latfloor in $device/*cpu-ddr-latfloor*/devfreq/*cpu-ddr-latfloor*
+ do
+ echo "compute" > $latfloor/governor
+ echo 10 > $latfloor/polling_interval
+ done
+
+ #Gold L3 ratio ceil
+ for l3gold in $device/*cpu4-cpu-l3-lat/devfreq/*cpu4-cpu-l3-lat
+ do
+ echo 4000 > $l3gold/mem_latency/ratio_ceil
+ done
+ done
+
+ if [ -f /sys/devices/soc0/hw_platform ]; then
+ hw_platform=`cat /sys/devices/soc0/hw_platform`
+ else
+ hw_platform=`cat /sys/devices/system/soc/soc0/hw_platform`
+ fi
+
+ if [ -f /sys/devices/soc0/platform_subtype_id ]; then
+ platform_subtype_id=`cat /sys/devices/soc0/platform_subtype_id`
+ fi
+
+ case "$hw_platform" in
+ "MTP" | "Surf" | "RCM" )
+ # Start Host based Touch processing
+ case "$platform_subtype_id" in
+ "0" | "1")
+ start_hbtp
+ ;;
+ esac
+ ;;
+ esac
+
+ echo 0 > /sys/module/lpm_levels/parameters/sleep_disabled
+ configure_memory_parameters
;;
esac
@@ -2890,6 +3941,9 @@ case "$target" in
echo 0-3 > /dev/cpuset/background/cpus
echo 0-3 > /dev/cpuset/system-background/cpus
echo 0 > /proc/sys/kernel/sched_boost
+
+ # Set Memory parameters
+ configure_memory_parameters
;;
esac
@@ -2949,15 +4003,6 @@ case "$target" in
echo 1 > /sys/devices/system/cpu/cpu3/online
echo 0 > /sys/module/lpm_levels/parameters/sleep_disabled
- # Tune core control
- echo 2 > /sys/devices/system/cpu/cpu0/core_ctl/min_cpus
- max_freq=`cat /sys/devices/system/cpu/cpu0/cpufreq/cpuinfo_max_freq`
- min_freq=800000
- echo $((min_freq*100 / max_freq)) $((min_freq*100 / max_freq)) $((66*1000000 / max_freq)) \
- $((55*1000000 / max_freq)) > /sys/devices/system/cpu/cpu0/core_ctl/busy_up_thres
- echo $((33*1000000 / max_freq)) > /sys/devices/system/cpu/cpu0/core_ctl/busy_down_thres
- echo 100 > /sys/devices/system/cpu/cpu0/core_ctl/offline_delay_ms
-
for devfreq_gov in /sys/class/devfreq/*qcom,cpubw*/governor
do
echo "bw_hwmon" > $devfreq_gov
@@ -2986,6 +4031,7 @@ case "$target" in
# Set Memory parameters
configure_memory_parameters
+ restorecon -R /sys/devices/system/cpu
;;
esac
@@ -3011,7 +4057,7 @@ chown -h system /sys/devices/system/cpu/cpufreq/ondemand/sampling_rate
chown -h system /sys/devices/system/cpu/cpufreq/ondemand/sampling_down_factor
chown -h system /sys/devices/system/cpu/cpufreq/ondemand/io_is_busy
-emmc_boot=`getprop ro.boot.emmc`
+emmc_boot=`getprop vendor.boot.emmc`
case "$emmc_boot"
in "true")
chown -h system /sys/devices/platform/rs300000a7.65536/force_sync
@@ -3036,7 +4082,7 @@ case "$target" in
start mpdecision
;;
"msm8916")
- setprop sys.post_boot.parsed 1
+ setprop vendor.post_boot.parsed 1
if [ -f /sys/devices/soc0/soc_id ]; then
soc_id=`cat /sys/devices/soc0/soc_id`
@@ -3045,38 +4091,22 @@ case "$target" in
fi
case $soc_id in
"239" | "241" | "263" | "268" | "269" | "270" | "271")
- setprop ro.min_freq_0 960000
- setprop ro.min_freq_4 800000
+ setprop vendor.min_freq_0 960000
+ setprop vendor.min_freq_4 800000
;;
"206" | "247" | "248" | "249" | "250" | "233" | "240" | "242")
- setprop ro.min_freq_0 800000
+ setprop vendor.min_freq_0 800000
;;
esac
;;
"msm8909")
- echo 128 > /sys/block/mmcblk0/bdi/read_ahead_kb
- echo 128 > /sys/block/mmcblk0/queue/read_ahead_kb
- echo 128 > /sys/block/mmcblk0rpmb/bdi/read_ahead_kb
- echo 128 > /sys/block/mmcblk0rpmb/queue/read_ahead_kb
- setprop sys.post_boot.parsed 1
+ setprop vendor.post_boot.parsed 1
;;
"msm8952")
- echo 128 > /sys/block/mmcblk0/bdi/read_ahead_kb
- echo 128 > /sys/block/mmcblk0/queue/read_ahead_kb
- echo 128 > /sys/block/dm-0/queue/read_ahead_kb
- echo 128 > /sys/block/dm-1/queue/read_ahead_kb
- echo 128 > /sys/block/mmcblk0rpmb/bdi/read_ahead_kb
- echo 128 > /sys/block/mmcblk0rpmb/queue/read_ahead_kb
- setprop sys.post_boot.parsed 1
+ setprop vendor.post_boot.parsed 1
;;
"msm8937" | "msm8953")
- echo 128 > /sys/block/mmcblk0/bdi/read_ahead_kb
- echo 128 > /sys/block/mmcblk0/queue/read_ahead_kb
- echo 128 > /sys/block/dm-0/queue/read_ahead_kb
- echo 128 > /sys/block/dm-1/queue/read_ahead_kb
- echo 128 > /sys/block/mmcblk0rpmb/bdi/read_ahead_kb
- echo 128 > /sys/block/mmcblk0rpmb/queue/read_ahead_kb
- setprop sys.post_boot.parsed 1
+ setprop vendor.post_boot.parsed 1
low_ram_enable=`getprop ro.config.low_ram`
@@ -3088,8 +4118,8 @@ case "$target" in
start mpdecision
echo 512 > /sys/block/mmcblk0/bdi/read_ahead_kb
;;
- "msm8994" | "msm8992" | "msm8996" | "msm8998" | "sdm660" | "apq8098_latv" | "sdm845")
- setprop sys.post_boot.parsed 1
+ "msm8994" | "msm8992" | "msm8996" | "msm8998" | "sdm660" | "apq8098_latv" | "sdm845" | "sdm710" | "msmnile" | "msmsteppe")
+ setprop vendor.post_boot.parsed 1
;;
"apq8084")
rm /data/system/perfd/default_values
@@ -3197,4 +4227,3 @@ esac
misc_link=$(ls -l /dev/block/bootdevice/by-name/misc)
real_path=${misc_link##*>}
setprop persist.vendor.mmi.misc_dev_path $real_path
-
diff --git a/rootdir/bin/init.crda.sh b/rootdir/bin/init.qcom.sensors.sh
index 4264789..d2eb8e1 100755
--- a/rootdir/bin/init.crda.sh
+++ b/rootdir/bin/init.qcom.sensors.sh
@@ -1,6 +1,5 @@
-#! /vendor/bin/sh
-
-# Copyright (c) 2012, The Linux Foundation. All rights reserved.
+#!/vendor/bin/sh
+# Copyright (c) 2015, 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:
@@ -27,9 +26,19 @@
# ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
#
-country=`getprop wlan.crda.country`
-# crda takes input in COUNTRY environment variable
-if [ $country != "" ]
-then
-COUNTRY="$country" /system/bin/crda
-fi
+#
+# Function to start sensors for SSC enabled platforms
+#
+start_sensors()
+{
+ chmod -h 664 /persist/sensors/sensors_settings
+ chown -h -R system.system /persist/sensors
+ start vendor.sensors.qti
+
+ # Only for SLPI
+ if [ -c /dev/msm_dsps -o -c /dev/sensors ]; then
+ start vendor.sensors
+ fi
+}
+
+start_sensors
diff --git a/rootdir/bin/init.qcom.sh b/rootdir/bin/init.qcom.sh
index fc1f560..fbf8c82 100755
--- a/rootdir/bin/init.qcom.sh
+++ b/rootdir/bin/init.qcom.sh
@@ -28,6 +28,7 @@
#
target=`getprop ro.board.platform`
+low_ram=`getprop ro.config.low_ram`
if [ -f /sys/devices/soc0/soc_id ]; then
platformid=`cat /sys/devices/soc0/soc_id`
else
@@ -81,55 +82,28 @@ start_vm_bms()
start_msm_irqbalance_8939()
{
- if [ -f /system/vendor/bin/msm_irqbalance ]; then
+ if [ -f /vendor/bin/msm_irqbalance ]; then
case "$platformid" in
- "239" | "293" | "294" | "295" | "304" | "313")
+ "239" | "293" | "294" | "295" | "304" | "313" |"353")
start vendor.msm_irqbalance;;
+ "349" | "350" )
+ start vendor.msm_irqbal_lb;;
esac
fi
}
-start_msm_irqbalance_8952()
-{
- if [ -f /system/vendor/bin/msm_irqbalance ]; then
- case "$platformid" in
- "241" | "263" | "264" | "268" | "269" | "270" | "271")
- start vendor.msm_irqbalance;;
- esac
- case "$platformid" in
- "266" | "274" | "277" | "278")
- start vendor.msm_irqbal_lb;;
- esac
- fi
-}
-
-start_msm_irqbalance660()
+start_msm_irqbalance()
{
if [ -f /vendor/bin/msm_irqbalance ]; then
case "$platformid" in
"317" | "324" | "325" | "326" | "345" | "346")
start vendor.msm_irqbalance;;
- "318" | "327")
+ "318" | "327" | "385")
start vendor.msm_irqbl_sdm630;;
esac
fi
}
-start_msm_irqbalance()
-{
- if [ -f /vendor/bin/msm_irqbalance ]; then
- start vendor.msm_irqbalance
- fi
-}
-
-start_copying_prebuilt_qcril_db()
-{
- if [ -f /vendor/radio/qcril_database/qcril.db -a ! -f /data/vendor/radio/qcril.db ]; then
- cp /vendor/radio/qcril_database/qcril.db /data/vendor/radio/qcril.db
- chown -h radio.radio /data/vendor/radio/qcril.db
- fi
-}
-
baseband=`getprop ro.baseband`
echo 1 > /proc/sys/net/ipv6/conf/default/accept_ra_defrtr
@@ -226,7 +200,7 @@ case "$target" in
esac
;;
esac
- start_msm_irqbalance660
+ start_msm_irqbalance
;;
"apq8084")
platformvalue=`cat /sys/devices/soc0/hw_platform`
@@ -279,7 +253,7 @@ case "$target" in
;;
esac
;;
- "msm8994" | "msm8992" | "msm8998" | "apq8098_latv" | "sdm845")
+ "msm8994" | "msm8992" | "msm8998" | "apq8098_latv" | "sdm845" | "sdm710" | "qcs605" | "msmnile" | "talos")
start_msm_irqbalance
;;
"msm8996")
@@ -306,60 +280,6 @@ case "$target" in
"msm8909")
start_vm_bms
;;
- "msm8952")
- start_msm_irqbalance_8952
- if [ -f /sys/devices/soc0/soc_id ]; then
- soc_id=`cat /sys/devices/soc0/soc_id`
- else
- soc_id=`cat /sys/devices/system/soc/soc0/id`
- fi
-
- if [ -f /sys/devices/soc0/platform_subtype_id ]; then
- platform_subtype_id=`cat /sys/devices/soc0/platform_subtype_id`
- fi
- if [ -f /sys/devices/soc0/hw_platform ]; then
- hw_platform=`cat /sys/devices/soc0/hw_platform`
- fi
- case "$soc_id" in
- "264")
- case "$hw_platform" in
- "Surf")
- case "$platform_subtype_id" in
- "1" | "2")
- setprop qemu.hw.mainkeys 0
- ;;
- esac
- ;;
- "MTP")
- case "$platform_subtype_id" in
- "3")
- setprop qemu.hw.mainkeys 0
- ;;
- esac
- ;;
- "QRD")
- case "$platform_subtype_id" in
- "0")
- setprop qemu.hw.mainkeys 0
- ;;
- esac
- ;;
- esac
- ;;
- "266" | "274" | "277" | "278")
- case "$hw_platform" in
- "Surf" | "RCM")
- if [ $panel_xres -eq 1440 ]; then
- setprop qemu.hw.mainkeys 0
- fi
- ;;
- "MTP" | "QRD")
- setprop qemu.hw.mainkeys 0
- ;;
- esac
- ;;
- esac
- ;;
"msm8937")
start_msm_irqbalance_8939
if [ -f /sys/devices/soc0/soc_id ]; then
@@ -373,8 +293,42 @@ case "$target" in
else
hw_platform=`cat /sys/devices/system/soc/soc0/hw_platform`
fi
+ if [ "$low_ram" != "true" ]; then
+ case "$soc_id" in
+ "294" | "295" | "303" | "307" | "308" | "309" | "313" | "320" | "353" | "354" | "363" | "364")
+ case "$hw_platform" in
+ "Surf")
+ setprop qemu.hw.mainkeys 0
+ ;;
+ "MTP")
+ setprop qemu.hw.mainkeys 0
+ ;;
+ "RCM")
+ setprop qemu.hw.mainkeys 0
+ ;;
+ "QRD")
+ setprop qemu.hw.mainkeys 0
+ ;;
+ esac
+ ;;
+ esac
+ fi
+ ;;
+ "msm8953")
+ start_msm_irqbalance_8939
+ if [ -f /sys/devices/soc0/soc_id ]; then
+ soc_id=`cat /sys/devices/soc0/soc_id`
+ else
+ soc_id=`cat /sys/devices/system/soc/soc0/id`
+ fi
+
+ if [ -f /sys/devices/soc0/hw_platform ]; then
+ hw_platform=`cat /sys/devices/soc0/hw_platform`
+ else
+ hw_platform=`cat /sys/devices/system/soc/soc0/hw_platform`
+ fi
case "$soc_id" in
- "294" | "295" | "303" | "307" | "308" | "309" | "313" | "320")
+ "293" | "304" | "338" | "351" | "349" | "350" )
case "$hw_platform" in
"Surf")
setprop qemu.hw.mainkeys 0
@@ -392,8 +346,7 @@ case "$target" in
;;
esac
;;
- "msm8953")
- start_msm_irqbalance_8939
+ "sdm710")
if [ -f /sys/devices/soc0/soc_id ]; then
soc_id=`cat /sys/devices/soc0/soc_id`
else
@@ -406,7 +359,7 @@ case "$target" in
hw_platform=`cat /sys/devices/system/soc/soc0/hw_platform`
fi
case "$soc_id" in
- "293" | "304" | "338" | "351" )
+ "336" | "337" | "347" | "360" )
case "$hw_platform" in
"Surf")
setprop qemu.hw.mainkeys 0
@@ -427,33 +380,28 @@ case "$target" in
esac
#
-# Copy qcril.db if needed for RIL
-#
-start_copying_prebuilt_qcril_db
-echo 1 > /data/vendor/radio/db_check_done
-
-#
# Make modem config folder and copy firmware config to that folder for RIL
#
-if [ -f /data/vendor/radio/ver_info.txt ]; then
- prev_version_info=`cat /data/vendor/radio/ver_info.txt`
+if [ -f /data/vendor/modem_config/ver_info.txt ]; then
+ prev_version_info=`cat /data/vendor/modem_config/ver_info.txt`
else
prev_version_info=""
fi
-cur_version_info=`cat /firmware/verinfo/ver_info.txt`
-if [ ! -f /firmware/verinfo/ver_info.txt -o "$prev_version_info" != "$cur_version_info" ]; then
- rm -rf /data/vendor/radio/modem_config
- mkdir /data/vendor/radio/modem_config
- chmod 770 /data/vendor/radio/modem_config
- cp -r /firmware/image/modem_pr/mcfg/configs/* /data/vendor/radio/modem_config
- chown -hR radio.radio /data/vendor/radio/modem_config
- cp /firmware/verinfo/ver_info.txt /data/vendor/radio/ver_info.txt
- chown radio.radio /data/vendor/radio/ver_info.txt
+cur_version_info=`cat /vendor/firmware_mnt/verinfo/ver_info.txt`
+if [ ! -f /vendor/firmware_mnt/verinfo/ver_info.txt -o "$prev_version_info" != "$cur_version_info" ]; then
+ # add W for group recursively before delete
+ chmod g+w -R /data/vendor/modem_config/*
+ rm -rf /data/vendor/modem_config/*
+ # preserve the read only mode for all subdir and files
+ cp --preserve=m -dr /vendor/firmware_mnt/image/modem_pr/mcfg/configs/* /data/vendor/modem_config
+ cp --preserve=m -d /vendor/firmware_mnt/verinfo/ver_info.txt /data/vendor/modem_config/
+ cp --preserve=m -d /vendor/firmware_mnt/image/modem_pr/mbn_ota.txt /data/vendor/modem_config/
+ # the group must be root, otherwise this script could not add "W" for group recursively
+ chown -hR radio.root /data/vendor/modem_config/*
fi
-cp /firmware/image/modem_pr/mbn_ota.txt /data/vendor/radio/modem_config
-chown radio.radio /data/vendor/radio/modem_config/mbn_ota.txt
-echo 1 > /data/vendor/radio/copy_complete
+chmod g-w /data/vendor/modem_config
+setprop ro.vendor.ril.mbn_copy_completed 1
#check build variant for printk logging
#current default minimum boot-time-default
diff --git a/rootdir/bin/init.qcom.usb.sh b/rootdir/bin/init.qcom.usb.sh
index 9bd8ca2..4a18c40 100755
--- a/rootdir/bin/init.qcom.usb.sh
+++ b/rootdir/bin/init.qcom.usb.sh
@@ -1,5 +1,5 @@
#!/vendor/bin/sh
-# Copyright (c) 2012-2017, The Linux Foundation. All rights reserved.
+# Copyright (c) 2012-2018, 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
@@ -27,8 +27,6 @@
# IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
#
#
-chown -h root.system /sys/devices/platform/msm_hsusb/gadget/wakeup
-chmod -h 220 /sys/devices/platform/msm_hsusb/gadget/wakeup
# Set platform variables
if [ -f /sys/devices/soc0/hw_platform ]; then
@@ -43,44 +41,6 @@ else
soc_machine=`cat /sys/devices/system/soc/soc0/machine` 2> /dev/null
fi
-# Get hardware revision
-if [ -f /sys/devices/soc0/revision ]; then
- soc_revision=`cat /sys/devices/soc0/revision` 2> /dev/null
-else
- soc_revision=`cat /sys/devices/system/soc/soc0/revision` 2> /dev/null
-fi
-
-#
-# Allow persistent usb charging disabling
-# User needs to set usb charging disabled in persist.usb.chgdisabled
-#
-target=`getprop ro.board.platform`
-usbchgdisabled=`getprop persist.usb.chgdisabled`
-case "$usbchgdisabled" in
- "") ;; #Do nothing here
- * )
- case $target in
- "msm8660")
- echo "$usbchgdisabled" > /sys/module/pmic8058_charger/parameters/disabled
- echo "$usbchgdisabled" > /sys/module/smb137b/parameters/disabled
- ;;
- "msm8960")
- echo "$usbchgdisabled" > /sys/module/pm8921_charger/parameters/disabled
- ;;
- esac
-esac
-
-usbcurrentlimit=`getprop persist.usb.currentlimit`
-case "$usbcurrentlimit" in
- "") ;; #Do nothing here
- * )
- case $target in
- "msm8960")
- echo "$usbcurrentlimit" > /sys/module/pm8921_charger/parameters/usb_max_current
- ;;
- esac
-esac
-
#
# Check ESOC for external MDM
#
@@ -89,7 +49,7 @@ esac
if [ -d /sys/bus/esoc/devices ]; then
for f in /sys/bus/esoc/devices/*; do
if [ -d $f ]; then
- if [ `grep "^MDM" $f/esoc_name` ]; then
+ if [ `grep -e "^MDM" -e "^SDX" $f/esoc_name` ]; then
esoc_link=`cat $f/esoc_link`
break
fi
@@ -106,44 +66,141 @@ else
soc_id=`cat /sys/devices/system/soc/soc0/id`
fi
+if [ -f /sys/class/android_usb/f_mass_storage/lun/nofua ]; then
+ echo 1 > /sys/class/android_usb/f_mass_storage/lun/nofua
+fi
+
#
-# Allow USB enumeration with default PID/VID
+# Override USB default composition
#
-baseband=`getprop ro.baseband`
+# If USB persist config not set, set default configuration
+miui_release=`getprop ro.fota.oem`
+miui_debuggable=`getprop ro.debuggable`
+if [ "$(getprop persist.vendor.usb.config)" == "" -a \
+ "$(getprop init.svc.vendor.usb-gadget-hal-1-0)" != "running" ]; then
+ if [ "$esoc_link" != "" ]; then
+ setprop persist.vendor.usb.config diag,diag_mdm,qdss,qdss_mdm,serial_cdev,dpl,rmnet,adb
+ else
+ case "$(getprop ro.baseband)" in
+ "apq")
+ setprop persist.vendor.usb.config diag,adb
+ ;;
+ *)
+ case "$soc_hwplatform" in
+ "Dragon" | "SBC")
+ setprop persist.vendor.usb.config diag,adb
+ ;;
+ *)
+ soc_machine=${soc_machine:0:3}
+ case "$soc_machine" in
+ "SDA")
+ setprop persist.vendor.usb.config diag,adb
+ ;;
+ *)
+ case "$target" in
+ "msm8996")
+ setprop persist.vendor.usb.config diag,serial_cdev,serial_tty,rmnet_ipa,mass_storage,adb
+ ;;
+ "msm8909")
+ setprop persist.vendor.usb.config diag,serial_smd,rmnet_qti_bam,adb
+ ;;
+ "msm8937")
+ if [ -d /config/usb_gadget ]; then
+ setprop persist.vendor.usb.config diag,serial_cdev,rmnet,dpl,adb
+ else
+ case "$soc_id" in
+ "313" | "320")
+ echo BAM2BAM_IPA > /sys/class/android_usb/android0/f_rndis_qc/rndis_transports
+ setprop persist.vendor.usb.config diag,serial_smd,rmnet_ipa,adb
+ ;;
+ *)
+ setprop persist.vendor.usb.config diag,serial_smd,rmnet_qti_bam,adb
+ ;;
+ esac
+ fi
+ ;;
+ "msm8953")
+ if [ -d /config/usb_gadget ]; then
+ setprop persist.vendor.usb.config diag,serial_cdev,rmnet,dpl,adb
+ else
+ setprop persist.vendor.usb.config diag,serial_smd,rmnet_ipa,adb
+ fi
+ ;;
+ "msm8998" | "sdm660" | "sdm636"| "apq8098_latv")
+ case "$miui_release" in
+ "")
+ case "$miui_debuggable" in
+ "1")
+ setprop persist.vendor.usb.config diag,serial_cdev,rmnet,adb
+ ;;
+ *)
+ setprop persist.vendor.usb.config diag,serial_cdev,rmnet
+ ;;
+ esac
+ ;;
+ *)
+ case "$miui_debuggable" in
+ "1")
+ setprop persist.vendor.usb.config adb
+ ;;
+ *)
+ setprop persist.vendor.usb.config none
+ ;;
+ esac
+ ;;
+ esac
+ ;;
+ "sdm845" | "sdm710")
+ setprop persist.vendor.usb.config diag,serial_cdev,rmnet,dpl,adb
+ ;;
+ "msmnile" | "talos")
+ setprop persist.vendor.usb.config diag,serial_cdev,rmnet,dpl,qdss,adb
+ ;;
+ *)
+ setprop persist.vendor.usb.config diag,adb
+ ;;
+ esac
+ ;;
+ esac
+ ;;
+ esac
+ ;;
+ esac
+ fi
+fi
+
+# set rndis transport to BAM2BAM_IPA for 8920 and 8940
+if [ "$target" == "msm8937" ]; then
+ if [ ! -d /config/usb_gadget ]; then
+ case "$soc_id" in
+ "313" | "320")
+ echo BAM2BAM_IPA > /sys/class/android_usb/android0/f_rndis_qc/rndis_transports
+ ;;
+ *)
+ ;;
+ esac
+ fi
+fi
-echo 1 > /sys/class/android_usb/f_mass_storage/lun/nofua
+# set device mode notification to USB driver for SA8150 Auto ADP
+product=`getprop ro.build.product`
-# set USB controller's device node
-case "$target" in
- "msm8996")
- setprop sys.usb.controller "6a00000.dwc3"
- setprop sys.usb.rndis.func.name "rndis_bam"
- setprop sys.usb.rmnet.func.name "rmnet_bam"
- ;;
- "msm8998" | "apq8098_latv")
- setprop sys.usb.controller "a800000.dwc3"
- setprop sys.usb.rndis.func.name "gsi"
- setprop sys.usb.rmnet.func.name "gsi"
- ;;
- "sdm660")
- setprop sys.usb.controller "a800000.dwc3"
- setprop sys.usb.rndis.func.name "rndis_bam"
- setprop sys.usb.rmnet.func.name "rmnet_bam"
- echo 15916 > /sys/module/usb_f_qcrndis/parameters/rndis_dl_max_xfer_size
- ;;
- "sdm845")
- setprop sys.usb.controller "a600000.dwc3"
- setprop sys.usb.rndis.func.name "gsi"
- setprop sys.usb.rmnet.func.name "gsi"
- ;;
- *)
+case "$product" in
+ "msmnile_au")
+ echo peripheral > /sys/bus/platform/devices/a600000.ssusb/mode
+ ;;
+ *)
;;
esac
# check configfs is mounted or not
if [ -d /config/usb_gadget ]; then
+ # Chip-serial is used for unique MSM identification in Product string
msm_serial=`cat /sys/devices/soc0/serial_number`;
msm_serial_hex=`printf %08X $msm_serial`
+ machine_type=`cat /sys/devices/soc0/machine`
+ product_string="$machine_type-$soc_hwplatform _SN:$msm_serial_hex"
+ echo "$product_string" > /config/usb_gadget/g1/strings/0x409/product
# ADB requires valid iSerialNumber; if ro.serialno is missing, use dummy
serialnumber=`cat /config/usb_gadget/g1/strings/0x409/serialnumber` 2> /dev/null
@@ -151,141 +208,76 @@ if [ -d /config/usb_gadget ]; then
serialno=1234567
echo $serialno > /config/usb_gadget/g1/strings/0x409/serialnumber
fi
-
- persist_comp=`getprop persist.sys.usb.config`
- comp=`getprop sys.usb.config`
- echo $persist_comp
- echo $comp
- if [ "$comp" != "$persist_comp" ]; then
- echo "setting sys.usb.config"
- setprop sys.usb.config $persist_comp
- fi
-
- setprop sys.usb.configfs 1
-else
- persist_comp=`getprop persist.sys.usb.config`
- comp=`getprop sys.usb.config`
- echo $persist_comp
- echo $comp
- if [ "$comp" != "$persist_comp" ]; then
- echo "setting sys.usb.config"
- setprop sys.usb.config $persist_comp
- fi
fi
#
-# Do target specific things
-#
-case "$target" in
- "msm8974")
-# Select USB BAM - 2.0 or 3.0
- echo ssusb > /sys/bus/platform/devices/usb_bam/enable
- ;;
- "apq8084")
- if [ "$baseband" == "apq" ]; then
- echo "msm_hsic_host" > /sys/bus/platform/drivers/xhci_msm_hsic/unbind
- fi
- ;;
- "msm8226")
- if [ -e /sys/bus/platform/drivers/msm_hsic_host ]; then
- if [ ! -L /sys/bus/usb/devices/1-1 ]; then
- echo msm_hsic_host > /sys/bus/platform/drivers/msm_hsic_host/unbind
- fi
- fi
- ;;
- "msm8994" | "msm8992" | "msm8996" | "msm8953")
- echo BAM2BAM_IPA > /sys/class/android_usb/android0/f_rndis_qc/rndis_transports
- echo 131072 > /sys/module/g_android/parameters/mtp_tx_req_len
- echo 131072 > /sys/module/g_android/parameters/mtp_rx_req_len
- ;;
- "msm8937")
- case "$soc_id" in
- "313" | "320")
- echo BAM2BAM_IPA > /sys/class/android_usb/android0/f_rndis_qc/rndis_transports
- ;;
- esac
- ;;
-esac
-
-#
-# set module params for embedded rmnet devices
-#
-rmnetmux=`getprop persist.rmnet.mux`
-case "$baseband" in
- "mdm" | "dsda" | "sglte2")
- case "$rmnetmux" in
- "enabled")
- echo 1 > /sys/module/rmnet_usb/parameters/mux_enabled
- echo 8 > /sys/module/rmnet_usb/parameters/no_fwd_rmnet_links
- echo 17 > /sys/module/rmnet_usb/parameters/no_rmnet_insts_per_dev
- ;;
- esac
- echo 1 > /sys/module/rmnet_usb/parameters/rmnet_data_init
- # Allow QMUX daemon to assign port open wait time
- chown -h radio.radio /sys/devices/virtual/hsicctl/hsicctl0/modem_wait
- ;;
- "dsda2")
- echo 2 > /sys/module/rmnet_usb/parameters/no_rmnet_devs
- echo hsicctl,hsusbctl > /sys/module/rmnet_usb/parameters/rmnet_dev_names
- case "$rmnetmux" in
- "enabled") #mux is neabled on both mdms
- echo 3 > /sys/module/rmnet_usb/parameters/mux_enabled
- echo 8 > /sys/module/rmnet_usb/parameters/no_fwd_rmnet_links
- echo 17 > write /sys/module/rmnet_usb/parameters/no_rmnet_insts_per_dev
- ;;
- "enabled_hsic") #mux is enabled on hsic mdm
- echo 1 > /sys/module/rmnet_usb/parameters/mux_enabled
- echo 8 > /sys/module/rmnet_usb/parameters/no_fwd_rmnet_links
- echo 17 > /sys/module/rmnet_usb/parameters/no_rmnet_insts_per_dev
- ;;
- "enabled_hsusb") #mux is enabled on hsusb mdm
- echo 2 > /sys/module/rmnet_usb/parameters/mux_enabled
- echo 8 > /sys/module/rmnet_usb/parameters/no_fwd_rmnet_links
- echo 17 > /sys/module/rmnet_usb/parameters/no_rmnet_insts_per_dev
- ;;
- esac
- echo 1 > /sys/module/rmnet_usb/parameters/rmnet_data_init
- # Allow QMUX daemon to assign port open wait time
- chown -h radio.radio /sys/devices/virtual/hsicctl/hsicctl0/modem_wait
- ;;
-esac
-
-#
-# Add support for exposing lun0 as cdrom in mass-storage
-#
-cdromname="/system/etc/cdrom_install.iso"
-platformver=`cat /sys/devices/soc0/hw_platform`
-case "$target" in
- "msm8226" | "msm8610" | "msm8916")
- case $platformver in
- "QRD")
- echo "mounting usbcdrom lun"
- echo $cdromname > /sys/class/android_usb/android0/f_mass_storage/rom/file
- chmod 0444 /sys/class/android_usb/android0/f_mass_storage/rom/file
- ;;
- esac
- ;;
-esac
-
-#
# Initialize RNDIS Diag option. If unset, set it to 'none'.
#
-diag_extra=`getprop persist.sys.usb.config.extra`
+diag_extra=`getprop persist.vendor.usb.config.extra`
if [ "$diag_extra" == "" ]; then
- setprop persist.sys.usb.config.extra none
-fi
-
-# soc_ids for 8937
-if [ -f /sys/devices/soc0/soc_id ]; then
- soc_id=`cat /sys/devices/soc0/soc_id`
-else
- soc_id=`cat /sys/devices/system/soc/soc0/id`
+ setprop persist.vendor.usb.config.extra none
fi
# enable rps cpus on msm8937 target
-setprop sys.usb.rps_mask 0
+setprop vendor.usb.rps_mask 0
case "$soc_id" in
- "294" | "295")
- setprop sys.usb.rps_mask 40
+ "294" | "295" | "353" | "354")
+ setprop vendor.usb.rps_mask 40
;;
esac
+
+#
+# Initialize UVC conifguration.
+#
+if [ -d /config/usb_gadget/g1/functions/uvc.0 ]; then
+ cd /config/usb_gadget/g1/functions/uvc.0
+
+ echo 3072 > streaming_maxpacket
+ echo 1 > streaming_maxburst
+ mkdir control/header/h
+ ln -s control/header/h control/class/fs/
+ ln -s control/header/h control/class/ss
+
+ mkdir -p streaming/uncompressed/u/360p
+ echo "666666\n1000000\n5000000\n" > streaming/uncompressed/u/360p/dwFrameInterval
+
+ mkdir -p streaming/uncompressed/u/720p
+ echo 1280 > streaming/uncompressed/u/720p/wWidth
+ echo 720 > streaming/uncompressed/u/720p/wWidth
+ echo 29491200 > streaming/uncompressed/u/720p/dwMinBitRate
+ echo 29491200 > streaming/uncompressed/u/720p/dwMaxBitRate
+ echo 1843200 > streaming/uncompressed/u/720p/dwMaxVideoFrameBufferSize
+ echo 5000000 > streaming/uncompressed/u/720p/dwDefaultFrameInterval
+ echo "5000000\n" > streaming/uncompressed/u/720p/dwFrameInterval
+
+ mkdir -p streaming/mjpeg/m/360p
+ echo "666666\n1000000\n5000000\n" > streaming/mjpeg/m/360p/dwFrameInterval
+
+ mkdir -p streaming/mjpeg/m/720p
+ echo 1280 > streaming/mjpeg/m/720p/wWidth
+ echo 720 > streaming/mjpeg/m/720p/wWidth
+ echo 29491200 > streaming/mjpeg/m/720p/dwMinBitRate
+ echo 29491200 > streaming/mjpeg/m/720p/dwMaxBitRate
+ echo 1843200 > streaming/mjpeg/m/720p/dwMaxVideoFrameBufferSize
+ echo 5000000 > streaming/mjpeg/m/720p/dwDefaultFrameInterval
+ echo "5000000\n" > streaming/mjpeg/m/720p/dwFrameInterval
+
+ echo 0x04 > /config/usb_gadget/g1/functions/uvc.0/streaming/mjpeg/m/bmaControls
+
+ mkdir -p streaming/h264/h/960p
+ echo 1920 > streaming/h264/h/960p/wWidth
+ echo 960 > streaming/h264/h/960p/wWidth
+ echo 40 > streaming/h264/h/960p/bLevelIDC
+ echo "333667\n" > streaming/h264/h/960p/dwFrameInterval
+
+ mkdir -p streaming/h264/h/1920p
+ echo "333667\n" > streaming/h264/h/1920p/dwFrameInterval
+
+ mkdir streaming/header/h
+ ln -s streaming/uncompressed/u streaming/header/h
+ ln -s streaming/mjpeg/m streaming/header/h
+ ln -s streaming/h264/h streaming/header/h
+ ln -s streaming/header/h streaming/class/fs/
+ ln -s streaming/header/h streaming/class/hs/
+ ln -s streaming/header/h streaming/class/ss/
+fi
diff --git a/rootdir/bin/init.qti.qseecomd.sh b/rootdir/bin/init.qti.qseecomd.sh
index f1c725c..3b027f2 100755
--- a/rootdir/bin/init.qti.qseecomd.sh
+++ b/rootdir/bin/init.qti.qseecomd.sh
@@ -31,5 +31,5 @@
while [ "$registered" != "true" ]
do
sleep 0.1
- registered="`getprop sys.listeners.registered`"
+ registered="`getprop vendor.sys.listeners.registered`"
done