init.kernel.post_boot-cape.sh 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227
  1. #=============================================================================
  2. # Copyright (c) 2021-2022 Qualcomm Technologies, Inc.
  3. # All Rights Reserved.
  4. # Confidential and Proprietary - Qualcomm Technologies, Inc.
  5. #=============================================================================
  6. rev=`cat /sys/devices/soc0/revision`
  7. ddr_type=`od -An -tx /proc/device-tree/memory/ddr_device_type`
  8. ddr_type4="07"
  9. ddr_type5="08"
  10. # Core control parameters for gold
  11. echo 2 > /sys/devices/system/cpu/cpu4/core_ctl/min_cpus
  12. echo 60 > /sys/devices/system/cpu/cpu4/core_ctl/busy_up_thres
  13. echo 30 > /sys/devices/system/cpu/cpu4/core_ctl/busy_down_thres
  14. echo 100 > /sys/devices/system/cpu/cpu4/core_ctl/offline_delay_ms
  15. echo 3 > /sys/devices/system/cpu/cpu4/core_ctl/task_thres
  16. # Core control parameters for gold+
  17. echo 0 > /sys/devices/system/cpu/cpu7/core_ctl/min_cpus
  18. echo 60 > /sys/devices/system/cpu/cpu7/core_ctl/busy_up_thres
  19. echo 30 > /sys/devices/system/cpu/cpu7/core_ctl/busy_down_thres
  20. echo 100 > /sys/devices/system/cpu/cpu7/core_ctl/offline_delay_ms
  21. echo 1 > /sys/devices/system/cpu/cpu7/core_ctl/task_thres
  22. # Controls how many more tasks should be eligible to run on gold CPUs
  23. # w.r.t number of gold CPUs available to trigger assist (max number of
  24. # tasks eligible to run on previous cluster minus number of CPUs in
  25. # the previous cluster).
  26. #
  27. # Setting to 1 by default which means there should be at least
  28. # 4 tasks eligible to run on gold cluster (tasks running on gold cores
  29. # plus misfit tasks on silver cores) to trigger assitance from gold+.
  30. echo 1 > /sys/devices/system/cpu/cpu7/core_ctl/nr_prev_assist_thresh
  31. # Disable Core control on silver
  32. echo 0 > /sys/devices/system/cpu/cpu0/core_ctl/enable
  33. # Setting b.L scheduler parameters
  34. echo 85 85 > /proc/sys/walt/sched_downmigrate
  35. echo 95 95 > /proc/sys/walt/sched_upmigrate
  36. echo 85 > /proc/sys/walt/sched_group_downmigrate
  37. echo 100 > /proc/sys/walt/sched_group_upmigrate
  38. echo 1 > /proc/sys/walt/sched_walt_rotate_big_tasks
  39. echo 400000000 > /proc/sys/walt/sched_coloc_downmigrate_ns
  40. echo 39000000 39000000 39000000 39000000 39000000 39000000 39000000 5000000 > /proc/sys/walt/sched_coloc_busy_hyst_cpu_ns
  41. echo 240 > /proc/sys/walt/sched_coloc_busy_hysteresis_enable_cpus
  42. echo 10 10 10 10 10 10 10 95 > /proc/sys/walt/sched_coloc_busy_hyst_cpu_busy_pct
  43. echo 5000000 5000000 5000000 5000000 5000000 5000000 5000000 2000000 > /proc/sys/walt/sched_util_busy_hyst_cpu_ns
  44. echo 255 > /proc/sys/walt/sched_util_busy_hysteresis_enable_cpus
  45. echo 15 15 15 15 15 15 15 15 > /proc/sys/walt/sched_util_busy_hyst_cpu_util
  46. # set the threshold for low latency task boost feature which prioritize
  47. # binder activity tasks
  48. echo 325 > /proc/sys/walt/walt_low_latency_task_threshold
  49. # cpuset parameters
  50. echo 0-2 > /dev/cpuset/background/cpus
  51. echo 0-3 > /dev/cpuset/system-background/cpus
  52. echo 4-7 > /dev/cpuset/foreground/boost/cpus
  53. echo 0-2,4-7 > /dev/cpuset/foreground/cpus
  54. echo 0-7 > /dev/cpuset/top-app/cpus
  55. echo 0-7 > /dev/cpuset/audio-app/cpus
  56. # Turn off scheduler boost at the end
  57. echo 0 > /proc/sys/walt/sched_boost
  58. # Reset the RT boost, which is 1024 (max) by default.
  59. echo 0 > /proc/sys/kernel/sched_util_clamp_min_rt_default
  60. # configure governor settings for silver cluster
  61. echo "walt" > /sys/devices/system/cpu/cpufreq/policy0/scaling_governor
  62. echo 0 > /sys/devices/system/cpu/cpufreq/policy0/walt/down_rate_limit_us
  63. echo 0 > /sys/devices/system/cpu/cpufreq/policy0/walt/up_rate_limit_us
  64. echo 1228800 > /sys/devices/system/cpu/cpufreq/policy0/walt/hispeed_freq
  65. echo 556800 > /sys/devices/system/cpu/cpufreq/policy0/scaling_min_freq
  66. echo 1804800 > /sys/devices/system/cpu/cpufreq/policy0/scaling_max_freq
  67. echo 1 > /sys/devices/system/cpu/cpufreq/policy0/walt/pl
  68. # configure input boost settings
  69. echo 1228800 0 0 0 0 0 0 0 > /proc/sys/walt/input_boost/input_boost_freq
  70. echo 120 > /proc/sys/walt/input_boost/input_boost_ms
  71. echo 1785600 0 0 0 2169600 0 0 2419200 > /proc/sys/walt/input_boost/powerkey_input_boost_freq
  72. echo 120 > /proc/sys/walt/input_boost/powerkey_input_boost_ms
  73. # configure governor settings for gold cluster
  74. echo "walt" > /sys/devices/system/cpu/cpufreq/policy4/scaling_governor
  75. echo 0 > /sys/devices/system/cpu/cpufreq/policy4/walt/down_rate_limit_us
  76. echo 0 > /sys/devices/system/cpu/cpufreq/policy4/walt/up_rate_limit_us
  77. echo 1555200 > /sys/devices/system/cpu/cpufreq/policy4/walt/hispeed_freq
  78. echo 1 > /sys/devices/system/cpu/cpufreq/policy4/walt/pl
  79. # configure governor settings for gold+ cluster
  80. echo "walt" > /sys/devices/system/cpu/cpufreq/policy7/scaling_governor
  81. echo 0 > /sys/devices/system/cpu/cpufreq/policy7/walt/down_rate_limit_us
  82. echo 0 > /sys/devices/system/cpu/cpufreq/policy7/walt/up_rate_limit_us
  83. echo 1651200 > /sys/devices/system/cpu/cpufreq/policy7/walt/hispeed_freq
  84. echo 1 > /sys/devices/system/cpu/cpufreq/policy7/walt/pl
  85. # colocation V3 settings
  86. echo 768000 > /sys/devices/system/cpu/cpufreq/policy4/walt/rtg_boost_freq
  87. # configure bus-dcvs
  88. bus_dcvs="/sys/devices/system/cpu/bus_dcvs"
  89. for device in $bus_dcvs/*
  90. do
  91. cat $device/hw_min_freq > $device/boost_freq
  92. done
  93. for llccbw in $bus_dcvs/LLCC/*bwmon-llcc
  94. do
  95. echo "4577 7110 9155 12298 14236 15258" > $llccbw/mbps_zones
  96. echo 4 > $llccbw/sample_ms
  97. echo 80 > $llccbw/io_percent
  98. echo 20 > $llccbw/hist_memory
  99. echo 10 > $llccbw/hyst_length
  100. echo 30 > $llccbw/down_thres
  101. echo 0 > $llccbw/guard_band_mbps
  102. echo 250 > $llccbw/up_scale
  103. echo 1600 > $llccbw/idle_mbps
  104. echo 806000 > $llccbw/max_freq
  105. echo 40 > $llccbw/window_ms
  106. done
  107. for ddrbw in $bus_dcvs/DDR/*bwmon-ddr
  108. do
  109. echo "1720 2086 2929 3879 6515 7980 12191" > $ddrbw/mbps_zones
  110. echo 4 > $ddrbw/sample_ms
  111. echo 80 > $ddrbw/io_percent
  112. echo 20 > $ddrbw/hist_memory
  113. echo 10 > $ddrbw/hyst_length
  114. echo 30 > $ddrbw/down_thres
  115. echo 0 > $ddrbw/guard_band_mbps
  116. echo 250 > $ddrbw/up_scale
  117. echo 1600 > $ddrbw/idle_mbps
  118. echo 2092000 > $ddrbw/max_freq
  119. echo 40 > $ddrbw/window_ms
  120. done
  121. for latfloor in $bus_dcvs/*/*latfloor
  122. do
  123. echo 25000 > $latfloor/ipm_ceil
  124. done
  125. for l3silver in $bus_dcvs/L3/*silver
  126. do
  127. echo 1708800 > $l3silver/max_freq
  128. done
  129. for l3gold in $bus_dcvs/L3/*gold
  130. do
  131. echo 4000 > $l3gold/ipm_ceil
  132. echo 1708800 > $l3gold/max_freq
  133. done
  134. for l3prime in $bus_dcvs/L3/*prime
  135. do
  136. echo 20000 > $l3prime/ipm_ceil
  137. echo 1708800 > $l3prime/max_freq
  138. done
  139. for l3pcompute in $bus_dcvs/L3/*prime-compute
  140. do
  141. echo 1708800 > $l3pcompute/max_freq
  142. done
  143. for ddrprime in $bus_dcvs/DDR/*prime
  144. do
  145. echo 25 > $ddrprime/freq_scale_pct
  146. echo 1881 > $ddrprime/freq_scale_limit_mhz
  147. done
  148. for qosgold in $bus_dcvs/DDRQOS/*gold
  149. do
  150. echo 50 > $qosgold/ipm_ceil
  151. done
  152. echo 0 > /sys/kernel/msm_performance/parameters/splh_log_level
  153. #set s2idle as default
  154. echo s2idle > /sys/power/mem_sleep
  155. #Enable LPM
  156. echo N > /sys/devices/system/cpu/qcom_lpm/parameters/sleep_disabled
  157. # Let kernel know our image version/variant/crm_version
  158. if [ -f /sys/devices/soc0/select_image ]; then
  159. image_version="10:"
  160. image_version+=`getprop ro.build.id`
  161. image_version+=":"
  162. image_version+=`getprop ro.build.version.incremental`
  163. image_variant=`getprop ro.product.name`
  164. image_variant+="-"
  165. image_variant+=`getprop ro.build.type`
  166. oem_version=`getprop ro.build.version.codename`
  167. echo 10 > /sys/devices/soc0/select_image
  168. echo $image_version > /sys/devices/soc0/image_version
  169. echo $image_variant > /sys/devices/soc0/image_variant
  170. echo $oem_version > /sys/devices/soc0/image_crm_version
  171. fi
  172. # Change console log level as per console config property
  173. console_config=`getprop persist.vendor.console.silent.config`
  174. case "$console_config" in
  175. "1")
  176. echo "Enable console config to $console_config"
  177. echo 0 > /proc/sys/kernel/printk
  178. ;;
  179. *)
  180. echo "Enable console config to $console_config"
  181. ;;
  182. esac
  183. setprop vendor.post_boot.parsed 1
  184. #Limit the dmabuf pool for zizhan
  185. vendor_name=`getprop ro.product.vendor.name`
  186. case "$vendor_name" in
  187. "zizhan")
  188. echo 120000 > /sys/kernel/dma_mi_pool/msm_total_pools_max
  189. ;;
  190. *)
  191. ;;
  192. esac