xref: /aosp_15_r20/external/skia/tools/skpbench/_hardware_pixel2.py (revision c8dee2aa9b3f27cf6c858bd81872bdeb2c07ed17)
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