|  | .TH TURBOSTAT 8 | 
|  | .SH NAME | 
|  | turbostat \- Report processor frequency and idle statistics | 
|  | .SH SYNOPSIS | 
|  | .ft B | 
|  | .B turbostat | 
|  | .RB [ "\-s" ] | 
|  | .RB [ "\-v" ] | 
|  | .RB [ "\-M MSR#" ] | 
|  | .RB command | 
|  | .br | 
|  | .B turbostat | 
|  | .RB [ "\-s" ] | 
|  | .RB [ "\-v" ] | 
|  | .RB [ "\-M MSR#" ] | 
|  | .RB [ "\-i interval_sec" ] | 
|  | .SH DESCRIPTION | 
|  | \fBturbostat \fP reports processor topology, frequency | 
|  | and idle power state statistics on modern X86 processors. | 
|  | Either \fBcommand\fP is forked and statistics are printed | 
|  | upon its completion, or statistics are printed periodically. | 
|  |  | 
|  | \fBturbostat \fP | 
|  | requires that the processor | 
|  | supports an "invariant" TSC, plus the APERF and MPERF MSRs. | 
|  | \fBturbostat \fP will report idle cpu power state residency | 
|  | on processors that additionally support C-state residency counters. | 
|  |  | 
|  | .SS Options | 
|  | The \fB-s\fP option limits output to a 1-line system summary for each interval. | 
|  | .PP | 
|  | The \fB-c\fP option limits output to the 1st thread in each core. | 
|  | .PP | 
|  | The \fB-p\fP option limits output to the 1st thread in each package. | 
|  | .PP | 
|  | The \fB-v\fP option increases verbosity. | 
|  | .PP | 
|  | The \fB-M MSR#\fP option dumps the specified MSR, | 
|  | in addition to the usual frequency and idle statistics. | 
|  | .PP | 
|  | The \fB-i interval_sec\fP option prints statistics every \fiinterval_sec\fP seconds. | 
|  | The default is 5 seconds. | 
|  | .PP | 
|  | The \fBcommand\fP parameter forks \fBcommand\fP and upon its exit, | 
|  | displays the statistics gathered since it was forked. | 
|  | .PP | 
|  | .SH FIELD DESCRIPTIONS | 
|  | .nf | 
|  | \fBpk\fP processor package number. | 
|  | \fBcor\fP processor core number. | 
|  | \fBCPU\fP Linux CPU (logical processor) number. | 
|  | Note that multiple CPUs per core indicate support for Intel(R) Hyper-Threading Technology. | 
|  | \fB%c0\fP percent of the interval that the CPU retired instructions. | 
|  | \fBGHz\fP average clock rate while the CPU was in c0 state. | 
|  | \fBTSC\fP average GHz that the TSC ran during the entire interval. | 
|  | \fB%c1, %c3, %c6, %c7\fP show the percentage residency in hardware core idle states. | 
|  | \fB%pc2, %pc3, %pc6, %pc7\fP percentage residency in hardware package idle states. | 
|  | .fi | 
|  | .PP | 
|  | .SH EXAMPLE | 
|  | Without any parameters, turbostat prints out counters ever 5 seconds. | 
|  | (override interval with "-i sec" option, or specify a command | 
|  | for turbostat to fork). | 
|  |  | 
|  | The first row of statistics is a summary for the entire system. | 
|  | Note that the summary is a weighted average. | 
|  | Subsequent rows show per-CPU statistics. | 
|  |  | 
|  | .nf | 
|  | [root@x980]# ./turbostat | 
|  | cor CPU    %c0  GHz  TSC    %c1    %c3    %c6   %pc3   %pc6 | 
|  | 0.09 1.62 3.38   1.83   0.32  97.76   1.26  83.61 | 
|  | 0   0   0.15 1.62 3.38  10.23   0.05  89.56   1.26  83.61 | 
|  | 0   6   0.05 1.62 3.38  10.34 | 
|  | 1   2   0.03 1.62 3.38   0.07   0.05  99.86 | 
|  | 1   8   0.03 1.62 3.38   0.06 | 
|  | 2   4   0.21 1.62 3.38   0.10   1.49  98.21 | 
|  | 2  10   0.02 1.62 3.38   0.29 | 
|  | 8   1   0.04 1.62 3.38   0.04   0.08  99.84 | 
|  | 8   7   0.01 1.62 3.38   0.06 | 
|  | 9   3   0.53 1.62 3.38   0.10   0.20  99.17 | 
|  | 9   9   0.02 1.62 3.38   0.60 | 
|  | 10   5   0.01 1.62 3.38   0.02   0.04  99.92 | 
|  | 10  11   0.02 1.62 3.38   0.02 | 
|  | .fi | 
|  | .SH SUMMARY EXAMPLE | 
|  | The "-s" option prints the column headers just once, | 
|  | and then the one line system summary for each sample interval. | 
|  |  | 
|  | .nf | 
|  | [root@x980]# ./turbostat -s | 
|  | %c0  GHz  TSC    %c1    %c3    %c6   %pc3   %pc6 | 
|  | 0.23 1.67 3.38   2.00   0.30  97.47   1.07  82.12 | 
|  | 0.10 1.62 3.38   1.87   2.25  95.77  12.02  72.60 | 
|  | 0.20 1.64 3.38   1.98   0.11  97.72   0.30  83.36 | 
|  | 0.11 1.70 3.38   1.86   1.81  96.22   9.71  74.90 | 
|  | .fi | 
|  | .SH VERBOSE EXAMPLE | 
|  | The "-v" option adds verbosity to the output: | 
|  |  | 
|  | .nf | 
|  | GenuineIntel 11 CPUID levels; family:model:stepping 0x6:2c:2 (6:44:2) | 
|  | 12 * 133 = 1600 MHz max efficiency | 
|  | 25 * 133 = 3333 MHz TSC frequency | 
|  | 26 * 133 = 3467 MHz max turbo 4 active cores | 
|  | 26 * 133 = 3467 MHz max turbo 3 active cores | 
|  | 27 * 133 = 3600 MHz max turbo 2 active cores | 
|  | 27 * 133 = 3600 MHz max turbo 1 active cores | 
|  |  | 
|  | .fi | 
|  | The \fBmax efficiency\fP frequency, a.k.a. Low Frequency Mode, is the frequency | 
|  | available at the minimum package voltage.  The \fBTSC frequency\fP is the nominal | 
|  | maximum frequency of the processor if turbo-mode were not available.  This frequency | 
|  | should be sustainable on all CPUs indefinitely, given nominal power and cooling. | 
|  | The remaining rows show what maximum turbo frequency is possible | 
|  | depending on the number of idle cores.  Note that this information is | 
|  | not available on all processors. | 
|  | .SH FORK EXAMPLE | 
|  | If turbostat is invoked with a command, it will fork that command | 
|  | and output the statistics gathered when the command exits. | 
|  | eg. Here a cycle soaker is run on 1 CPU (see %c0) for a few seconds | 
|  | until ^C while the other CPUs are mostly idle: | 
|  |  | 
|  | .nf | 
|  | [root@x980 lenb]# ./turbostat cat /dev/zero > /dev/null | 
|  | ^C | 
|  | cor CPU    %c0  GHz  TSC    %c1    %c3    %c6   %pc3   %pc6 | 
|  | 8.86 3.61 3.38  15.06  31.19  44.89   0.00   0.00 | 
|  | 0   0   1.46 3.22 3.38  16.84  29.48  52.22   0.00   0.00 | 
|  | 0   6   0.21 3.06 3.38  18.09 | 
|  | 1   2   0.53 3.33 3.38   2.80  46.40  50.27 | 
|  | 1   8   0.89 3.47 3.38   2.44 | 
|  | 2   4   1.36 3.43 3.38   9.04  23.71  65.89 | 
|  | 2  10   0.18 2.86 3.38  10.22 | 
|  | 8   1   0.04 2.87 3.38  99.96   0.01   0.00 | 
|  | 8   7  99.72 3.63 3.38   0.27 | 
|  | 9   3   0.31 3.21 3.38   7.64  56.55  35.50 | 
|  | 9   9   0.08 2.95 3.38   7.88 | 
|  | 10   5   1.42 3.43 3.38   2.14  30.99  65.44 | 
|  | 10  11   0.16 2.88 3.38   3.40 | 
|  | .fi | 
|  | Above the cycle soaker drives cpu7 up its 3.6 Ghz turbo limit | 
|  | while the other processors are generally in various states of idle. | 
|  |  | 
|  | Note that cpu1 and cpu7 are HT siblings within core8. | 
|  | As cpu7 is very busy, it prevents its sibling, cpu1, | 
|  | from entering a c-state deeper than c1. | 
|  |  | 
|  | Note that turbostat reports average GHz of 3.63, while | 
|  | the arithmetic average of the GHz column above is lower. | 
|  | This is a weighted average, where the weight is %c0.  ie. it is the total number of | 
|  | un-halted cycles elapsed per time divided by the number of CPUs. | 
|  | .SH NOTES | 
|  |  | 
|  | .B "turbostat " | 
|  | must be run as root. | 
|  |  | 
|  | .B "turbostat " | 
|  | reads hardware counters, but doesn't write them. | 
|  | So it will not interfere with the OS or other programs, including | 
|  | multiple invocations of itself. | 
|  |  | 
|  | \fBturbostat \fP | 
|  | may work poorly on Linux-2.6.20 through 2.6.29, | 
|  | as \fBacpi-cpufreq \fPperiodically cleared the APERF and MPERF | 
|  | in those kernels. | 
|  |  | 
|  | The APERF, MPERF MSRs are defined to count non-halted cycles. | 
|  | Although it is not guaranteed by the architecture, turbostat assumes | 
|  | that they count at TSC rate, which is true on all processors tested to date. | 
|  |  | 
|  | .SH REFERENCES | 
|  | "Intel® Turbo Boost Technology | 
|  | in Intel® Core™ Microarchitecture (Nehalem) Based Processors" | 
|  | http://download.intel.com/design/processor/applnots/320354.pdf | 
|  |  | 
|  | "Intel® 64 and IA-32 Architectures Software Developer's Manual | 
|  | Volume 3B: System Programming Guide" | 
|  | http://www.intel.com/products/processor/manuals/ | 
|  |  | 
|  | .SH FILES | 
|  | .ta | 
|  | .nf | 
|  | /dev/cpu/*/msr | 
|  | .fi | 
|  |  | 
|  | .SH "SEE ALSO" | 
|  | msr(4), vmstat(8) | 
|  | .PP | 
|  | .SH AUTHOR | 
|  | .nf | 
|  | Written by Len Brown <len.brown@intel.com> |