1*c8dee2aaSAndroid Build Coastguard Worker# Copyright 2018 Google Inc. 2*c8dee2aaSAndroid Build Coastguard Worker# 3*c8dee2aaSAndroid Build Coastguard Worker# Use of this source code is governed by a BSD-style license that can be 4*c8dee2aaSAndroid Build Coastguard Worker# found in the LICENSE file. 5*c8dee2aaSAndroid Build Coastguard Worker 6*c8dee2aaSAndroid Build Coastguard Workerfrom _hardware import Expectation 7*c8dee2aaSAndroid Build Coastguard Workerfrom _hardware_android import HardwareAndroid 8*c8dee2aaSAndroid Build Coastguard Worker 9*c8dee2aaSAndroid Build Coastguard WorkerCPU_CLOCK_RATE = 2035200 10*c8dee2aaSAndroid Build Coastguard WorkerMEM_CLOCK_RATE = 13763 11*c8dee2aaSAndroid Build Coastguard WorkerGPU_CLOCK_RATE = 670000000 12*c8dee2aaSAndroid Build Coastguard WorkerGPU_POWER_LEVEL = 1 # lower is faster, minimum is 0 13*c8dee2aaSAndroid Build Coastguard Worker 14*c8dee2aaSAndroid Build Coastguard Workerclass HardwarePixel2(HardwareAndroid): 15*c8dee2aaSAndroid Build Coastguard Worker def __init__(self, adb): 16*c8dee2aaSAndroid Build Coastguard Worker HardwareAndroid.__init__(self, adb) 17*c8dee2aaSAndroid Build Coastguard Worker 18*c8dee2aaSAndroid Build Coastguard Worker def __enter__(self): 19*c8dee2aaSAndroid Build Coastguard Worker HardwareAndroid.__enter__(self) 20*c8dee2aaSAndroid Build Coastguard Worker if not self._adb.is_root(): 21*c8dee2aaSAndroid Build Coastguard Worker return self 22*c8dee2aaSAndroid Build Coastguard Worker 23*c8dee2aaSAndroid Build Coastguard Worker self._adb.shell('\n'.join([ 24*c8dee2aaSAndroid Build Coastguard Worker ''' 25*c8dee2aaSAndroid Build Coastguard Worker stop thermal-engine 26*c8dee2aaSAndroid Build Coastguard Worker stop perfd''', 27*c8dee2aaSAndroid Build Coastguard Worker 28*c8dee2aaSAndroid Build Coastguard Worker # turn off the slow cores and one fast core 29*c8dee2aaSAndroid Build Coastguard Worker ''' 30*c8dee2aaSAndroid Build Coastguard Worker for N in 0 1 2 3 7; do 31*c8dee2aaSAndroid Build Coastguard Worker echo 0 > /sys/devices/system/cpu/cpu$N/online 32*c8dee2aaSAndroid Build Coastguard Worker done''', 33*c8dee2aaSAndroid Build Coastguard Worker 34*c8dee2aaSAndroid Build Coastguard Worker # lock 3 fast cores: two for Skia and one for the OS 35*c8dee2aaSAndroid Build Coastguard Worker ''' 36*c8dee2aaSAndroid Build Coastguard Worker for N in 4 5 6; do 37*c8dee2aaSAndroid Build Coastguard Worker echo 1 > /sys/devices/system/cpu/cpu$N/online 38*c8dee2aaSAndroid Build Coastguard Worker echo userspace > /sys/devices/system/cpu/cpu$N/cpufreq/scaling_governor 39*c8dee2aaSAndroid Build Coastguard Worker echo %i > /sys/devices/system/cpu/cpu$N/cpufreq/scaling_max_freq 40*c8dee2aaSAndroid Build Coastguard Worker echo %i > /sys/devices/system/cpu/cpu$N/cpufreq/scaling_min_freq 41*c8dee2aaSAndroid Build Coastguard Worker echo %i > /sys/devices/system/cpu/cpu$N/cpufreq/scaling_setspeed 42*c8dee2aaSAndroid Build Coastguard Worker done''' % tuple(CPU_CLOCK_RATE for _ in range(3)), 43*c8dee2aaSAndroid Build Coastguard Worker 44*c8dee2aaSAndroid Build Coastguard Worker # Set GPU bus and idle timer 45*c8dee2aaSAndroid Build Coastguard Worker ''' 46*c8dee2aaSAndroid Build Coastguard Worker echo 0 > /sys/class/kgsl/kgsl-3d0/bus_split''', 47*c8dee2aaSAndroid Build Coastguard Worker # csmartdalton, 4-26-2018: this line hangs my device 48*c8dee2aaSAndroid Build Coastguard Worker # echo 1 > /sys/class/kgsl/kgsl-3d0/force_clk_on 49*c8dee2aaSAndroid Build Coastguard Worker ''' 50*c8dee2aaSAndroid Build Coastguard Worker echo 10000 > /sys/class/kgsl/kgsl-3d0/idle_timer''', 51*c8dee2aaSAndroid Build Coastguard Worker 52*c8dee2aaSAndroid Build Coastguard Worker # Set mem frequency to max 53*c8dee2aaSAndroid Build Coastguard Worker ''' 54*c8dee2aaSAndroid Build Coastguard Worker echo %i > /sys/class/devfreq/soc\:qcom,gpubw/min_freq 55*c8dee2aaSAndroid Build Coastguard Worker echo %i > /sys/class/devfreq/soc\:qcom,gpubw/max_freq 56*c8dee2aaSAndroid Build Coastguard Worker echo %i > /sys/class/devfreq/soc\:qcom,cpubw/min_freq 57*c8dee2aaSAndroid Build Coastguard Worker echo %i > /sys/class/devfreq/soc\:qcom,cpubw/max_freq 58*c8dee2aaSAndroid Build Coastguard Worker echo %i > /sys/class/devfreq/soc\:qcom,mincpubw/min_freq 59*c8dee2aaSAndroid Build Coastguard Worker echo %i > /sys/class/devfreq/soc\:qcom,mincpubw/max_freq 60*c8dee2aaSAndroid Build Coastguard Worker echo %i > /sys/class/devfreq/soc\:qcom,memlat-cpu0/min_freq 61*c8dee2aaSAndroid Build Coastguard Worker echo %i > /sys/class/devfreq/soc\:qcom,memlat-cpu0/max_freq''' % 62*c8dee2aaSAndroid Build Coastguard Worker tuple(MEM_CLOCK_RATE for _ in range(8)), 63*c8dee2aaSAndroid Build Coastguard Worker 64*c8dee2aaSAndroid Build Coastguard Worker # Set GPU to performance mode 65*c8dee2aaSAndroid Build Coastguard Worker ''' 66*c8dee2aaSAndroid Build Coastguard Worker echo performance > /sys/class/kgsl/kgsl-3d0/devfreq/governor 67*c8dee2aaSAndroid Build Coastguard Worker echo %i > /sys/class/kgsl/kgsl-3d0/devfreq/max_freq 68*c8dee2aaSAndroid Build Coastguard Worker echo %i > /sys/class/kgsl/kgsl-3d0/devfreq/min_freq''' % 69*c8dee2aaSAndroid Build Coastguard Worker tuple(GPU_CLOCK_RATE for _ in range(2)), 70*c8dee2aaSAndroid Build Coastguard Worker 71*c8dee2aaSAndroid Build Coastguard Worker # Set GPU power level 72*c8dee2aaSAndroid Build Coastguard Worker ''' 73*c8dee2aaSAndroid Build Coastguard Worker echo %i > /sys/class/kgsl/kgsl-3d0/max_pwrlevel 74*c8dee2aaSAndroid Build Coastguard Worker echo %i > /sys/class/kgsl/kgsl-3d0/min_pwrlevel''' % 75*c8dee2aaSAndroid Build Coastguard Worker tuple(GPU_POWER_LEVEL for _ in range(2))])) 76*c8dee2aaSAndroid Build Coastguard Worker 77*c8dee2aaSAndroid Build Coastguard Worker assert('msm_therm' == self._adb.check(\ 78*c8dee2aaSAndroid Build Coastguard Worker 'cat /sys/class/thermal/thermal_zone10/type').strip()) 79*c8dee2aaSAndroid Build Coastguard Worker assert('pm8998_tz' == self._adb.check(\ 80*c8dee2aaSAndroid Build Coastguard Worker 'cat /sys/class/thermal/thermal_zone7/type').strip()) 81*c8dee2aaSAndroid Build Coastguard Worker 82*c8dee2aaSAndroid Build Coastguard Worker return self 83*c8dee2aaSAndroid Build Coastguard Worker 84*c8dee2aaSAndroid Build Coastguard Worker def sanity_check(self): 85*c8dee2aaSAndroid Build Coastguard Worker HardwareAndroid.sanity_check(self) 86*c8dee2aaSAndroid Build Coastguard Worker 87*c8dee2aaSAndroid Build Coastguard Worker if not self._adb.is_root(): 88*c8dee2aaSAndroid Build Coastguard Worker return 89*c8dee2aaSAndroid Build Coastguard Worker 90*c8dee2aaSAndroid Build Coastguard Worker result = self._adb.check(' '.join( 91*c8dee2aaSAndroid Build Coastguard Worker ['cat', 92*c8dee2aaSAndroid Build Coastguard Worker '/sys/class/power_supply/battery/capacity', 93*c8dee2aaSAndroid Build Coastguard Worker '/sys/devices/system/cpu/online'] + \ 94*c8dee2aaSAndroid Build Coastguard Worker ['/sys/devices/system/cpu/cpu%i/cpufreq/scaling_cur_freq' % i 95*c8dee2aaSAndroid Build Coastguard Worker for i in range(4, 7)] + \ 96*c8dee2aaSAndroid Build Coastguard Worker # Unfortunately we can't monitor the gpu clock: 97*c8dee2aaSAndroid Build Coastguard Worker # 98*c8dee2aaSAndroid Build Coastguard Worker # /sys/class/kgsl/kgsl-3d0/devfreq/cur_freq 99*c8dee2aaSAndroid Build Coastguard Worker # 100*c8dee2aaSAndroid Build Coastguard Worker # It doesn't respect the min_freq/max_freq values when not under load. 101*c8dee2aaSAndroid Build Coastguard Worker ['/sys/kernel/debug/clk/bimc_clk/measure', 102*c8dee2aaSAndroid Build Coastguard Worker '/sys/class/kgsl/kgsl-3d0/temp', 103*c8dee2aaSAndroid Build Coastguard Worker '/sys/class/kgsl/kgsl-3d0/throttling', 104*c8dee2aaSAndroid Build Coastguard Worker '/sys/class/thermal/thermal_zone10/temp', 105*c8dee2aaSAndroid Build Coastguard Worker '/sys/class/thermal/thermal_zone7/temp'])) 106*c8dee2aaSAndroid Build Coastguard Worker 107*c8dee2aaSAndroid Build Coastguard Worker expectations = \ 108*c8dee2aaSAndroid Build Coastguard Worker [Expectation(int, min_value=30, name='battery', sleeptime=30*60), 109*c8dee2aaSAndroid Build Coastguard Worker Expectation(str, exact_value='4-6', name='online cpus')] + \ 110*c8dee2aaSAndroid Build Coastguard Worker [Expectation(int, exact_value=CPU_CLOCK_RATE, name='cpu_%i clock rate' %i) 111*c8dee2aaSAndroid Build Coastguard Worker for i in range(4, 7)] + \ 112*c8dee2aaSAndroid Build Coastguard Worker [Expectation(long, min_value=902390000, max_value=902409999, 113*c8dee2aaSAndroid Build Coastguard Worker name='measured ddr clock', sleeptime=10), 114*c8dee2aaSAndroid Build Coastguard Worker Expectation(int, max_value=750, name='gpu temperature'), 115*c8dee2aaSAndroid Build Coastguard Worker Expectation(int, exact_value=1, name='gpu throttling'), 116*c8dee2aaSAndroid Build Coastguard Worker Expectation(int, max_value=75, name='msm_therm temperature'), 117*c8dee2aaSAndroid Build Coastguard Worker Expectation(int, max_value=75000, name='pm8998_tz temperature')] 118*c8dee2aaSAndroid Build Coastguard Worker 119*c8dee2aaSAndroid Build Coastguard Worker Expectation.check_all(expectations, result.splitlines()) 120