blob: a42cafa5166f7b6016ebca91680baf689e3c7c73 [file] [log] [blame]
# Copyright 2018 Google Inc.
#
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
from _hardware import Expectation
from _hardware_android import HardwareAndroid
CPU_CLOCK_RATE = 2035200
MEM_CLOCK_RATE = 13763
GPU_CLOCK_RATE = 670000000
GPU_POWER_LEVEL = 1 # lower is faster, minimum is 0
class HardwarePixel2(HardwareAndroid):
def __init__(self, adb):
HardwareAndroid.__init__(self, adb)
def __enter__(self):
HardwareAndroid.__enter__(self)
if not self._adb.is_root():
return self
self._adb.shell('\n'.join([
'''
stop thermal-engine
stop perfd''',
# turn off the slow cores and one fast core
'''
for N in 0 1 2 3 7; do
echo 0 > /sys/devices/system/cpu/cpu$N/online
done''',
# lock 3 fast cores: two for Skia and one for the OS
'''
for N in 4 5 6; do
echo 1 > /sys/devices/system/cpu/cpu$N/online
echo userspace > /sys/devices/system/cpu/cpu$N/cpufreq/scaling_governor
echo %i > /sys/devices/system/cpu/cpu$N/cpufreq/scaling_max_freq
echo %i > /sys/devices/system/cpu/cpu$N/cpufreq/scaling_min_freq
echo %i > /sys/devices/system/cpu/cpu$N/cpufreq/scaling_setspeed
done''' % tuple(CPU_CLOCK_RATE for _ in range(3)),
# Set GPU bus and idle timer
'''
echo 0 > /sys/class/kgsl/kgsl-3d0/bus_split''',
# csmartdalton, 4-26-2018: this line hangs my device
# echo 1 > /sys/class/kgsl/kgsl-3d0/force_clk_on
'''
echo 10000 > /sys/class/kgsl/kgsl-3d0/idle_timer''',
# Set mem frequency to max
'''
echo %i > /sys/class/devfreq/soc\:qcom,gpubw/min_freq
echo %i > /sys/class/devfreq/soc\:qcom,gpubw/max_freq
echo %i > /sys/class/devfreq/soc\:qcom,cpubw/min_freq
echo %i > /sys/class/devfreq/soc\:qcom,cpubw/max_freq
echo %i > /sys/class/devfreq/soc\:qcom,mincpubw/min_freq
echo %i > /sys/class/devfreq/soc\:qcom,mincpubw/max_freq
echo %i > /sys/class/devfreq/soc\:qcom,memlat-cpu0/min_freq
echo %i > /sys/class/devfreq/soc\:qcom,memlat-cpu0/max_freq''' %
tuple(MEM_CLOCK_RATE for _ in range(8)),
# Set GPU to performance mode
'''
echo performance > /sys/class/kgsl/kgsl-3d0/devfreq/governor
echo %i > /sys/class/kgsl/kgsl-3d0/devfreq/max_freq
echo %i > /sys/class/kgsl/kgsl-3d0/devfreq/min_freq''' %
tuple(GPU_CLOCK_RATE for _ in range(2)),
# Set GPU power level
'''
echo %i > /sys/class/kgsl/kgsl-3d0/max_pwrlevel
echo %i > /sys/class/kgsl/kgsl-3d0/min_pwrlevel''' %
tuple(GPU_POWER_LEVEL for _ in range(2))]))
assert('msm_therm' == self._adb.check(\
'cat /sys/class/thermal/thermal_zone10/type').strip())
assert('pm8998_tz' == self._adb.check(\
'cat /sys/class/thermal/thermal_zone7/type').strip())
return self
def sanity_check(self):
HardwareAndroid.sanity_check(self)
if not self._adb.is_root():
return
result = self._adb.check(' '.join(
['cat',
'/sys/class/power_supply/battery/capacity',
'/sys/devices/system/cpu/online'] + \
['/sys/devices/system/cpu/cpu%i/cpufreq/scaling_cur_freq' % i
for i in range(4, 7)] + \
# Unfortunately we can't monitor the gpu clock:
#
# /sys/class/kgsl/kgsl-3d0/devfreq/cur_freq
#
# It doesn't respect the min_freq/max_freq values when not under load.
['/sys/kernel/debug/clk/bimc_clk/measure',
'/sys/class/kgsl/kgsl-3d0/temp',
'/sys/class/kgsl/kgsl-3d0/throttling',
'/sys/class/thermal/thermal_zone10/temp',
'/sys/class/thermal/thermal_zone7/temp']))
expectations = \
[Expectation(int, min_value=30, name='battery', sleeptime=30*60),
Expectation(str, exact_value='4-6', name='online cpus')] + \
[Expectation(int, exact_value=CPU_CLOCK_RATE, name='cpu_%i clock rate' %i)
for i in range(4, 7)] + \
[Expectation(long, min_value=902390000, max_value=902409999,
name='measured ddr clock', sleeptime=10),
Expectation(int, max_value=750, name='gpu temperature'),
Expectation(int, exact_value=1, name='gpu throttling'),
Expectation(int, max_value=75, name='msm_therm temperature'),
Expectation(int, max_value=75000, name='pm8998_tz temperature')]
Expectation.check_all(expectations, result.splitlines())