GNU Linux-libre 4.9.309-gnu1
[releases.git] / tools / testing / selftests / intel_pstate / run.sh
1 #!/bin/bash
2 #
3 # This test runs on Intel x86 based hardware which support the intel_pstate
4 # driver.  The test checks the frequency settings from the maximum turbo
5 # state to the minimum supported frequency, in decrements of 100MHz.  The
6 # test runs the aperf.c program to put load on each processor.
7 #
8 # The results are displayed in a table which indicate the "Target" state,
9 # or the requested frequency in MHz, the Actual frequency, as read from
10 # /proc/cpuinfo, the difference between the Target and Actual frequencies,
11 # and the value of MSR 0x199 (MSR_IA32_PERF_CTL) which indicates what
12 # pstate the cpu is in, and the value of
13 # /sys/devices/system/cpu/intel_pstate/max_perf_pct X maximum turbo state
14 #
15 # Notes: In some cases several frequency values may be placed in the
16 # /tmp/result.X files.  This is done on purpose in order to catch cases
17 # where the pstate driver may not be working at all.  There is the case
18 # where, for example, several "similar" frequencies are in the file:
19 #
20 #
21 #/tmp/result.3100:1:cpu MHz              : 2899.980
22 #/tmp/result.3100:2:cpu MHz              : 2900.000
23 #/tmp/result.3100:3:msr 0x199: 0x1e00
24 #/tmp/result.3100:4:max_perf_pct 94
25 #
26 # and the test will error out in those cases.  The result.X file can be checked
27 # for consistency and modified to remove the extra MHz values.  The result.X
28 # files can be re-evaluated by setting EVALUATE_ONLY to 1 below.
29
30 EVALUATE_ONLY=0
31
32 max_cpus=$(($(nproc)-1))
33
34 # compile programs
35 gcc aperf.c -Wall -D_GNU_SOURCE -o aperf  -lm
36 [ $? -ne 0 ] && echo "Problem compiling aperf.c." && exit 1
37 gcc -o msr msr.c -lm
38 [ $? -ne 0 ] && echo "Problem compiling msr.c." && exit 1
39
40 function run_test () {
41
42         file_ext=$1
43         for cpu in `seq 0 $max_cpus`
44         do
45                 echo "launching aperf load on $cpu"
46                 ./aperf $cpu &
47         done
48
49         echo "sleeping for 5 seconds"
50         sleep 5
51         grep MHz /proc/cpuinfo | sort -u > /tmp/result.freqs
52         num_freqs=$(wc -l /tmp/result.freqs | awk ' { print $1 } ')
53         if [ $num_freqs -ge 2 ]; then
54                 tail -n 1 /tmp/result.freqs > /tmp/result.$1
55         else
56                 cp /tmp/result.freqs /tmp/result.$1
57         fi
58         ./msr 0 >> /tmp/result.$1
59
60         max_perf_pct=$(cat /sys/devices/system/cpu/intel_pstate/max_perf_pct)
61         echo "max_perf_pct $max_perf_pct" >> /tmp/result.$1
62
63         for job in `jobs -p`
64         do
65                 echo "waiting for job id $job"
66                 wait $job
67         done
68 }
69
70 #
71 # MAIN (ALL UNITS IN MHZ)
72 #
73
74 # Get the marketing frequency
75 _mkt_freq=$(cat /proc/cpuinfo | grep -m 1 "model name" | awk '{print $NF}')
76 _mkt_freq=$(echo $_mkt_freq | tr -d [:alpha:][:punct:])
77 mkt_freq=${_mkt_freq}0
78
79 # Get the ranges from cpupower
80 _min_freq=$(cpupower frequency-info -l | tail -1 | awk ' { print $1 } ')
81 min_freq=$(($_min_freq / 1000))
82 _max_freq=$(cpupower frequency-info -l | tail -1 | awk ' { print $2 } ')
83 max_freq=$(($_max_freq / 1000))
84
85
86 [ $EVALUATE_ONLY -eq 0 ] && for freq in `seq $max_freq -100 $min_freq`
87 do
88         echo "Setting maximum frequency to $freq"
89         cpupower frequency-set -g powersave --max=${freq}MHz >& /dev/null
90         run_test $freq
91 done
92
93 [ $EVALUATE_ONLY -eq 0 ] && cpupower frequency-set -g powersave --max=${max_freq}MHz >& /dev/null
94
95 echo "=============================================================================="
96 echo "The marketing frequency of the cpu is $mkt_freq MHz"
97 echo "The maximum frequency of the cpu is $max_freq MHz"
98 echo "The minimum frequency of the cpu is $min_freq MHz"
99
100 # make a pretty table
101 echo "Target      Actual      Difference     MSR(0x199)     max_perf_pct"
102 for freq in `seq $max_freq -100 $min_freq`
103 do
104         result_freq=$(cat /tmp/result.${freq} | grep "cpu MHz" | awk ' { print $4 } ' | awk -F "." ' { print $1 } ')
105         msr=$(cat /tmp/result.${freq} | grep "msr" | awk ' { print $3 } ')
106         max_perf_pct=$(cat /tmp/result.${freq} | grep "max_perf_pct" | awk ' { print $2 } ' )
107         echo " $freq        $result_freq          $(($result_freq-$freq))          $msr          $(($max_perf_pct*$max_freq))"
108 done
109 exit 0