init.kernel.post_boot-taro.sh 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257
  1. #=============================================================================
  2. # Copyright (c) 2020-2021 Qualcomm Technologies, Inc.
  3. # All Rights Reserved.
  4. # Confidential and Proprietary - Qualcomm Technologies, Inc.
  5. #
  6. # Copyright (c) 2009-2012, 2014-2019, The Linux Foundation. All rights reserved.
  7. #
  8. # Redistribution and use in source and binary forms, with or without
  9. # modification, are permitted provided that the following conditions are met:
  10. # * Redistributions of source code must retain the above copyright
  11. # notice, this list of conditions and the following disclaimer.
  12. # * Redistributions in binary form must reproduce the above copyright
  13. # notice, this list of conditions and the following disclaimer in the
  14. # documentation and/or other materials provided with the distribution.
  15. # * Neither the name of The Linux Foundation nor
  16. # the names of its contributors may be used to endorse or promote
  17. # products derived from this software without specific prior written
  18. # permission.
  19. #
  20. # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
  21. # AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  22. # IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
  23. # NON-INFRINGEMENT ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
  24. # CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
  25. # EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
  26. # PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
  27. # OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
  28. # WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
  29. # OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
  30. # ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  31. #=============================================================================
  32. rev=`cat /sys/devices/soc0/revision`
  33. ddr_type=`od -An -tx /proc/device-tree/memory/ddr_device_type`
  34. ddr_type4="07"
  35. ddr_type5="08"
  36. # Core control parameters for gold
  37. echo 2 > /sys/devices/system/cpu/cpu4/core_ctl/min_cpus
  38. echo 60 > /sys/devices/system/cpu/cpu4/core_ctl/busy_up_thres
  39. echo 30 > /sys/devices/system/cpu/cpu4/core_ctl/busy_down_thres
  40. echo 100 > /sys/devices/system/cpu/cpu4/core_ctl/offline_delay_ms
  41. echo 3 > /sys/devices/system/cpu/cpu4/core_ctl/task_thres
  42. # Core control parameters for gold+
  43. echo 0 > /sys/devices/system/cpu/cpu7/core_ctl/min_cpus
  44. echo 60 > /sys/devices/system/cpu/cpu7/core_ctl/busy_up_thres
  45. echo 30 > /sys/devices/system/cpu/cpu7/core_ctl/busy_down_thres
  46. echo 100 > /sys/devices/system/cpu/cpu7/core_ctl/offline_delay_ms
  47. echo 1 > /sys/devices/system/cpu/cpu7/core_ctl/task_thres
  48. # Controls how many more tasks should be eligible to run on gold CPUs
  49. # w.r.t number of gold CPUs available to trigger assist (max number of
  50. # tasks eligible to run on previous cluster minus number of CPUs in
  51. # the previous cluster).
  52. #
  53. # Setting to 1 by default which means there should be at least
  54. # 4 tasks eligible to run on gold cluster (tasks running on gold cores
  55. # plus misfit tasks on silver cores) to trigger assitance from gold+.
  56. echo 1 > /sys/devices/system/cpu/cpu7/core_ctl/nr_prev_assist_thresh
  57. # Disable Core control on silver
  58. echo 0 > /sys/devices/system/cpu/cpu0/core_ctl/enable
  59. # Setting b.L scheduler parameters
  60. echo 95 95 > /proc/sys/walt/sched_upmigrate
  61. echo 85 85 > /proc/sys/walt/sched_downmigrate
  62. echo 100 > /proc/sys/walt/sched_group_upmigrate
  63. echo 85 > /proc/sys/walt/sched_group_downmigrate
  64. echo 1 > /proc/sys/walt/sched_walt_rotate_big_tasks
  65. echo 400000000 > /proc/sys/walt/sched_coloc_downmigrate_ns
  66. echo 39000000 39000000 39000000 39000000 39000000 39000000 39000000 5000000 > /proc/sys/walt/sched_coloc_busy_hyst_cpu_ns
  67. echo 240 > /proc/sys/walt/sched_coloc_busy_hysteresis_enable_cpus
  68. echo 10 10 10 10 10 10 10 95 > /proc/sys/walt/sched_coloc_busy_hyst_cpu_busy_pct
  69. echo 5000000 5000000 5000000 5000000 5000000 5000000 5000000 2000000 > /proc/sys/walt/sched_util_busy_hyst_cpu_ns
  70. echo 255 > /proc/sys/walt/sched_util_busy_hysteresis_enable_cpus
  71. echo 15 15 15 15 15 15 15 15 > /proc/sys/walt/sched_util_busy_hyst_cpu_util
  72. # XM power profiling
  73. echo 0 > /sys/devices/system/cpu/cpufreq/policy0/walt/target_load_thresh
  74. echo 4 > /sys/devices/system/cpu/cpufreq/policy0/walt/target_load_shift
  75. echo 0 > /proc/sys/kernel/sched_util_clamp_min_rt_default
  76. # set the threshold for low latency task boost feature which prioritize
  77. # binder activity tasks
  78. echo 325 > /proc/sys/walt/walt_low_latency_task_threshold
  79. # cpuset parameters
  80. echo 0-2 > /dev/cpuset/background/cpus
  81. echo 0-3 > /dev/cpuset/system-background/cpus
  82. echo 4-7 > /dev/cpuset/foreground/boost/cpus
  83. echo 0-2,4-7 > /dev/cpuset/foreground/cpus
  84. echo 0-7 > /dev/cpuset/top-app/cpus
  85. # Turn off scheduler boost at the end
  86. echo 0 > /proc/sys/walt/sched_boost
  87. # Reset the RT boost, which is 1024 (max) by default.
  88. echo 0 > /proc/sys/kernel/sched_util_clamp_min_rt_default
  89. # configure governor settings for silver cluster
  90. echo "walt" > /sys/devices/system/cpu/cpufreq/policy0/scaling_governor
  91. echo 0 > /sys/devices/system/cpu/cpufreq/policy0/walt/down_rate_limit_us
  92. echo 0 > /sys/devices/system/cpu/cpufreq/policy0/walt/up_rate_limit_us
  93. echo 800000 > /sys/devices/system/cpu/cpufreq/policy0/walt/rtg_boost_freq
  94. if [ $rev == "1.0" ]; then
  95. echo 1190400 > /sys/devices/system/cpu/cpufreq/policy0/walt/hispeed_freq
  96. else
  97. echo 998000 > /sys/devices/system/cpu/cpufreq/policy0/walt/hispeed_freq
  98. fi
  99. echo 614400 > /sys/devices/system/cpu/cpufreq/policy0/scaling_min_freq
  100. echo 1 > /sys/devices/system/cpu/cpufreq/policy0/walt/pl
  101. # configure input boost settings
  102. if [ $rev == "1.0" ]; then
  103. echo 1382800 0 0 0 0 0 0 0 > /proc/sys/walt/input_boost/input_boost_freq
  104. else
  105. echo 1171200 0 0 0 0 0 0 0 > /proc/sys/walt/input_boost/input_boost_freq
  106. fi
  107. echo 100 > /proc/sys/walt/input_boost/input_boost_ms
  108. echo 1785600 0 0 0 2169600 0 0 2419200 > /proc/sys/walt/input_boost/powerkey_input_boost_freq
  109. echo 120 > /proc/sys/walt/input_boost/powerkey_input_boost_ms
  110. # configure governor settings for gold cluster
  111. echo "walt" > /sys/devices/system/cpu/cpufreq/policy4/scaling_governor
  112. echo 0 > /sys/devices/system/cpu/cpufreq/policy4/walt/down_rate_limit_us
  113. echo 0 > /sys/devices/system/cpu/cpufreq/policy4/walt/up_rate_limit_us
  114. echo 600000 > /sys/devices/system/cpu/cpufreq/policy4/walt/rtg_boost_freq
  115. if [ $rev == "1.0" ]; then
  116. echo 1497600 > /sys/devices/system/cpu/cpufreq/policy4/walt/hispeed_freq
  117. else
  118. echo 1497600 > /sys/devices/system/cpu/cpufreq/policy4/walt/hispeed_freq
  119. fi
  120. echo 1 > /sys/devices/system/cpu/cpufreq/policy4/walt/pl
  121. # configure governor settings for gold+ cluster
  122. echo "walt" > /sys/devices/system/cpu/cpufreq/policy7/scaling_governor
  123. echo 0 > /sys/devices/system/cpu/cpufreq/policy7/walt/down_rate_limit_us
  124. echo 0 > /sys/devices/system/cpu/cpufreq/policy7/walt/up_rate_limit_us
  125. if [ $rev == "1.0" ]; then
  126. echo 1536000 > /sys/devices/system/cpu/cpufreq/policy7/walt/hispeed_freq
  127. else
  128. echo 1536000 > /sys/devices/system/cpu/cpufreq/policy7/walt/hispeed_freq
  129. fi
  130. echo 1 > /sys/devices/system/cpu/cpufreq/policy7/walt/pl
  131. # configure bus-dcvs
  132. bus_dcvs="/sys/devices/system/cpu/bus_dcvs"
  133. for device in $bus_dcvs/*
  134. do
  135. cat $device/hw_min_freq > $device/boost_freq
  136. done
  137. for llccbw in $bus_dcvs/LLCC/*bwmon-llcc
  138. do
  139. echo "4577 7110 9155 12298 14236 15258" > $llccbw/mbps_zones
  140. echo 4 > $llccbw/sample_ms
  141. echo 80 > $llccbw/io_percent
  142. echo 20 > $llccbw/hist_memory
  143. echo 10 > $llccbw/hyst_length
  144. echo 30 > $llccbw/down_thres
  145. echo 0 > $llccbw/guard_band_mbps
  146. echo 250 > $llccbw/up_scale
  147. echo 1600 > $llccbw/idle_mbps
  148. echo 806000 > $llccbw/max_freq
  149. echo 40 > $llccbw/window_ms
  150. done
  151. for ddrbw in $bus_dcvs/DDR/*bwmon-ddr
  152. do
  153. echo "1720 2086 2929 3879 6515 7980 12191" > $ddrbw/mbps_zones
  154. echo 4 > $ddrbw/sample_ms
  155. echo 80 > $ddrbw/io_percent
  156. echo 20 > $ddrbw/hist_memory
  157. echo 10 > $ddrbw/hyst_length
  158. echo 30 > $ddrbw/down_thres
  159. echo 0 > $ddrbw/guard_band_mbps
  160. echo 250 > $ddrbw/up_scale
  161. echo 1600 > $ddrbw/idle_mbps
  162. echo 2092000 > $ddrbw/max_freq
  163. echo 40 > $ddrbw/window_ms
  164. done
  165. for latfloor in $bus_dcvs/*/*latfloor
  166. do
  167. echo 25000 > $latfloor/ipm_ceil
  168. done
  169. for l3gold in $bus_dcvs/L3/*gold
  170. do
  171. echo 4000 > $l3gold/ipm_ceil
  172. done
  173. for l3prime in $bus_dcvs/L3/*prime
  174. do
  175. echo 20000 > $l3prime/ipm_ceil
  176. done
  177. for ddrprime in $bus_dcvs/DDR/*prime
  178. do
  179. echo 25 > $ddrprime/freq_scale_pct
  180. echo 1881 > $ddrprime/freq_scale_limit_mhz
  181. done
  182. for qosgold in $bus_dcvs/DDRQOS/*gold
  183. do
  184. echo 50 > $qosgold/ipm_ceil
  185. done
  186. if [ "$rev" == "1.0" ]; then
  187. echo Y > /sys/devices/system/cpu/qcom_lpm/parameters/sleep_disabled
  188. echo 1 > /sys/devices/system/cpu/cpu0/cpuidle/state1/disable
  189. echo 1 > /sys/devices/system/cpu/cpu1/cpuidle/state1/disable
  190. echo 1 > /sys/devices/system/cpu/cpu2/cpuidle/state1/disable
  191. echo 1 > /sys/devices/system/cpu/cpu3/cpuidle/state1/disable
  192. echo 1 > /sys/devices/system/cpu/cpu4/cpuidle/state1/disable
  193. echo 1 > /sys/devices/system/cpu/cpu5/cpuidle/state1/disable
  194. echo 1 > /sys/devices/system/cpu/cpu6/cpuidle/state1/disable
  195. echo 1 > /sys/devices/system/cpu/cpu7/cpuidle/state1/disable
  196. echo 0 > "/sys/devices/platform/hypervisor/hypervisor:qcom,gh-watchdog/wakeup_enable"
  197. else
  198. echo N > /sys/devices/system/cpu/qcom_lpm/parameters/sleep_disabled
  199. fi
  200. echo s2idle > /sys/power/mem_sleep
  201. # Let kernel know our image version/variant/crm_version
  202. if [ -f /sys/devices/soc0/select_image ]; then
  203. image_version="10:"
  204. image_version+=`getprop ro.build.id`
  205. image_version+=":"
  206. image_version+=`getprop ro.build.version.incremental`
  207. image_variant=`getprop ro.product.name`
  208. image_variant+="-"
  209. image_variant+=`getprop ro.build.type`
  210. oem_version=`getprop ro.build.version.codename`
  211. echo 10 > /sys/devices/soc0/select_image
  212. echo $image_version > /sys/devices/soc0/image_version
  213. echo $image_variant > /sys/devices/soc0/image_variant
  214. echo $oem_version > /sys/devices/soc0/image_crm_version
  215. fi
  216. # Change console log level as per console config property
  217. console_config=`getprop persist.vendor.console.silent.config`
  218. case "$console_config" in
  219. "1")
  220. echo "Enable console config to $console_config"
  221. echo 0 > /proc/sys/kernel/printk
  222. ;;
  223. *)
  224. echo "Enable console config to $console_config"
  225. ;;
  226. esac
  227. setprop vendor.post_boot.parsed 1