init.kernel.post_boot-taro.sh 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244
  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. # set the threshold for low latency task boost feature which prioritize
  73. # binder activity tasks
  74. echo 325 > /proc/sys/walt/walt_low_latency_task_threshold
  75. # cpuset parameters
  76. echo 0-3 > /dev/cpuset/background/cpus
  77. echo 0-3 > /dev/cpuset/system-background/cpus
  78. # Turn off scheduler boost at the end
  79. echo 0 > /proc/sys/walt/sched_boost
  80. # Reset the RT boost, which is 1024 (max) by default.
  81. echo 0 > /proc/sys/kernel/sched_util_clamp_min_rt_default
  82. # configure governor settings for silver cluster
  83. echo "walt" > /sys/devices/system/cpu/cpufreq/policy0/scaling_governor
  84. echo 0 > /sys/devices/system/cpu/cpufreq/policy0/walt/down_rate_limit_us
  85. echo 0 > /sys/devices/system/cpu/cpufreq/policy0/walt/up_rate_limit_us
  86. if [ $rev == "1.0" ]; then
  87. echo 1190400 > /sys/devices/system/cpu/cpufreq/policy0/walt/hispeed_freq
  88. else
  89. echo 1267200 > /sys/devices/system/cpu/cpufreq/policy0/walt/hispeed_freq
  90. fi
  91. echo 614400 > /sys/devices/system/cpu/cpufreq/policy0/scaling_min_freq
  92. echo 1 > /sys/devices/system/cpu/cpufreq/policy0/walt/pl
  93. # configure input boost settings
  94. if [ $rev == "1.0" ]; then
  95. echo 1382800 0 0 0 0 0 0 0 > /proc/sys/walt/input_boost/input_boost_freq
  96. else
  97. echo 1171200 0 0 0 0 0 0 0 > /proc/sys/walt/input_boost/input_boost_freq
  98. fi
  99. echo 100 > /proc/sys/walt/input_boost/input_boost_ms
  100. # configure governor settings for gold cluster
  101. echo "walt" > /sys/devices/system/cpu/cpufreq/policy4/scaling_governor
  102. echo 0 > /sys/devices/system/cpu/cpufreq/policy4/walt/down_rate_limit_us
  103. echo 0 > /sys/devices/system/cpu/cpufreq/policy4/walt/up_rate_limit_us
  104. if [ $rev == "1.0" ]; then
  105. echo 1497600 > /sys/devices/system/cpu/cpufreq/policy4/walt/hispeed_freq
  106. else
  107. echo 1555200 > /sys/devices/system/cpu/cpufreq/policy4/walt/hispeed_freq
  108. fi
  109. echo 1 > /sys/devices/system/cpu/cpufreq/policy4/walt/pl
  110. # configure governor settings for gold+ cluster
  111. echo "walt" > /sys/devices/system/cpu/cpufreq/policy7/scaling_governor
  112. echo 0 > /sys/devices/system/cpu/cpufreq/policy7/walt/down_rate_limit_us
  113. echo 0 > /sys/devices/system/cpu/cpufreq/policy7/walt/up_rate_limit_us
  114. if [ $rev == "1.0" ]; then
  115. echo 1536000 > /sys/devices/system/cpu/cpufreq/policy7/walt/hispeed_freq
  116. else
  117. echo 1728000 > /sys/devices/system/cpu/cpufreq/policy7/walt/hispeed_freq
  118. fi
  119. echo 1 > /sys/devices/system/cpu/cpufreq/policy7/walt/pl
  120. # configure bus-dcvs
  121. bus_dcvs="/sys/devices/system/cpu/bus_dcvs"
  122. for device in $bus_dcvs/*
  123. do
  124. cat $device/hw_min_freq > $device/boost_freq
  125. done
  126. for llccbw in $bus_dcvs/LLCC/*bwmon-llcc
  127. do
  128. echo "4577 7110 9155 12298 14236 15258" > $llccbw/mbps_zones
  129. echo 4 > $llccbw/sample_ms
  130. echo 80 > $llccbw/io_percent
  131. echo 20 > $llccbw/hist_memory
  132. echo 10 > $llccbw/hyst_length
  133. echo 30 > $llccbw/down_thres
  134. echo 0 > $llccbw/guard_band_mbps
  135. echo 250 > $llccbw/up_scale
  136. echo 1600 > $llccbw/idle_mbps
  137. echo 806000 > $llccbw/max_freq
  138. echo 40 > $llccbw/window_ms
  139. done
  140. for ddrbw in $bus_dcvs/DDR/*bwmon-ddr
  141. do
  142. echo "1720 2086 2929 3879 6515 7980 12191" > $ddrbw/mbps_zones
  143. echo 4 > $ddrbw/sample_ms
  144. echo 80 > $ddrbw/io_percent
  145. echo 20 > $ddrbw/hist_memory
  146. echo 10 > $ddrbw/hyst_length
  147. echo 30 > $ddrbw/down_thres
  148. echo 0 > $ddrbw/guard_band_mbps
  149. echo 250 > $ddrbw/up_scale
  150. echo 1600 > $ddrbw/idle_mbps
  151. echo 2092000 > $ddrbw/max_freq
  152. echo 40 > $ddrbw/window_ms
  153. done
  154. for latfloor in $bus_dcvs/*/*latfloor
  155. do
  156. echo 25000 > $latfloor/ipm_ceil
  157. done
  158. for l3gold in $bus_dcvs/L3/*gold
  159. do
  160. echo 4000 > $l3gold/ipm_ceil
  161. done
  162. for l3prime in $bus_dcvs/L3/*prime
  163. do
  164. echo 20000 > $l3prime/ipm_ceil
  165. done
  166. for ddrprime in $bus_dcvs/DDR/*prime
  167. do
  168. echo 25 > $ddrprime/freq_scale_pct
  169. echo 1881 > $ddrprime/freq_scale_limit_mhz
  170. done
  171. for qosgold in $bus_dcvs/DDRQOS/*gold
  172. do
  173. echo 50 > $qosgold/ipm_ceil
  174. done
  175. if [ "$rev" == "1.0" ]; then
  176. echo Y > /sys/devices/system/cpu/qcom_lpm/parameters/sleep_disabled
  177. echo 1 > /sys/devices/system/cpu/cpu0/cpuidle/state1/disable
  178. echo 1 > /sys/devices/system/cpu/cpu1/cpuidle/state1/disable
  179. echo 1 > /sys/devices/system/cpu/cpu2/cpuidle/state1/disable
  180. echo 1 > /sys/devices/system/cpu/cpu3/cpuidle/state1/disable
  181. echo 1 > /sys/devices/system/cpu/cpu4/cpuidle/state1/disable
  182. echo 1 > /sys/devices/system/cpu/cpu5/cpuidle/state1/disable
  183. echo 1 > /sys/devices/system/cpu/cpu6/cpuidle/state1/disable
  184. echo 1 > /sys/devices/system/cpu/cpu7/cpuidle/state1/disable
  185. echo 0 > "/sys/devices/platform/hypervisor/hypervisor:qcom,gh-watchdog/wakeup_enable"
  186. else
  187. echo N > /sys/devices/system/cpu/qcom_lpm/parameters/sleep_disabled
  188. fi
  189. echo s2idle > /sys/power/mem_sleep
  190. # Let kernel know our image version/variant/crm_version
  191. if [ -f /sys/devices/soc0/select_image ]; then
  192. image_version="10:"
  193. image_version+=`getprop ro.build.id`
  194. image_version+=":"
  195. image_version+=`getprop ro.build.version.incremental`
  196. image_variant=`getprop ro.product.name`
  197. image_variant+="-"
  198. image_variant+=`getprop ro.build.type`
  199. oem_version=`getprop ro.build.version.codename`
  200. echo 10 > /sys/devices/soc0/select_image
  201. echo $image_version > /sys/devices/soc0/image_version
  202. echo $image_variant > /sys/devices/soc0/image_variant
  203. echo $oem_version > /sys/devices/soc0/image_crm_version
  204. fi
  205. # Change console log level as per console config property
  206. console_config=`getprop persist.vendor.console.silent.config`
  207. case "$console_config" in
  208. "1")
  209. echo "Enable console config to $console_config"
  210. echo 0 > /proc/sys/kernel/printk
  211. ;;
  212. *)
  213. echo "Enable console config to $console_config"
  214. ;;
  215. esac
  216. setprop vendor.post_boot.parsed 1