| 
									
										
										
										
											2009-04-20 15:37:32 +02:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2009-06-02 23:37:05 +02:00
										 |  |  |  * builtin-stat.c | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Builtin stat command: Give a precise performance counters summary | 
					
						
							|  |  |  |  * overview about any workload, CPU or specific PID. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Sample output: | 
					
						
							| 
									
										
										
										
											2009-04-20 15:37:32 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												perf stat: Add -d -d and -d -d -d options to show more CPU events
Print even more detailed statistics if requested via perf stat -d:
       -d:          detailed events, L1 and LLC data cache
    -d -d:     more detailed events, dTLB and iTLB events
 -d -d -d:     very detailed events, adding prefetch events
Full output looks like this now:
 Performance counter stats for '/home/mingo/hackbench 10' (5 runs):
       1703.674707 task-clock                #    8.709 CPUs utilized            ( +-  4.19% )
            49,068 context-switches          #    0.029 M/sec                    ( +- 16.66% )
             8,303 CPU-migrations            #    0.005 M/sec                    ( +- 24.90% )
            17,397 page-faults               #    0.010 M/sec                    ( +-  0.46% )
     2,345,389,239 cycles                    #    1.377 GHz                      ( +-  4.61% ) [55.90%]
     1,884,503,527 stalled-cycles-frontend   #   80.35% frontend cycles idle     ( +-  5.67% ) [50.39%]
       743,919,737 stalled-cycles-backend    #   31.72% backend  cycles idle     ( +-  8.75% ) [49.91%]
     1,314,416,379 instructions              #    0.56  insns per cycle
                                             #    1.43  stalled cycles per insn  ( +-  2.53% ) [60.87%]
       272,592,567 branches                  #  160.003 M/sec                    ( +-  1.74% ) [56.56%]
         3,794,846 branch-misses             #    1.39% of all branches          ( +-  6.59% ) [58.50%]
       449,982,778 L1-dcache-loads           #  264.125 M/sec                    ( +-  2.47% ) [49.88%]
        22,404,961 L1-dcache-load-misses     #    4.98% of all L1-dcache hits    ( +-  6.08% ) [55.05%]
         6,204,750 LLC-loads                 #    3.642 M/sec                    ( +-  8.91% ) [43.75%]
         1,837,411 LLC-load-misses           #    1.078 M/sec                    ( +-  7.27% ) [12.07%]
       411,440,421 L1-icache-loads           #  241.502 M/sec                    ( +-  5.60% ) [36.52%]
        27,556,832 L1-icache-load-misses     #   16.175 M/sec                    ( +-  7.46% ) [46.72%]
       464,067,627 dTLB-loads                #  272.392 M/sec                    ( +-  4.46% ) [54.17%]
        10,765,648 dTLB-load-misses          #    6.319 M/sec                    ( +-  3.18% ) [48.68%]
     1,273,080,386 iTLB-loads                #  747.256 M/sec                    ( +-  3.38% ) [47.53%]
           117,481 iTLB-load-misses          #    0.069 M/sec                    ( +- 14.99% ) [47.01%]
         4,590,653 L1-dcache-prefetches      #    2.695 M/sec                    ( +-  4.49% ) [46.19%]
         1,712,660 L1-dcache-prefetch-misses #    1.005 M/sec                    ( +-  3.75% ) [44.82%]
        0.195622057  seconds time elapsed  ( +-  6.84% )
Also clean up the attribute construction code to be appending, and factor
it out into add_default_attributes().
Tweak the coverage percentage printout a bit, so that it's easier to view it
alongside the +- sttddev colum.
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Steven Rostedt <rostedt@goodmis.org>
Link: http://lkml.kernel.org/n/tip-to3kgu04449s64062val8b62@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-05-19 13:30:56 +02:00
										 |  |  |    $ perf stat ./hackbench 10 | 
					
						
							| 
									
										
										
										
											2009-04-20 15:37:32 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												perf stat: Add -d -d and -d -d -d options to show more CPU events
Print even more detailed statistics if requested via perf stat -d:
       -d:          detailed events, L1 and LLC data cache
    -d -d:     more detailed events, dTLB and iTLB events
 -d -d -d:     very detailed events, adding prefetch events
Full output looks like this now:
 Performance counter stats for '/home/mingo/hackbench 10' (5 runs):
       1703.674707 task-clock                #    8.709 CPUs utilized            ( +-  4.19% )
            49,068 context-switches          #    0.029 M/sec                    ( +- 16.66% )
             8,303 CPU-migrations            #    0.005 M/sec                    ( +- 24.90% )
            17,397 page-faults               #    0.010 M/sec                    ( +-  0.46% )
     2,345,389,239 cycles                    #    1.377 GHz                      ( +-  4.61% ) [55.90%]
     1,884,503,527 stalled-cycles-frontend   #   80.35% frontend cycles idle     ( +-  5.67% ) [50.39%]
       743,919,737 stalled-cycles-backend    #   31.72% backend  cycles idle     ( +-  8.75% ) [49.91%]
     1,314,416,379 instructions              #    0.56  insns per cycle
                                             #    1.43  stalled cycles per insn  ( +-  2.53% ) [60.87%]
       272,592,567 branches                  #  160.003 M/sec                    ( +-  1.74% ) [56.56%]
         3,794,846 branch-misses             #    1.39% of all branches          ( +-  6.59% ) [58.50%]
       449,982,778 L1-dcache-loads           #  264.125 M/sec                    ( +-  2.47% ) [49.88%]
        22,404,961 L1-dcache-load-misses     #    4.98% of all L1-dcache hits    ( +-  6.08% ) [55.05%]
         6,204,750 LLC-loads                 #    3.642 M/sec                    ( +-  8.91% ) [43.75%]
         1,837,411 LLC-load-misses           #    1.078 M/sec                    ( +-  7.27% ) [12.07%]
       411,440,421 L1-icache-loads           #  241.502 M/sec                    ( +-  5.60% ) [36.52%]
        27,556,832 L1-icache-load-misses     #   16.175 M/sec                    ( +-  7.46% ) [46.72%]
       464,067,627 dTLB-loads                #  272.392 M/sec                    ( +-  4.46% ) [54.17%]
        10,765,648 dTLB-load-misses          #    6.319 M/sec                    ( +-  3.18% ) [48.68%]
     1,273,080,386 iTLB-loads                #  747.256 M/sec                    ( +-  3.38% ) [47.53%]
           117,481 iTLB-load-misses          #    0.069 M/sec                    ( +- 14.99% ) [47.01%]
         4,590,653 L1-dcache-prefetches      #    2.695 M/sec                    ( +-  4.49% ) [46.19%]
         1,712,660 L1-dcache-prefetch-misses #    1.005 M/sec                    ( +-  3.75% ) [44.82%]
        0.195622057  seconds time elapsed  ( +-  6.84% )
Also clean up the attribute construction code to be appending, and factor
it out into add_default_attributes().
Tweak the coverage percentage printout a bit, so that it's easier to view it
alongside the +- sttddev colum.
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Steven Rostedt <rostedt@goodmis.org>
Link: http://lkml.kernel.org/n/tip-to3kgu04449s64062val8b62@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-05-19 13:30:56 +02:00
										 |  |  |   Time: 0.118 | 
					
						
							| 
									
										
										
										
											2009-04-20 15:37:32 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												perf stat: Add -d -d and -d -d -d options to show more CPU events
Print even more detailed statistics if requested via perf stat -d:
       -d:          detailed events, L1 and LLC data cache
    -d -d:     more detailed events, dTLB and iTLB events
 -d -d -d:     very detailed events, adding prefetch events
Full output looks like this now:
 Performance counter stats for '/home/mingo/hackbench 10' (5 runs):
       1703.674707 task-clock                #    8.709 CPUs utilized            ( +-  4.19% )
            49,068 context-switches          #    0.029 M/sec                    ( +- 16.66% )
             8,303 CPU-migrations            #    0.005 M/sec                    ( +- 24.90% )
            17,397 page-faults               #    0.010 M/sec                    ( +-  0.46% )
     2,345,389,239 cycles                    #    1.377 GHz                      ( +-  4.61% ) [55.90%]
     1,884,503,527 stalled-cycles-frontend   #   80.35% frontend cycles idle     ( +-  5.67% ) [50.39%]
       743,919,737 stalled-cycles-backend    #   31.72% backend  cycles idle     ( +-  8.75% ) [49.91%]
     1,314,416,379 instructions              #    0.56  insns per cycle
                                             #    1.43  stalled cycles per insn  ( +-  2.53% ) [60.87%]
       272,592,567 branches                  #  160.003 M/sec                    ( +-  1.74% ) [56.56%]
         3,794,846 branch-misses             #    1.39% of all branches          ( +-  6.59% ) [58.50%]
       449,982,778 L1-dcache-loads           #  264.125 M/sec                    ( +-  2.47% ) [49.88%]
        22,404,961 L1-dcache-load-misses     #    4.98% of all L1-dcache hits    ( +-  6.08% ) [55.05%]
         6,204,750 LLC-loads                 #    3.642 M/sec                    ( +-  8.91% ) [43.75%]
         1,837,411 LLC-load-misses           #    1.078 M/sec                    ( +-  7.27% ) [12.07%]
       411,440,421 L1-icache-loads           #  241.502 M/sec                    ( +-  5.60% ) [36.52%]
        27,556,832 L1-icache-load-misses     #   16.175 M/sec                    ( +-  7.46% ) [46.72%]
       464,067,627 dTLB-loads                #  272.392 M/sec                    ( +-  4.46% ) [54.17%]
        10,765,648 dTLB-load-misses          #    6.319 M/sec                    ( +-  3.18% ) [48.68%]
     1,273,080,386 iTLB-loads                #  747.256 M/sec                    ( +-  3.38% ) [47.53%]
           117,481 iTLB-load-misses          #    0.069 M/sec                    ( +- 14.99% ) [47.01%]
         4,590,653 L1-dcache-prefetches      #    2.695 M/sec                    ( +-  4.49% ) [46.19%]
         1,712,660 L1-dcache-prefetch-misses #    1.005 M/sec                    ( +-  3.75% ) [44.82%]
        0.195622057  seconds time elapsed  ( +-  6.84% )
Also clean up the attribute construction code to be appending, and factor
it out into add_default_attributes().
Tweak the coverage percentage printout a bit, so that it's easier to view it
alongside the +- sttddev colum.
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Steven Rostedt <rostedt@goodmis.org>
Link: http://lkml.kernel.org/n/tip-to3kgu04449s64062val8b62@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-05-19 13:30:56 +02:00
										 |  |  |   Performance counter stats for './hackbench 10': | 
					
						
							| 
									
										
										
										
											2009-04-20 15:37:32 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												perf stat: Add -d -d and -d -d -d options to show more CPU events
Print even more detailed statistics if requested via perf stat -d:
       -d:          detailed events, L1 and LLC data cache
    -d -d:     more detailed events, dTLB and iTLB events
 -d -d -d:     very detailed events, adding prefetch events
Full output looks like this now:
 Performance counter stats for '/home/mingo/hackbench 10' (5 runs):
       1703.674707 task-clock                #    8.709 CPUs utilized            ( +-  4.19% )
            49,068 context-switches          #    0.029 M/sec                    ( +- 16.66% )
             8,303 CPU-migrations            #    0.005 M/sec                    ( +- 24.90% )
            17,397 page-faults               #    0.010 M/sec                    ( +-  0.46% )
     2,345,389,239 cycles                    #    1.377 GHz                      ( +-  4.61% ) [55.90%]
     1,884,503,527 stalled-cycles-frontend   #   80.35% frontend cycles idle     ( +-  5.67% ) [50.39%]
       743,919,737 stalled-cycles-backend    #   31.72% backend  cycles idle     ( +-  8.75% ) [49.91%]
     1,314,416,379 instructions              #    0.56  insns per cycle
                                             #    1.43  stalled cycles per insn  ( +-  2.53% ) [60.87%]
       272,592,567 branches                  #  160.003 M/sec                    ( +-  1.74% ) [56.56%]
         3,794,846 branch-misses             #    1.39% of all branches          ( +-  6.59% ) [58.50%]
       449,982,778 L1-dcache-loads           #  264.125 M/sec                    ( +-  2.47% ) [49.88%]
        22,404,961 L1-dcache-load-misses     #    4.98% of all L1-dcache hits    ( +-  6.08% ) [55.05%]
         6,204,750 LLC-loads                 #    3.642 M/sec                    ( +-  8.91% ) [43.75%]
         1,837,411 LLC-load-misses           #    1.078 M/sec                    ( +-  7.27% ) [12.07%]
       411,440,421 L1-icache-loads           #  241.502 M/sec                    ( +-  5.60% ) [36.52%]
        27,556,832 L1-icache-load-misses     #   16.175 M/sec                    ( +-  7.46% ) [46.72%]
       464,067,627 dTLB-loads                #  272.392 M/sec                    ( +-  4.46% ) [54.17%]
        10,765,648 dTLB-load-misses          #    6.319 M/sec                    ( +-  3.18% ) [48.68%]
     1,273,080,386 iTLB-loads                #  747.256 M/sec                    ( +-  3.38% ) [47.53%]
           117,481 iTLB-load-misses          #    0.069 M/sec                    ( +- 14.99% ) [47.01%]
         4,590,653 L1-dcache-prefetches      #    2.695 M/sec                    ( +-  4.49% ) [46.19%]
         1,712,660 L1-dcache-prefetch-misses #    1.005 M/sec                    ( +-  3.75% ) [44.82%]
        0.195622057  seconds time elapsed  ( +-  6.84% )
Also clean up the attribute construction code to be appending, and factor
it out into add_default_attributes().
Tweak the coverage percentage printout a bit, so that it's easier to view it
alongside the +- sttddev colum.
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Steven Rostedt <rostedt@goodmis.org>
Link: http://lkml.kernel.org/n/tip-to3kgu04449s64062val8b62@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-05-19 13:30:56 +02:00
										 |  |  |        1708.761321 task-clock                #   11.037 CPUs utilized | 
					
						
							|  |  |  |             41,190 context-switches          #    0.024 M/sec | 
					
						
							|  |  |  |              6,735 CPU-migrations            #    0.004 M/sec | 
					
						
							|  |  |  |             17,318 page-faults               #    0.010 M/sec | 
					
						
							|  |  |  |      5,205,202,243 cycles                    #    3.046 GHz | 
					
						
							|  |  |  |      3,856,436,920 stalled-cycles-frontend   #   74.09% frontend cycles idle | 
					
						
							|  |  |  |      1,600,790,871 stalled-cycles-backend    #   30.75% backend  cycles idle | 
					
						
							|  |  |  |      2,603,501,247 instructions              #    0.50  insns per cycle | 
					
						
							|  |  |  |                                              #    1.48  stalled cycles per insn
 | 
					
						
							|  |  |  |        484,357,498 branches                  #  283.455 M/sec | 
					
						
							|  |  |  |          6,388,934 branch-misses             #    1.32% of all branches | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         0.154822978  seconds time elapsed | 
					
						
							| 
									
										
										
										
											2009-04-20 15:37:32 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-26 09:17:18 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
											  
											
												perf stat: Add -d -d and -d -d -d options to show more CPU events
Print even more detailed statistics if requested via perf stat -d:
       -d:          detailed events, L1 and LLC data cache
    -d -d:     more detailed events, dTLB and iTLB events
 -d -d -d:     very detailed events, adding prefetch events
Full output looks like this now:
 Performance counter stats for '/home/mingo/hackbench 10' (5 runs):
       1703.674707 task-clock                #    8.709 CPUs utilized            ( +-  4.19% )
            49,068 context-switches          #    0.029 M/sec                    ( +- 16.66% )
             8,303 CPU-migrations            #    0.005 M/sec                    ( +- 24.90% )
            17,397 page-faults               #    0.010 M/sec                    ( +-  0.46% )
     2,345,389,239 cycles                    #    1.377 GHz                      ( +-  4.61% ) [55.90%]
     1,884,503,527 stalled-cycles-frontend   #   80.35% frontend cycles idle     ( +-  5.67% ) [50.39%]
       743,919,737 stalled-cycles-backend    #   31.72% backend  cycles idle     ( +-  8.75% ) [49.91%]
     1,314,416,379 instructions              #    0.56  insns per cycle
                                             #    1.43  stalled cycles per insn  ( +-  2.53% ) [60.87%]
       272,592,567 branches                  #  160.003 M/sec                    ( +-  1.74% ) [56.56%]
         3,794,846 branch-misses             #    1.39% of all branches          ( +-  6.59% ) [58.50%]
       449,982,778 L1-dcache-loads           #  264.125 M/sec                    ( +-  2.47% ) [49.88%]
        22,404,961 L1-dcache-load-misses     #    4.98% of all L1-dcache hits    ( +-  6.08% ) [55.05%]
         6,204,750 LLC-loads                 #    3.642 M/sec                    ( +-  8.91% ) [43.75%]
         1,837,411 LLC-load-misses           #    1.078 M/sec                    ( +-  7.27% ) [12.07%]
       411,440,421 L1-icache-loads           #  241.502 M/sec                    ( +-  5.60% ) [36.52%]
        27,556,832 L1-icache-load-misses     #   16.175 M/sec                    ( +-  7.46% ) [46.72%]
       464,067,627 dTLB-loads                #  272.392 M/sec                    ( +-  4.46% ) [54.17%]
        10,765,648 dTLB-load-misses          #    6.319 M/sec                    ( +-  3.18% ) [48.68%]
     1,273,080,386 iTLB-loads                #  747.256 M/sec                    ( +-  3.38% ) [47.53%]
           117,481 iTLB-load-misses          #    0.069 M/sec                    ( +- 14.99% ) [47.01%]
         4,590,653 L1-dcache-prefetches      #    2.695 M/sec                    ( +-  4.49% ) [46.19%]
         1,712,660 L1-dcache-prefetch-misses #    1.005 M/sec                    ( +-  3.75% ) [44.82%]
        0.195622057  seconds time elapsed  ( +-  6.84% )
Also clean up the attribute construction code to be appending, and factor
it out into add_default_attributes().
Tweak the coverage percentage printout a bit, so that it's easier to view it
alongside the +- sttddev colum.
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Steven Rostedt <rostedt@goodmis.org>
Link: http://lkml.kernel.org/n/tip-to3kgu04449s64062val8b62@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-05-19 13:30:56 +02:00
										 |  |  |  * Copyright (C) 2008-2011, Red Hat Inc, Ingo Molnar <mingo@redhat.com> | 
					
						
							| 
									
										
										
										
											2009-05-26 09:17:18 +02:00
										 |  |  |  * | 
					
						
							|  |  |  |  * Improvements and fixes by: | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *   Arjan van de Ven <arjan@linux.intel.com> | 
					
						
							|  |  |  |  *   Yanmin Zhang <yanmin.zhang@intel.com> | 
					
						
							|  |  |  |  *   Wu Fengguang <fengguang.wu@intel.com> | 
					
						
							|  |  |  |  *   Mike Galbraith <efault@gmx.de> | 
					
						
							|  |  |  |  *   Paul Mackerras <paulus@samba.org> | 
					
						
							| 
									
										
										
										
											2009-06-27 03:02:07 +05:30
										 |  |  |  *   Jaswinder Singh Rajput <jaswinder@kernel.org> | 
					
						
							| 
									
										
										
										
											2009-05-26 09:17:18 +02:00
										 |  |  |  * | 
					
						
							|  |  |  |  * Released under the GPL v2. (and only v2, not any later version) | 
					
						
							| 
									
										
										
										
											2009-04-20 15:37:32 +02:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-23 18:28:58 +02:00
										 |  |  | #include "perf.h"
 | 
					
						
							| 
									
										
										
										
											2009-05-27 09:10:38 +02:00
										 |  |  | #include "builtin.h"
 | 
					
						
							| 
									
										
										
										
											2009-04-27 08:02:14 +02:00
										 |  |  | #include "util/util.h"
 | 
					
						
							| 
									
										
										
										
											2009-05-26 09:17:18 +02:00
										 |  |  | #include "util/parse-options.h"
 | 
					
						
							|  |  |  | #include "util/parse-events.h"
 | 
					
						
							| 
									
										
										
										
											2013-08-21 16:47:26 -07:00
										 |  |  | #include "util/pmu.h"
 | 
					
						
							| 
									
										
										
										
											2009-08-16 22:05:48 +02:00
										 |  |  | #include "util/event.h"
 | 
					
						
							| 
									
										
										
										
											2011-01-11 20:56:53 -02:00
										 |  |  | #include "util/evlist.h"
 | 
					
						
							| 
									
										
										
										
											2011-01-03 16:39:04 -02:00
										 |  |  | #include "util/evsel.h"
 | 
					
						
							| 
									
										
										
										
											2009-08-16 22:05:48 +02:00
										 |  |  | #include "util/debug.h"
 | 
					
						
							| 
									
										
										
										
											2011-04-27 05:39:24 +02:00
										 |  |  | #include "util/color.h"
 | 
					
						
							| 
									
										
										
										
											2012-09-17 16:31:14 +08:00
										 |  |  | #include "util/stat.h"
 | 
					
						
							| 
									
										
										
										
											2009-12-31 16:05:50 +08:00
										 |  |  | #include "util/header.h"
 | 
					
						
							| 
									
										
											  
											
												perf tools: Fix sparse CPU numbering related bugs
At present, the perf subcommands that do system-wide monitoring
(perf stat, perf record and perf top) don't work properly unless
the online cpus are numbered 0, 1, ..., N-1.  These tools ask
for the number of online cpus with sysconf(_SC_NPROCESSORS_ONLN)
and then try to create events for cpus 0, 1, ..., N-1.
This creates problems for systems where the online cpus are
numbered sparsely.  For example, a POWER6 system in
single-threaded mode (i.e. only running 1 hardware thread per
core) will have only even-numbered cpus online.
This fixes the problem by reading the /sys/devices/system/cpu/online
file to find out which cpus are online.  The code that does that is in
tools/perf/util/cpumap.[ch], and consists of a read_cpu_map()
function that sets up a cpumap[] array and returns the number of
online cpus.  If /sys/devices/system/cpu/online can't be read or
can't be parsed successfully, it falls back to using sysconf to
ask how many cpus are online and sets up an identity map in cpumap[].
The perf record, perf stat and perf top code then calls
read_cpu_map() in the system-wide monitoring case (instead of
sysconf) and uses cpumap[] to get the cpu numbers to pass to
perf_event_open.
Signed-off-by: Paul Mackerras <paulus@samba.org>
Cc: Anton Blanchard <anton@samba.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Arnaldo Carvalho de Melo <acme@infradead.org>
LKML-Reference: <20100310093609.GA3959@brick.ozlabs.ibm.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2010-03-10 20:36:09 +11:00
										 |  |  | #include "util/cpumap.h"
 | 
					
						
							| 
									
										
										
										
											2010-03-18 11:36:05 -03:00
										 |  |  | #include "util/thread.h"
 | 
					
						
							| 
									
										
										
										
											2011-01-18 15:15:24 -02:00
										 |  |  | #include "util/thread_map.h"
 | 
					
						
							| 
									
										
										
										
											2009-04-20 15:37:32 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-23 13:40:14 +02:00
										 |  |  | #include <stdlib.h>
 | 
					
						
							| 
									
										
										
										
											2009-04-20 15:37:32 +02:00
										 |  |  | #include <sys/prctl.h>
 | 
					
						
							| 
									
										
											  
											
												perf stat: add perf stat -B to pretty print large numbers
It is hard to read very large numbers so provide an option to perf stat
to separate thousands using a separator. The patch leverages the locale
support of stdio. You need to set your LC_NUMERIC appropriately, for
instance LC_NUMERIC=en_US.UTF8. You need to pass -B to activate this
feature. This way existing scripts parsing the output do not need to be
changed. Here is an example.
$ perf stat noploop 2
noploop for 2 seconds
 Performance counter stats for 'noploop 2':
        1998.347031  task-clock-msecs         #      0.998 CPUs
                 61  context-switches         #      0.000 M/sec
                  0  CPU-migrations           #      0.000 M/sec
                118  page-faults              #      0.000 M/sec
      4,138,410,900  cycles                   #   2070.917 M/sec  (scaled from 70.01%)
      2,062,650,268  instructions             #      0.498 IPC    (scaled from 70.01%)
      2,057,653,466  branches                 #   1029.678 M/sec  (scaled from 70.01%)
             40,267  branch-misses            #      0.002 %      (scaled from 30.04%)
      2,055,961,348  cache-references         #   1028.831 M/sec  (scaled from 30.03%)
             53,725  cache-misses             #      0.027 M/sec  (scaled from 30.02%)
        2.001393933  seconds time elapsed
$ perf stat -B  noploop 2
noploop for 2 seconds
 Performance counter stats for 'noploop 2':
        1998.297883  task-clock-msecs         #      0.998 CPUs
                 59  context-switches         #      0.000 M/sec
                  0  CPU-migrations           #      0.000 M/sec
                119  page-faults              #      0.000 M/sec
      4,131,380,160  cycles                   #   2067.450 M/sec  (scaled from 70.01%)
      2,059,096,507  instructions             #      0.498 IPC    (scaled from 70.01%)
      2,054,681,303  branches                 #   1028.216 M/sec  (scaled from 70.01%)
             25,650  branch-misses            #      0.001 %      (scaled from 30.05%)
      2,056,283,014  cache-references         #   1029.017 M/sec  (scaled from 30.03%)
             47,097  cache-misses             #      0.024 M/sec  (scaled from 30.02%)
        2.001391016  seconds time elapsed
Cc: David S. Miller <davem@davemloft.net>
Cc: Frédéric Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Tom Zanussi <tzanussi@gmail.com>
LKML-Reference: <4bf28fe8.914ed80a.01ca.fffff5f5@mx.google.com>
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2010-05-18 15:00:01 +02:00
										 |  |  | #include <locale.h>
 | 
					
						
							| 
									
										
										
										
											2009-05-05 17:50:27 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												perf stat: Add csv-style output
This patch adds an option (-x/--field-separator) to print counts using a
CSV-style output. The user can pass a custom separator. This makes it very easy
to import counts directly into your favorite spreadsheet without having to
write scripts.
Example:
$ perf stat --field-separator=,  -a -- sleep 1
4009.961740,task-clock-msecs
13,context-switches
2,CPU-migrations
189,page-faults
9596385684,cycles
3493659441,instructions
872897069,branches
41562,branch-misses
22424,cache-references
1289,cache-misses
Works also in non-aggregated mode:
$ perf stat -x ,  -a -A -- sleep 1
CPU0,1002.526168,task-clock-msecs
CPU1,1002.528365,task-clock-msecs
CPU2,1002.523360,task-clock-msecs
CPU3,1002.519878,task-clock-msecs
CPU0,1,context-switches
CPU1,5,context-switches
CPU2,5,context-switches
CPU3,6,context-switches
CPU0,0,CPU-migrations
CPU1,1,CPU-migrations
CPU2,0,CPU-migrations
CPU3,1,CPU-migrations
CPU0,2,page-faults
CPU1,6,page-faults
CPU2,9,page-faults
CPU3,174,page-faults
CPU0,2399439771,cycles
CPU1,2380369063,cycles
CPU2,2399142710,cycles
CPU3,2373161192,cycles
CPU0,872900618,instructions
CPU1,873030960,instructions
CPU2,872714525,instructions
CPU3,874460580,instructions
CPU0,221556839,branches
CPU1,218134342,branches
CPU2,218161730,branches
CPU3,218284093,branches
CPU0,18556,branch-misses
CPU1,1449,branch-misses
CPU2,3447,branch-misses
CPU3,12714,branch-misses
CPU0,8330,cache-references
CPU1,313844,cache-references
CPU2,47993728,cache-references
CPU3,826481,cache-references
CPU0,272,cache-misses
CPU1,5360,cache-misses
CPU2,1342193,cache-misses
CPU3,13992,cache-misses
This second version adds the ability to name a separator and uses
field-separator as the long option to be consistent with perf report.
Commiter note: Since we enabled --big-num by default in 201e0b0 and -x can't be
used with it, we need to notice if the user explicitely enabled or disabled -B,
add code to disable big_num if the user didn't explicitely set --big_num when
-x is used.
Cc: David S. Miller <davem@davemloft.net>
Cc: Frederik Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: paulus@samba.org
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Robert Richter <robert.richter@amd.com>
LKML-Reference: <4cf68aa7.0fedd80a.5294.1203@mx.google.com>
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2010-12-01 18:49:05 +02:00
										 |  |  | #define DEFAULT_SEPARATOR	" "
 | 
					
						
							| 
									
										
										
										
											2011-05-30 08:55:59 -06:00
										 |  |  | #define CNTR_NOT_SUPPORTED	"<not supported>"
 | 
					
						
							|  |  |  | #define CNTR_NOT_COUNTED	"<not counted>"
 | 
					
						
							| 
									
										
											  
											
												perf stat: Add csv-style output
This patch adds an option (-x/--field-separator) to print counts using a
CSV-style output. The user can pass a custom separator. This makes it very easy
to import counts directly into your favorite spreadsheet without having to
write scripts.
Example:
$ perf stat --field-separator=,  -a -- sleep 1
4009.961740,task-clock-msecs
13,context-switches
2,CPU-migrations
189,page-faults
9596385684,cycles
3493659441,instructions
872897069,branches
41562,branch-misses
22424,cache-references
1289,cache-misses
Works also in non-aggregated mode:
$ perf stat -x ,  -a -A -- sleep 1
CPU0,1002.526168,task-clock-msecs
CPU1,1002.528365,task-clock-msecs
CPU2,1002.523360,task-clock-msecs
CPU3,1002.519878,task-clock-msecs
CPU0,1,context-switches
CPU1,5,context-switches
CPU2,5,context-switches
CPU3,6,context-switches
CPU0,0,CPU-migrations
CPU1,1,CPU-migrations
CPU2,0,CPU-migrations
CPU3,1,CPU-migrations
CPU0,2,page-faults
CPU1,6,page-faults
CPU2,9,page-faults
CPU3,174,page-faults
CPU0,2399439771,cycles
CPU1,2380369063,cycles
CPU2,2399142710,cycles
CPU3,2373161192,cycles
CPU0,872900618,instructions
CPU1,873030960,instructions
CPU2,872714525,instructions
CPU3,874460580,instructions
CPU0,221556839,branches
CPU1,218134342,branches
CPU2,218161730,branches
CPU3,218284093,branches
CPU0,18556,branch-misses
CPU1,1449,branch-misses
CPU2,3447,branch-misses
CPU3,12714,branch-misses
CPU0,8330,cache-references
CPU1,313844,cache-references
CPU2,47993728,cache-references
CPU3,826481,cache-references
CPU0,272,cache-misses
CPU1,5360,cache-misses
CPU2,1342193,cache-misses
CPU3,13992,cache-misses
This second version adds the ability to name a separator and uses
field-separator as the long option to be consistent with perf report.
Commiter note: Since we enabled --big-num by default in 201e0b0 and -x can't be
used with it, we need to notice if the user explicitely enabled or disabled -B,
add code to disable big_num if the user didn't explicitely set --big_num when
-x is used.
Cc: David S. Miller <davem@davemloft.net>
Cc: Frederik Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: paulus@samba.org
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Robert Richter <robert.richter@amd.com>
LKML-Reference: <4cf68aa7.0fedd80a.5294.1203@mx.google.com>
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2010-12-01 18:49:05 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												perf stat: Add interval printing
This patch adds a new printing mode for perf stat.  It allows interval
printing. That means perf stat can now print event deltas at regular
time interval.  This is useful to detect phases in programs.
The -I option enables interval printing. It expects an interval duration
in milliseconds. Minimum is 100ms. Once, activated perf stat prints
events deltas since last printout. All modes are supported.
$ perf stat -I 1000 -e cycles noploop 10
noploop for 10 seconds
 #           time             counts events
      1.000109853      2,388,560,546 cycles
      2.000262846      2,393,332,358 cycles
      3.000354131      2,393,176,537 cycles
      4.000439503      2,393,203,790 cycles
      5.000527075      2,393,167,675 cycles
      6.000609052      2,393,203,670 cycles
      7.000691082      2,393,175,678 cycles
The output format makes it easy to feed into a plotting program such as
gnuplot when the -I option is used in combination with the -x option:
$ perf stat -x, -I 1000 -e cycles noploop 10
noploop for 10 seconds
1.000084113,2378775498,cycles
2.000245798,2391056897,cycles
3.000354445,2392089414,cycles
4.000459115,2390936603,cycles
5.000565341,2392108173,cycles
Signed-off-by: Stephane Eranian <eranian@google.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1359460064-3060-3-git-send-email-eranian@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2013-01-29 12:47:44 +01:00
										 |  |  | static void print_stat(int argc, const char **argv); | 
					
						
							|  |  |  | static void print_counter_aggr(struct perf_evsel *counter, char *prefix); | 
					
						
							|  |  |  | static void print_counter(struct perf_evsel *counter, char *prefix); | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | static void print_aggr(char *prefix); | 
					
						
							| 
									
										
											  
											
												perf stat: Add interval printing
This patch adds a new printing mode for perf stat.  It allows interval
printing. That means perf stat can now print event deltas at regular
time interval.  This is useful to detect phases in programs.
The -I option enables interval printing. It expects an interval duration
in milliseconds. Minimum is 100ms. Once, activated perf stat prints
events deltas since last printout. All modes are supported.
$ perf stat -I 1000 -e cycles noploop 10
noploop for 10 seconds
 #           time             counts events
      1.000109853      2,388,560,546 cycles
      2.000262846      2,393,332,358 cycles
      3.000354131      2,393,176,537 cycles
      4.000439503      2,393,203,790 cycles
      5.000527075      2,393,167,675 cycles
      6.000609052      2,393,203,670 cycles
      7.000691082      2,393,175,678 cycles
The output format makes it easy to feed into a plotting program such as
gnuplot when the -I option is used in combination with the -x option:
$ perf stat -x, -I 1000 -e cycles noploop 10
noploop for 10 seconds
1.000084113,2378775498,cycles
2.000245798,2391056897,cycles
3.000354445,2392089414,cycles
4.000459115,2390936603,cycles
5.000565341,2392108173,cycles
Signed-off-by: Stephane Eranian <eranian@google.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1359460064-3060-3-git-send-email-eranian@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2013-01-29 12:47:44 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-21 16:47:26 -07:00
										 |  |  | /* Default events used for perf stat -T */ | 
					
						
							|  |  |  | static const char * const transaction_attrs[] = { | 
					
						
							|  |  |  | 	"task-clock", | 
					
						
							|  |  |  | 	"{" | 
					
						
							|  |  |  | 	"instructions," | 
					
						
							|  |  |  | 	"cycles," | 
					
						
							|  |  |  | 	"cpu/cycles-t/," | 
					
						
							|  |  |  | 	"cpu/tx-start/," | 
					
						
							|  |  |  | 	"cpu/el-start/," | 
					
						
							|  |  |  | 	"cpu/cycles-ct/" | 
					
						
							|  |  |  | 	"}" | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* More limited version when the CPU does not have all events. */ | 
					
						
							|  |  |  | static const char * const transaction_limited_attrs[] = { | 
					
						
							|  |  |  | 	"task-clock", | 
					
						
							|  |  |  | 	"{" | 
					
						
							|  |  |  | 	"instructions," | 
					
						
							|  |  |  | 	"cycles," | 
					
						
							|  |  |  | 	"cpu/cycles-t/," | 
					
						
							|  |  |  | 	"cpu/tx-start/" | 
					
						
							|  |  |  | 	"}" | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* must match transaction_attrs and the beginning limited_attrs */ | 
					
						
							|  |  |  | enum { | 
					
						
							|  |  |  | 	T_TASK_CLOCK, | 
					
						
							|  |  |  | 	T_INSTRUCTIONS, | 
					
						
							|  |  |  | 	T_CYCLES, | 
					
						
							|  |  |  | 	T_CYCLES_IN_TX, | 
					
						
							|  |  |  | 	T_TRANSACTION_START, | 
					
						
							|  |  |  | 	T_ELISION_START, | 
					
						
							|  |  |  | 	T_CYCLES_IN_TX_CP, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-05 18:26:27 +02:00
										 |  |  | static struct perf_evlist	*evsel_list; | 
					
						
							| 
									
										
										
										
											2011-01-11 20:56:53 -02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-12 16:46:16 -03:00
										 |  |  | static struct target target = { | 
					
						
							| 
									
										
										
										
											2012-05-07 14:09:04 +09:00
										 |  |  | 	.uid	= UINT_MAX, | 
					
						
							|  |  |  | }; | 
					
						
							| 
									
										
										
										
											2009-04-20 15:37:32 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | enum aggr_mode { | 
					
						
							|  |  |  | 	AGGR_NONE, | 
					
						
							|  |  |  | 	AGGR_GLOBAL, | 
					
						
							|  |  |  | 	AGGR_SOCKET, | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:29 +01:00
										 |  |  | 	AGGR_CORE, | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-24 18:19:34 +05:30
										 |  |  | static int			run_count			=  1; | 
					
						
							| 
									
										
										
										
											2010-05-12 10:40:01 +02:00
										 |  |  | static bool			no_inherit			= false; | 
					
						
							| 
									
										
										
										
											2010-04-13 18:37:33 +10:00
										 |  |  | static bool			scale				=  true; | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | static enum aggr_mode		aggr_mode			= AGGR_GLOBAL; | 
					
						
							| 
									
										
										
										
											2013-06-04 17:44:26 +02:00
										 |  |  | static volatile pid_t		child_pid			= -1; | 
					
						
							| 
									
										
										
										
											2010-04-13 18:37:33 +10:00
										 |  |  | static bool			null_run			=  false; | 
					
						
							| 
									
										
											  
											
												perf stat: Add -d -d and -d -d -d options to show more CPU events
Print even more detailed statistics if requested via perf stat -d:
       -d:          detailed events, L1 and LLC data cache
    -d -d:     more detailed events, dTLB and iTLB events
 -d -d -d:     very detailed events, adding prefetch events
Full output looks like this now:
 Performance counter stats for '/home/mingo/hackbench 10' (5 runs):
       1703.674707 task-clock                #    8.709 CPUs utilized            ( +-  4.19% )
            49,068 context-switches          #    0.029 M/sec                    ( +- 16.66% )
             8,303 CPU-migrations            #    0.005 M/sec                    ( +- 24.90% )
            17,397 page-faults               #    0.010 M/sec                    ( +-  0.46% )
     2,345,389,239 cycles                    #    1.377 GHz                      ( +-  4.61% ) [55.90%]
     1,884,503,527 stalled-cycles-frontend   #   80.35% frontend cycles idle     ( +-  5.67% ) [50.39%]
       743,919,737 stalled-cycles-backend    #   31.72% backend  cycles idle     ( +-  8.75% ) [49.91%]
     1,314,416,379 instructions              #    0.56  insns per cycle
                                             #    1.43  stalled cycles per insn  ( +-  2.53% ) [60.87%]
       272,592,567 branches                  #  160.003 M/sec                    ( +-  1.74% ) [56.56%]
         3,794,846 branch-misses             #    1.39% of all branches          ( +-  6.59% ) [58.50%]
       449,982,778 L1-dcache-loads           #  264.125 M/sec                    ( +-  2.47% ) [49.88%]
        22,404,961 L1-dcache-load-misses     #    4.98% of all L1-dcache hits    ( +-  6.08% ) [55.05%]
         6,204,750 LLC-loads                 #    3.642 M/sec                    ( +-  8.91% ) [43.75%]
         1,837,411 LLC-load-misses           #    1.078 M/sec                    ( +-  7.27% ) [12.07%]
       411,440,421 L1-icache-loads           #  241.502 M/sec                    ( +-  5.60% ) [36.52%]
        27,556,832 L1-icache-load-misses     #   16.175 M/sec                    ( +-  7.46% ) [46.72%]
       464,067,627 dTLB-loads                #  272.392 M/sec                    ( +-  4.46% ) [54.17%]
        10,765,648 dTLB-load-misses          #    6.319 M/sec                    ( +-  3.18% ) [48.68%]
     1,273,080,386 iTLB-loads                #  747.256 M/sec                    ( +-  3.38% ) [47.53%]
           117,481 iTLB-load-misses          #    0.069 M/sec                    ( +- 14.99% ) [47.01%]
         4,590,653 L1-dcache-prefetches      #    2.695 M/sec                    ( +-  4.49% ) [46.19%]
         1,712,660 L1-dcache-prefetch-misses #    1.005 M/sec                    ( +-  3.75% ) [44.82%]
        0.195622057  seconds time elapsed  ( +-  6.84% )
Also clean up the attribute construction code to be appending, and factor
it out into add_default_attributes().
Tweak the coverage percentage printout a bit, so that it's easier to view it
alongside the +- sttddev colum.
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Steven Rostedt <rostedt@goodmis.org>
Link: http://lkml.kernel.org/n/tip-to3kgu04449s64062val8b62@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-05-19 13:30:56 +02:00
										 |  |  | static int			detailed_run			=  0; | 
					
						
							| 
									
										
										
										
											2013-08-21 16:47:26 -07:00
										 |  |  | static bool			transaction_run; | 
					
						
							| 
									
										
										
										
											2010-12-01 17:53:27 -02:00
										 |  |  | static bool			big_num				=  true; | 
					
						
							| 
									
										
											  
											
												perf stat: Add csv-style output
This patch adds an option (-x/--field-separator) to print counts using a
CSV-style output. The user can pass a custom separator. This makes it very easy
to import counts directly into your favorite spreadsheet without having to
write scripts.
Example:
$ perf stat --field-separator=,  -a -- sleep 1
4009.961740,task-clock-msecs
13,context-switches
2,CPU-migrations
189,page-faults
9596385684,cycles
3493659441,instructions
872897069,branches
41562,branch-misses
22424,cache-references
1289,cache-misses
Works also in non-aggregated mode:
$ perf stat -x ,  -a -A -- sleep 1
CPU0,1002.526168,task-clock-msecs
CPU1,1002.528365,task-clock-msecs
CPU2,1002.523360,task-clock-msecs
CPU3,1002.519878,task-clock-msecs
CPU0,1,context-switches
CPU1,5,context-switches
CPU2,5,context-switches
CPU3,6,context-switches
CPU0,0,CPU-migrations
CPU1,1,CPU-migrations
CPU2,0,CPU-migrations
CPU3,1,CPU-migrations
CPU0,2,page-faults
CPU1,6,page-faults
CPU2,9,page-faults
CPU3,174,page-faults
CPU0,2399439771,cycles
CPU1,2380369063,cycles
CPU2,2399142710,cycles
CPU3,2373161192,cycles
CPU0,872900618,instructions
CPU1,873030960,instructions
CPU2,872714525,instructions
CPU3,874460580,instructions
CPU0,221556839,branches
CPU1,218134342,branches
CPU2,218161730,branches
CPU3,218284093,branches
CPU0,18556,branch-misses
CPU1,1449,branch-misses
CPU2,3447,branch-misses
CPU3,12714,branch-misses
CPU0,8330,cache-references
CPU1,313844,cache-references
CPU2,47993728,cache-references
CPU3,826481,cache-references
CPU0,272,cache-misses
CPU1,5360,cache-misses
CPU2,1342193,cache-misses
CPU3,13992,cache-misses
This second version adds the ability to name a separator and uses
field-separator as the long option to be consistent with perf report.
Commiter note: Since we enabled --big-num by default in 201e0b0 and -x can't be
used with it, we need to notice if the user explicitely enabled or disabled -B,
add code to disable big_num if the user didn't explicitely set --big_num when
-x is used.
Cc: David S. Miller <davem@davemloft.net>
Cc: Frederik Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: paulus@samba.org
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Robert Richter <robert.richter@amd.com>
LKML-Reference: <4cf68aa7.0fedd80a.5294.1203@mx.google.com>
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2010-12-01 18:49:05 +02:00
										 |  |  | static int			big_num_opt			=  -1; | 
					
						
							|  |  |  | static const char		*csv_sep			= NULL; | 
					
						
							|  |  |  | static bool			csv_output			= false; | 
					
						
							| 
									
										
										
										
											2011-08-17 18:42:07 +08:00
										 |  |  | static bool			group				= false; | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | static FILE			*output				= NULL; | 
					
						
							| 
									
										
										
										
											2012-10-23 13:40:14 +02:00
										 |  |  | static const char		*pre_cmd			= NULL; | 
					
						
							|  |  |  | static const char		*post_cmd			= NULL; | 
					
						
							|  |  |  | static bool			sync_run			= false; | 
					
						
							| 
									
										
											  
											
												perf stat: Add interval printing
This patch adds a new printing mode for perf stat.  It allows interval
printing. That means perf stat can now print event deltas at regular
time interval.  This is useful to detect phases in programs.
The -I option enables interval printing. It expects an interval duration
in milliseconds. Minimum is 100ms. Once, activated perf stat prints
events deltas since last printout. All modes are supported.
$ perf stat -I 1000 -e cycles noploop 10
noploop for 10 seconds
 #           time             counts events
      1.000109853      2,388,560,546 cycles
      2.000262846      2,393,332,358 cycles
      3.000354131      2,393,176,537 cycles
      4.000439503      2,393,203,790 cycles
      5.000527075      2,393,167,675 cycles
      6.000609052      2,393,203,670 cycles
      7.000691082      2,393,175,678 cycles
The output format makes it easy to feed into a plotting program such as
gnuplot when the -I option is used in combination with the -x option:
$ perf stat -x, -I 1000 -e cycles noploop 10
noploop for 10 seconds
1.000084113,2378775498,cycles
2.000245798,2391056897,cycles
3.000354445,2392089414,cycles
4.000459115,2390936603,cycles
5.000565341,2392108173,cycles
Signed-off-by: Stephane Eranian <eranian@google.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1359460064-3060-3-git-send-email-eranian@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2013-01-29 12:47:44 +01:00
										 |  |  | static unsigned int		interval			= 0; | 
					
						
							| 
									
										
										
										
											2013-08-02 17:41:11 -07:00
										 |  |  | static unsigned int		initial_delay			= 0; | 
					
						
							| 
									
										
										
										
											2013-11-12 17:58:49 +01:00
										 |  |  | static unsigned int		unit_width			= 4; /* strlen("unit") */ | 
					
						
							| 
									
										
										
										
											2013-03-01 13:02:27 -05:00
										 |  |  | static bool			forever				= false; | 
					
						
							| 
									
										
											  
											
												perf stat: Add interval printing
This patch adds a new printing mode for perf stat.  It allows interval
printing. That means perf stat can now print event deltas at regular
time interval.  This is useful to detect phases in programs.
The -I option enables interval printing. It expects an interval duration
in milliseconds. Minimum is 100ms. Once, activated perf stat prints
events deltas since last printout. All modes are supported.
$ perf stat -I 1000 -e cycles noploop 10
noploop for 10 seconds
 #           time             counts events
      1.000109853      2,388,560,546 cycles
      2.000262846      2,393,332,358 cycles
      3.000354131      2,393,176,537 cycles
      4.000439503      2,393,203,790 cycles
      5.000527075      2,393,167,675 cycles
      6.000609052      2,393,203,670 cycles
      7.000691082      2,393,175,678 cycles
The output format makes it easy to feed into a plotting program such as
gnuplot when the -I option is used in combination with the -x option:
$ perf stat -x, -I 1000 -e cycles noploop 10
noploop for 10 seconds
1.000084113,2378775498,cycles
2.000245798,2391056897,cycles
3.000354445,2392089414,cycles
4.000459115,2390936603,cycles
5.000565341,2392108173,cycles
Signed-off-by: Stephane Eranian <eranian@google.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1359460064-3060-3-git-send-email-eranian@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2013-01-29 12:47:44 +01:00
										 |  |  | static struct timespec		ref_time; | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | static struct cpu_map		*aggr_map; | 
					
						
							|  |  |  | static int			(*aggr_get_id)(struct cpu_map *m, int cpu); | 
					
						
							| 
									
										
											  
											
												perf stat: add perf stat -B to pretty print large numbers
It is hard to read very large numbers so provide an option to perf stat
to separate thousands using a separator. The patch leverages the locale
support of stdio. You need to set your LC_NUMERIC appropriately, for
instance LC_NUMERIC=en_US.UTF8. You need to pass -B to activate this
feature. This way existing scripts parsing the output do not need to be
changed. Here is an example.
$ perf stat noploop 2
noploop for 2 seconds
 Performance counter stats for 'noploop 2':
        1998.347031  task-clock-msecs         #      0.998 CPUs
                 61  context-switches         #      0.000 M/sec
                  0  CPU-migrations           #      0.000 M/sec
                118  page-faults              #      0.000 M/sec
      4,138,410,900  cycles                   #   2070.917 M/sec  (scaled from 70.01%)
      2,062,650,268  instructions             #      0.498 IPC    (scaled from 70.01%)
      2,057,653,466  branches                 #   1029.678 M/sec  (scaled from 70.01%)
             40,267  branch-misses            #      0.002 %      (scaled from 30.04%)
      2,055,961,348  cache-references         #   1028.831 M/sec  (scaled from 30.03%)
             53,725  cache-misses             #      0.027 M/sec  (scaled from 30.02%)
        2.001393933  seconds time elapsed
$ perf stat -B  noploop 2
noploop for 2 seconds
 Performance counter stats for 'noploop 2':
        1998.297883  task-clock-msecs         #      0.998 CPUs
                 59  context-switches         #      0.000 M/sec
                  0  CPU-migrations           #      0.000 M/sec
                119  page-faults              #      0.000 M/sec
      4,131,380,160  cycles                   #   2067.450 M/sec  (scaled from 70.01%)
      2,059,096,507  instructions             #      0.498 IPC    (scaled from 70.01%)
      2,054,681,303  branches                 #   1028.216 M/sec  (scaled from 70.01%)
             25,650  branch-misses            #      0.001 %      (scaled from 30.05%)
      2,056,283,014  cache-references         #   1029.017 M/sec  (scaled from 30.03%)
             47,097  cache-misses             #      0.024 M/sec  (scaled from 30.02%)
        2.001391016  seconds time elapsed
Cc: David S. Miller <davem@davemloft.net>
Cc: Frédéric Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Tom Zanussi <tzanussi@gmail.com>
LKML-Reference: <4bf28fe8.914ed80a.01ca.fffff5f5@mx.google.com>
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2010-05-18 15:00:01 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-31 16:05:50 +08:00
										 |  |  | static volatile int done = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-01-03 16:39:04 -02:00
										 |  |  | struct perf_stat { | 
					
						
							|  |  |  | 	struct stats	  res_stats[3]; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												perf stat: Add interval printing
This patch adds a new printing mode for perf stat.  It allows interval
printing. That means perf stat can now print event deltas at regular
time interval.  This is useful to detect phases in programs.
The -I option enables interval printing. It expects an interval duration
in milliseconds. Minimum is 100ms. Once, activated perf stat prints
events deltas since last printout. All modes are supported.
$ perf stat -I 1000 -e cycles noploop 10
noploop for 10 seconds
 #           time             counts events
      1.000109853      2,388,560,546 cycles
      2.000262846      2,393,332,358 cycles
      3.000354131      2,393,176,537 cycles
      4.000439503      2,393,203,790 cycles
      5.000527075      2,393,167,675 cycles
      6.000609052      2,393,203,670 cycles
      7.000691082      2,393,175,678 cycles
The output format makes it easy to feed into a plotting program such as
gnuplot when the -I option is used in combination with the -x option:
$ perf stat -x, -I 1000 -e cycles noploop 10
noploop for 10 seconds
1.000084113,2378775498,cycles
2.000245798,2391056897,cycles
3.000354445,2392089414,cycles
4.000459115,2390936603,cycles
5.000565341,2392108173,cycles
Signed-off-by: Stephane Eranian <eranian@google.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1359460064-3060-3-git-send-email-eranian@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2013-01-29 12:47:44 +01:00
										 |  |  | static inline void diff_timespec(struct timespec *r, struct timespec *a, | 
					
						
							|  |  |  | 				 struct timespec *b) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	r->tv_sec = a->tv_sec - b->tv_sec; | 
					
						
							|  |  |  | 	if (a->tv_nsec < b->tv_nsec) { | 
					
						
							|  |  |  | 		r->tv_nsec = a->tv_nsec + 1000000000L - b->tv_nsec; | 
					
						
							|  |  |  | 		r->tv_sec--; | 
					
						
							|  |  |  | 	} else { | 
					
						
							|  |  |  | 		r->tv_nsec = a->tv_nsec - b->tv_nsec ; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline struct cpu_map *perf_evsel__cpus(struct perf_evsel *evsel) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return (evsel->cpus && !target.cpu_list) ? evsel->cpus : evsel_list->cpus; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline int perf_evsel__nr_cpus(struct perf_evsel *evsel) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return perf_evsel__cpus(evsel)->nr; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-01 13:02:27 -05:00
										 |  |  | static void perf_evsel__reset_stat_priv(struct perf_evsel *evsel) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	memset(evsel->priv, 0, sizeof(struct perf_stat)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-01-03 17:45:52 -02:00
										 |  |  | static int perf_evsel__alloc_stat_priv(struct perf_evsel *evsel) | 
					
						
							| 
									
										
										
										
											2011-01-03 16:39:04 -02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-01-03 17:45:52 -02:00
										 |  |  | 	evsel->priv = zalloc(sizeof(struct perf_stat)); | 
					
						
							| 
									
										
										
										
											2011-01-03 16:39:04 -02:00
										 |  |  | 	return evsel->priv == NULL ? -ENOMEM : 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void perf_evsel__free_stat_priv(struct perf_evsel *evsel) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2013-12-26 17:41:15 -03:00
										 |  |  | 	zfree(&evsel->priv); | 
					
						
							| 
									
										
										
										
											2011-01-03 16:39:04 -02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												perf stat: Add interval printing
This patch adds a new printing mode for perf stat.  It allows interval
printing. That means perf stat can now print event deltas at regular
time interval.  This is useful to detect phases in programs.
The -I option enables interval printing. It expects an interval duration
in milliseconds. Minimum is 100ms. Once, activated perf stat prints
events deltas since last printout. All modes are supported.
$ perf stat -I 1000 -e cycles noploop 10
noploop for 10 seconds
 #           time             counts events
      1.000109853      2,388,560,546 cycles
      2.000262846      2,393,332,358 cycles
      3.000354131      2,393,176,537 cycles
      4.000439503      2,393,203,790 cycles
      5.000527075      2,393,167,675 cycles
      6.000609052      2,393,203,670 cycles
      7.000691082      2,393,175,678 cycles
The output format makes it easy to feed into a plotting program such as
gnuplot when the -I option is used in combination with the -x option:
$ perf stat -x, -I 1000 -e cycles noploop 10
noploop for 10 seconds
1.000084113,2378775498,cycles
2.000245798,2391056897,cycles
3.000354445,2392089414,cycles
4.000459115,2390936603,cycles
5.000565341,2392108173,cycles
Signed-off-by: Stephane Eranian <eranian@google.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1359460064-3060-3-git-send-email-eranian@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2013-01-29 12:47:44 +01:00
										 |  |  | static int perf_evsel__alloc_prev_raw_counts(struct perf_evsel *evsel) | 
					
						
							| 
									
										
										
										
											2012-09-10 15:53:50 +08:00
										 |  |  | { | 
					
						
							| 
									
										
											  
											
												perf stat: Add interval printing
This patch adds a new printing mode for perf stat.  It allows interval
printing. That means perf stat can now print event deltas at regular
time interval.  This is useful to detect phases in programs.
The -I option enables interval printing. It expects an interval duration
in milliseconds. Minimum is 100ms. Once, activated perf stat prints
events deltas since last printout. All modes are supported.
$ perf stat -I 1000 -e cycles noploop 10
noploop for 10 seconds
 #           time             counts events
      1.000109853      2,388,560,546 cycles
      2.000262846      2,393,332,358 cycles
      3.000354131      2,393,176,537 cycles
      4.000439503      2,393,203,790 cycles
      5.000527075      2,393,167,675 cycles
      6.000609052      2,393,203,670 cycles
      7.000691082      2,393,175,678 cycles
The output format makes it easy to feed into a plotting program such as
gnuplot when the -I option is used in combination with the -x option:
$ perf stat -x, -I 1000 -e cycles noploop 10
noploop for 10 seconds
1.000084113,2378775498,cycles
2.000245798,2391056897,cycles
3.000354445,2392089414,cycles
4.000459115,2390936603,cycles
5.000565341,2392108173,cycles
Signed-off-by: Stephane Eranian <eranian@google.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1359460064-3060-3-git-send-email-eranian@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2013-01-29 12:47:44 +01:00
										 |  |  | 	void *addr; | 
					
						
							|  |  |  | 	size_t sz; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	sz = sizeof(*evsel->counts) + | 
					
						
							|  |  |  | 	     (perf_evsel__nr_cpus(evsel) * sizeof(struct perf_counts_values)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	addr = zalloc(sz); | 
					
						
							|  |  |  | 	if (!addr) | 
					
						
							|  |  |  | 		return -ENOMEM; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	evsel->prev_raw_counts =  addr; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return 0; | 
					
						
							| 
									
										
										
										
											2012-09-10 15:53:50 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												perf stat: Add interval printing
This patch adds a new printing mode for perf stat.  It allows interval
printing. That means perf stat can now print event deltas at regular
time interval.  This is useful to detect phases in programs.
The -I option enables interval printing. It expects an interval duration
in milliseconds. Minimum is 100ms. Once, activated perf stat prints
events deltas since last printout. All modes are supported.
$ perf stat -I 1000 -e cycles noploop 10
noploop for 10 seconds
 #           time             counts events
      1.000109853      2,388,560,546 cycles
      2.000262846      2,393,332,358 cycles
      3.000354131      2,393,176,537 cycles
      4.000439503      2,393,203,790 cycles
      5.000527075      2,393,167,675 cycles
      6.000609052      2,393,203,670 cycles
      7.000691082      2,393,175,678 cycles
The output format makes it easy to feed into a plotting program such as
gnuplot when the -I option is used in combination with the -x option:
$ perf stat -x, -I 1000 -e cycles noploop 10
noploop for 10 seconds
1.000084113,2378775498,cycles
2.000245798,2391056897,cycles
3.000354445,2392089414,cycles
4.000459115,2390936603,cycles
5.000565341,2392108173,cycles
Signed-off-by: Stephane Eranian <eranian@google.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1359460064-3060-3-git-send-email-eranian@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2013-01-29 12:47:44 +01:00
										 |  |  | static void perf_evsel__free_prev_raw_counts(struct perf_evsel *evsel) | 
					
						
							| 
									
										
										
										
											2012-09-10 15:53:50 +08:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2013-12-26 17:41:15 -03:00
										 |  |  | 	zfree(&evsel->prev_raw_counts); | 
					
						
							| 
									
										
										
										
											2012-09-10 15:53:50 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-18 11:24:21 -03:00
										 |  |  | static void perf_evlist__free_stats(struct perf_evlist *evlist) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	struct perf_evsel *evsel; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-10 10:37:27 -03:00
										 |  |  | 	evlist__for_each(evlist, evsel) { | 
					
						
							| 
									
										
										
										
											2013-03-18 11:24:21 -03:00
										 |  |  | 		perf_evsel__free_stat_priv(evsel); | 
					
						
							|  |  |  | 		perf_evsel__free_counts(evsel); | 
					
						
							|  |  |  | 		perf_evsel__free_prev_raw_counts(evsel); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int perf_evlist__alloc_stats(struct perf_evlist *evlist, bool alloc_raw) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	struct perf_evsel *evsel; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-10 10:37:27 -03:00
										 |  |  | 	evlist__for_each(evlist, evsel) { | 
					
						
							| 
									
										
										
										
											2013-03-18 11:24:21 -03:00
										 |  |  | 		if (perf_evsel__alloc_stat_priv(evsel) < 0 || | 
					
						
							|  |  |  | 		    perf_evsel__alloc_counts(evsel, perf_evsel__nr_cpus(evsel)) < 0 || | 
					
						
							|  |  |  | 		    (alloc_raw && perf_evsel__alloc_prev_raw_counts(evsel) < 0)) | 
					
						
							|  |  |  | 			goto out_free; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | out_free: | 
					
						
							|  |  |  | 	perf_evlist__free_stats(evlist); | 
					
						
							|  |  |  | 	return -1; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-05 18:26:27 +02:00
										 |  |  | static struct stats runtime_nsecs_stats[MAX_NR_CPUS]; | 
					
						
							|  |  |  | static struct stats runtime_cycles_stats[MAX_NR_CPUS]; | 
					
						
							|  |  |  | static struct stats runtime_stalled_cycles_front_stats[MAX_NR_CPUS]; | 
					
						
							|  |  |  | static struct stats runtime_stalled_cycles_back_stats[MAX_NR_CPUS]; | 
					
						
							|  |  |  | static struct stats runtime_branches_stats[MAX_NR_CPUS]; | 
					
						
							|  |  |  | static struct stats runtime_cacherefs_stats[MAX_NR_CPUS]; | 
					
						
							|  |  |  | static struct stats runtime_l1_dcache_stats[MAX_NR_CPUS]; | 
					
						
							|  |  |  | static struct stats runtime_l1_icache_stats[MAX_NR_CPUS]; | 
					
						
							|  |  |  | static struct stats runtime_ll_cache_stats[MAX_NR_CPUS]; | 
					
						
							|  |  |  | static struct stats runtime_itlb_cache_stats[MAX_NR_CPUS]; | 
					
						
							|  |  |  | static struct stats runtime_dtlb_cache_stats[MAX_NR_CPUS]; | 
					
						
							| 
									
										
										
										
											2013-08-21 16:47:26 -07:00
										 |  |  | static struct stats runtime_cycles_in_tx_stats[MAX_NR_CPUS]; | 
					
						
							| 
									
										
										
										
											2012-04-05 18:26:27 +02:00
										 |  |  | static struct stats walltime_nsecs_stats; | 
					
						
							| 
									
										
										
										
											2013-08-21 16:47:26 -07:00
										 |  |  | static struct stats runtime_transaction_stats[MAX_NR_CPUS]; | 
					
						
							|  |  |  | static struct stats runtime_elision_stats[MAX_NR_CPUS]; | 
					
						
							| 
									
										
										
										
											2009-05-29 09:10:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-18 11:24:21 -03:00
										 |  |  | static void perf_stat__reset_stats(struct perf_evlist *evlist) | 
					
						
							| 
									
										
										
										
											2013-03-01 13:02:27 -05:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2013-03-18 11:24:21 -03:00
										 |  |  | 	struct perf_evsel *evsel; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-10 10:37:27 -03:00
										 |  |  | 	evlist__for_each(evlist, evsel) { | 
					
						
							| 
									
										
										
										
											2013-03-18 11:24:21 -03:00
										 |  |  | 		perf_evsel__reset_stat_priv(evsel); | 
					
						
							|  |  |  | 		perf_evsel__reset_counts(evsel, perf_evsel__nr_cpus(evsel)); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-01 13:02:27 -05:00
										 |  |  | 	memset(runtime_nsecs_stats, 0, sizeof(runtime_nsecs_stats)); | 
					
						
							|  |  |  | 	memset(runtime_cycles_stats, 0, sizeof(runtime_cycles_stats)); | 
					
						
							|  |  |  | 	memset(runtime_stalled_cycles_front_stats, 0, sizeof(runtime_stalled_cycles_front_stats)); | 
					
						
							|  |  |  | 	memset(runtime_stalled_cycles_back_stats, 0, sizeof(runtime_stalled_cycles_back_stats)); | 
					
						
							|  |  |  | 	memset(runtime_branches_stats, 0, sizeof(runtime_branches_stats)); | 
					
						
							|  |  |  | 	memset(runtime_cacherefs_stats, 0, sizeof(runtime_cacherefs_stats)); | 
					
						
							|  |  |  | 	memset(runtime_l1_dcache_stats, 0, sizeof(runtime_l1_dcache_stats)); | 
					
						
							|  |  |  | 	memset(runtime_l1_icache_stats, 0, sizeof(runtime_l1_icache_stats)); | 
					
						
							|  |  |  | 	memset(runtime_ll_cache_stats, 0, sizeof(runtime_ll_cache_stats)); | 
					
						
							|  |  |  | 	memset(runtime_itlb_cache_stats, 0, sizeof(runtime_itlb_cache_stats)); | 
					
						
							|  |  |  | 	memset(runtime_dtlb_cache_stats, 0, sizeof(runtime_dtlb_cache_stats)); | 
					
						
							| 
									
										
										
										
											2013-08-21 16:47:26 -07:00
										 |  |  | 	memset(runtime_cycles_in_tx_stats, 0, | 
					
						
							|  |  |  | 			sizeof(runtime_cycles_in_tx_stats)); | 
					
						
							|  |  |  | 	memset(runtime_transaction_stats, 0, | 
					
						
							|  |  |  | 		sizeof(runtime_transaction_stats)); | 
					
						
							|  |  |  | 	memset(runtime_elision_stats, 0, sizeof(runtime_elision_stats)); | 
					
						
							| 
									
										
										
										
											2013-03-01 13:02:27 -05:00
										 |  |  | 	memset(&walltime_nsecs_stats, 0, sizeof(walltime_nsecs_stats)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-11-12 18:34:00 +01:00
										 |  |  | static int create_perf_stat_counter(struct perf_evsel *evsel) | 
					
						
							| 
									
										
										
										
											2009-04-20 15:37:32 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-01-03 16:39:04 -02:00
										 |  |  | 	struct perf_event_attr *attr = &evsel->attr; | 
					
						
							| 
									
										
										
										
											2011-10-25 10:42:19 -02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-20 15:37:32 +02:00
										 |  |  | 	if (scale) | 
					
						
							| 
									
										
										
										
											2009-06-06 09:58:57 +02:00
										 |  |  | 		attr->read_format = PERF_FORMAT_TOTAL_TIME_ENABLED | | 
					
						
							|  |  |  | 				    PERF_FORMAT_TOTAL_TIME_RUNNING; | 
					
						
							| 
									
										
										
										
											2009-04-20 15:37:32 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-14 11:20:14 -03:00
										 |  |  | 	attr->inherit = !no_inherit; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-12 16:46:16 -03:00
										 |  |  | 	if (target__has_cpu(&target)) | 
					
						
							| 
									
										
										
										
											2012-12-13 13:13:07 -03:00
										 |  |  | 		return perf_evsel__open_per_cpu(evsel, perf_evsel__cpus(evsel)); | 
					
						
							| 
									
										
										
										
											2012-04-27 14:45:38 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-12 16:46:16 -03:00
										 |  |  | 	if (!target__has_task(&target) && perf_evsel__is_group_leader(evsel)) { | 
					
						
							| 
									
										
										
										
											2011-01-03 17:48:12 -02:00
										 |  |  | 		attr->disabled = 1; | 
					
						
							| 
									
										
										
										
											2013-08-02 17:41:11 -07:00
										 |  |  | 		if (!initial_delay) | 
					
						
							|  |  |  | 			attr->enable_on_exec = 1; | 
					
						
							| 
									
										
										
										
											2009-04-20 15:37:32 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-03-22 13:10:28 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-13 13:13:07 -03:00
										 |  |  | 	return perf_evsel__open_per_thread(evsel, evsel_list->threads); | 
					
						
							| 
									
										
										
										
											2009-04-20 15:37:32 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-29 09:10:54 +02:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * Does the counter have nsecs as a unit? | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2011-01-03 16:49:44 -02:00
										 |  |  | static inline int nsec_counter(struct perf_evsel *evsel) | 
					
						
							| 
									
										
										
										
											2009-05-29 09:10:54 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-01-03 16:49:44 -02:00
										 |  |  | 	if (perf_evsel__match(evsel, SOFTWARE, SW_CPU_CLOCK) || | 
					
						
							|  |  |  | 	    perf_evsel__match(evsel, SOFTWARE, SW_TASK_CLOCK)) | 
					
						
							| 
									
										
										
										
											2009-05-29 09:10:54 +02:00
										 |  |  | 		return 1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-21 16:47:26 -07:00
										 |  |  | static struct perf_evsel *nth_evsel(int n) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	static struct perf_evsel **array; | 
					
						
							|  |  |  | 	static int array_len; | 
					
						
							|  |  |  | 	struct perf_evsel *ev; | 
					
						
							|  |  |  | 	int j; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Assumes this only called when evsel_list does not change anymore. */ | 
					
						
							|  |  |  | 	if (!array) { | 
					
						
							| 
									
										
										
										
											2014-01-10 10:37:27 -03:00
										 |  |  | 		evlist__for_each(evsel_list, ev) | 
					
						
							| 
									
										
										
										
											2013-08-21 16:47:26 -07:00
										 |  |  | 			array_len++; | 
					
						
							|  |  |  | 		array = malloc(array_len * sizeof(void *)); | 
					
						
							|  |  |  | 		if (!array) | 
					
						
							|  |  |  | 			exit(ENOMEM); | 
					
						
							|  |  |  | 		j = 0; | 
					
						
							| 
									
										
										
										
											2014-01-10 10:37:27 -03:00
										 |  |  | 		evlist__for_each(evsel_list, ev) | 
					
						
							| 
									
										
										
										
											2013-08-21 16:47:26 -07:00
										 |  |  | 			array[j++] = ev; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if (n < array_len) | 
					
						
							|  |  |  | 		return array[n]; | 
					
						
							|  |  |  | 	return NULL; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-27 04:36:37 +02:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * Update various tracking values we maintain to print | 
					
						
							|  |  |  |  * more semantic information such as miss/hit ratios, | 
					
						
							|  |  |  |  * instruction rates, etc: | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | static void update_shadow_stats(struct perf_evsel *counter, u64 *count) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (perf_evsel__match(counter, SOFTWARE, SW_TASK_CLOCK)) | 
					
						
							|  |  |  | 		update_stats(&runtime_nsecs_stats[0], count[0]); | 
					
						
							|  |  |  | 	else if (perf_evsel__match(counter, HARDWARE, HW_CPU_CYCLES)) | 
					
						
							|  |  |  | 		update_stats(&runtime_cycles_stats[0], count[0]); | 
					
						
							| 
									
										
										
										
											2013-08-21 16:47:26 -07:00
										 |  |  | 	else if (transaction_run && | 
					
						
							|  |  |  | 		 perf_evsel__cmp(counter, nth_evsel(T_CYCLES_IN_TX))) | 
					
						
							|  |  |  | 		update_stats(&runtime_cycles_in_tx_stats[0], count[0]); | 
					
						
							|  |  |  | 	else if (transaction_run && | 
					
						
							|  |  |  | 		 perf_evsel__cmp(counter, nth_evsel(T_TRANSACTION_START))) | 
					
						
							|  |  |  | 		update_stats(&runtime_transaction_stats[0], count[0]); | 
					
						
							|  |  |  | 	else if (transaction_run && | 
					
						
							|  |  |  | 		 perf_evsel__cmp(counter, nth_evsel(T_ELISION_START))) | 
					
						
							|  |  |  | 		update_stats(&runtime_elision_stats[0], count[0]); | 
					
						
							| 
									
										
										
											
												perf stat: Analyze front-end and back-end stall counts
Sample output:
 Performance counter stats for './loop_1b':
        873.691065 task-clock               #    1.000 CPUs utilized
                 1 context-switches         #    0.000 M/sec
                 1 CPU-migrations           #    0.000 M/sec
                96 page-faults              #    0.000 M/sec
     2,012,637,222 cycles                   #    2.304 GHz                      (66.58%)
     1,001,397,911 stalled-cycles-frontend  #   49.76% frontend cycles idle     (66.58%)
         7,523,398 stalled-cycles-backend   #    0.37%  backend cycles idle     (66.76%)
     2,004,551,046 instructions             #    1.00  insns per cycle
                                            #    0.50  stalled cycles per insn  (66.80%)
     1,001,304,992 branches                 # 1146.063 M/sec                    (66.76%)
            39,453 branch-misses            #    0.00% of all branches          (66.64%)
        0.874046121  seconds time elapsed
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Link: http://lkml.kernel.org/n/tip-7y40wib8n003io7hjpn1dsrm@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-04-29 13:49:08 +02:00
										 |  |  | 	else if (perf_evsel__match(counter, HARDWARE, HW_STALLED_CYCLES_FRONTEND)) | 
					
						
							|  |  |  | 		update_stats(&runtime_stalled_cycles_front_stats[0], count[0]); | 
					
						
							| 
									
										
										
										
											2011-04-29 14:41:28 +02:00
										 |  |  | 	else if (perf_evsel__match(counter, HARDWARE, HW_STALLED_CYCLES_BACKEND)) | 
					
						
							| 
									
										
										
											
												perf stat: Analyze front-end and back-end stall counts
Sample output:
 Performance counter stats for './loop_1b':
        873.691065 task-clock               #    1.000 CPUs utilized
                 1 context-switches         #    0.000 M/sec
                 1 CPU-migrations           #    0.000 M/sec
                96 page-faults              #    0.000 M/sec
     2,012,637,222 cycles                   #    2.304 GHz                      (66.58%)
     1,001,397,911 stalled-cycles-frontend  #   49.76% frontend cycles idle     (66.58%)
         7,523,398 stalled-cycles-backend   #    0.37%  backend cycles idle     (66.76%)
     2,004,551,046 instructions             #    1.00  insns per cycle
                                            #    0.50  stalled cycles per insn  (66.80%)
     1,001,304,992 branches                 # 1146.063 M/sec                    (66.76%)
            39,453 branch-misses            #    0.00% of all branches          (66.64%)
        0.874046121  seconds time elapsed
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Link: http://lkml.kernel.org/n/tip-7y40wib8n003io7hjpn1dsrm@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-04-29 13:49:08 +02:00
										 |  |  | 		update_stats(&runtime_stalled_cycles_back_stats[0], count[0]); | 
					
						
							| 
									
										
										
										
											2011-04-27 04:36:37 +02:00
										 |  |  | 	else if (perf_evsel__match(counter, HARDWARE, HW_BRANCH_INSTRUCTIONS)) | 
					
						
							|  |  |  | 		update_stats(&runtime_branches_stats[0], count[0]); | 
					
						
							|  |  |  | 	else if (perf_evsel__match(counter, HARDWARE, HW_CACHE_REFERENCES)) | 
					
						
							|  |  |  | 		update_stats(&runtime_cacherefs_stats[0], count[0]); | 
					
						
							| 
									
										
											  
											
												perf stat: Print out miss/hit ratio for L1 data-cache events
Print out this kind of l1-dcache-misses percentage:
 Performance counter stats for './bw_tcp localhost':
    29,956,262,201 cycles                   #    3.002 GHz                      (scaled from 85.14%)
     8,255,209,558 stalled-cycles           #   27.56% of all cycles are idle   (scaled from 86.56%)
     1,206,130,308 l1-dcache-misses         #   40.49% of all L1-dcache hits    (scaled from 86.30%)
     2,978,756,779 l1-dcache-refs           #  298.512 M/sec                    (scaled from 70.02%)
     8,861,956,159 instructions             #    0.30  insns per cycle
                                            #    0.93  stalled cycles per insn  (scaled from 84.27%)
     1,644,306,068 branches                 #  164.782 M/sec                    (scaled from 86.43%)
        74,778,443 branch-misses            #    4.55% of all branches          (scaled from 70.69%)
       9978.695711 task-clock               #    0.693 CPUs utilized
       14.404347983  seconds time elapsed
And color the result depending on the severity of cache-trashing.
Acked-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
Acked-by Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Link: http://lkml.kernel.org/n/tip-54gmz0zymaid84zcs7joq02p@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-04-27 13:25:24 +02:00
										 |  |  | 	else if (perf_evsel__match(counter, HW_CACHE, HW_CACHE_L1D)) | 
					
						
							|  |  |  | 		update_stats(&runtime_l1_dcache_stats[0], count[0]); | 
					
						
							| 
									
										
										
											
												perf stat: Add more cache-miss percentage printouts
Print out the cache-miss percentage as well if the cache refs were
collected, for all the generic cache event types.
Before:
   11,103,723,230 dTLB-loads                #  622.471 M/sec                    ( +-  0.30% )
       87,065,337 dTLB-load-misses          #    4.881 M/sec                    ( +-  0.90% )
After:
   11,353,713,242 dTLB-loads                #  626.020 M/sec                    ( +-  0.35% )
      113,393,472 dTLB-load-misses          #    1.00% of all dTLB cache hits   ( +-  0.49% )
Also ASCII color highlight too high percentages, them when it's executed on the console.
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Steven Rostedt <rostedt@goodmis.org>
Link: http://lkml.kernel.org/n/tip-lkhwxsevdbd9a8nymx0vxc3y@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-05-19 14:01:42 +02:00
										 |  |  | 	else if (perf_evsel__match(counter, HW_CACHE, HW_CACHE_L1I)) | 
					
						
							|  |  |  | 		update_stats(&runtime_l1_icache_stats[0], count[0]); | 
					
						
							|  |  |  | 	else if (perf_evsel__match(counter, HW_CACHE, HW_CACHE_LL)) | 
					
						
							|  |  |  | 		update_stats(&runtime_ll_cache_stats[0], count[0]); | 
					
						
							|  |  |  | 	else if (perf_evsel__match(counter, HW_CACHE, HW_CACHE_DTLB)) | 
					
						
							|  |  |  | 		update_stats(&runtime_dtlb_cache_stats[0], count[0]); | 
					
						
							|  |  |  | 	else if (perf_evsel__match(counter, HW_CACHE, HW_CACHE_ITLB)) | 
					
						
							|  |  |  | 		update_stats(&runtime_itlb_cache_stats[0], count[0]); | 
					
						
							| 
									
										
										
										
											2011-04-27 04:36:37 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-29 09:10:54 +02:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2009-05-29 09:10:54 +02:00
										 |  |  |  * Read out the results of a single counter: | 
					
						
							| 
									
										
										
										
											2010-11-16 11:05:01 +02:00
										 |  |  |  * aggregate counts across CPUs in system-wide mode | 
					
						
							| 
									
										
										
										
											2009-05-29 09:10:54 +02:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2011-01-03 17:45:52 -02:00
										 |  |  | static int read_counter_aggr(struct perf_evsel *counter) | 
					
						
							| 
									
										
										
										
											2009-05-29 09:10:54 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-01-03 16:39:04 -02:00
										 |  |  | 	struct perf_stat *ps = counter->priv; | 
					
						
							| 
									
										
										
										
											2011-01-03 17:45:52 -02:00
										 |  |  | 	u64 *count = counter->counts->aggr.values; | 
					
						
							|  |  |  | 	int i; | 
					
						
							| 
									
										
										
										
											2009-05-29 09:10:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-10 15:53:50 +08:00
										 |  |  | 	if (__perf_evsel__read(counter, perf_evsel__nr_cpus(counter), | 
					
						
							| 
									
										
										
										
											2013-03-11 16:43:14 +09:00
										 |  |  | 			       thread_map__nr(evsel_list->threads), scale) < 0) | 
					
						
							| 
									
										
										
										
											2011-01-03 17:45:52 -02:00
										 |  |  | 		return -1; | 
					
						
							| 
									
										
										
										
											2009-09-04 15:36:08 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	for (i = 0; i < 3; i++) | 
					
						
							| 
									
										
										
										
											2011-01-03 16:39:04 -02:00
										 |  |  | 		update_stats(&ps->res_stats[i], count[i]); | 
					
						
							| 
									
										
										
										
											2009-09-04 15:36:08 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (verbose) { | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 		fprintf(output, "%s: %" PRIu64 " %" PRIu64 " %" PRIu64 "\n", | 
					
						
							| 
									
										
										
										
											2012-06-12 12:34:58 -03:00
										 |  |  | 			perf_evsel__name(counter), count[0], count[1], count[2]); | 
					
						
							| 
									
										
										
										
											2009-09-04 15:36:08 +02:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-29 09:10:54 +02:00
										 |  |  | 	/*
 | 
					
						
							|  |  |  | 	 * Save the full runtime - to allow normalization during printout: | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2011-04-27 04:36:37 +02:00
										 |  |  | 	update_shadow_stats(counter, count); | 
					
						
							| 
									
										
										
										
											2011-01-03 17:45:52 -02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	return 0; | 
					
						
							| 
									
										
										
										
											2010-11-16 11:05:01 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * Read out the results of a single counter: | 
					
						
							|  |  |  |  * do not aggregate counts across CPUs in system-wide mode | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2011-01-03 17:45:52 -02:00
										 |  |  | static int read_counter(struct perf_evsel *counter) | 
					
						
							| 
									
										
										
										
											2010-11-16 11:05:01 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-01-03 17:45:52 -02:00
										 |  |  | 	u64 *count; | 
					
						
							| 
									
										
										
										
											2010-11-16 11:05:01 +02:00
										 |  |  | 	int cpu; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-10 15:53:50 +08:00
										 |  |  | 	for (cpu = 0; cpu < perf_evsel__nr_cpus(counter); cpu++) { | 
					
						
							| 
									
										
										
										
											2011-01-03 17:45:52 -02:00
										 |  |  | 		if (__perf_evsel__read_on_cpu(counter, cpu, 0, scale) < 0) | 
					
						
							|  |  |  | 			return -1; | 
					
						
							| 
									
										
										
										
											2010-11-16 11:05:01 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-01-03 17:45:52 -02:00
										 |  |  | 		count = counter->counts->cpu[cpu].values; | 
					
						
							| 
									
										
										
										
											2010-11-16 11:05:01 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-27 04:36:37 +02:00
										 |  |  | 		update_shadow_stats(counter, count); | 
					
						
							| 
									
										
										
										
											2010-11-16 11:05:01 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2011-01-03 17:45:52 -02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	return 0; | 
					
						
							| 
									
										
										
										
											2009-05-29 09:10:54 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												perf stat: Add interval printing
This patch adds a new printing mode for perf stat.  It allows interval
printing. That means perf stat can now print event deltas at regular
time interval.  This is useful to detect phases in programs.
The -I option enables interval printing. It expects an interval duration
in milliseconds. Minimum is 100ms. Once, activated perf stat prints
events deltas since last printout. All modes are supported.
$ perf stat -I 1000 -e cycles noploop 10
noploop for 10 seconds
 #           time             counts events
      1.000109853      2,388,560,546 cycles
      2.000262846      2,393,332,358 cycles
      3.000354131      2,393,176,537 cycles
      4.000439503      2,393,203,790 cycles
      5.000527075      2,393,167,675 cycles
      6.000609052      2,393,203,670 cycles
      7.000691082      2,393,175,678 cycles
The output format makes it easy to feed into a plotting program such as
gnuplot when the -I option is used in combination with the -x option:
$ perf stat -x, -I 1000 -e cycles noploop 10
noploop for 10 seconds
1.000084113,2378775498,cycles
2.000245798,2391056897,cycles
3.000354445,2392089414,cycles
4.000459115,2390936603,cycles
5.000565341,2392108173,cycles
Signed-off-by: Stephane Eranian <eranian@google.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1359460064-3060-3-git-send-email-eranian@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2013-01-29 12:47:44 +01:00
										 |  |  | static void print_interval(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	static int num_print_interval; | 
					
						
							|  |  |  | 	struct perf_evsel *counter; | 
					
						
							|  |  |  | 	struct perf_stat *ps; | 
					
						
							|  |  |  | 	struct timespec ts, rs; | 
					
						
							|  |  |  | 	char prefix[64]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 	if (aggr_mode == AGGR_GLOBAL) { | 
					
						
							| 
									
										
										
										
											2014-01-10 10:37:27 -03:00
										 |  |  | 		evlist__for_each(evsel_list, counter) { | 
					
						
							| 
									
										
											  
											
												perf stat: Add interval printing
This patch adds a new printing mode for perf stat.  It allows interval
printing. That means perf stat can now print event deltas at regular
time interval.  This is useful to detect phases in programs.
The -I option enables interval printing. It expects an interval duration
in milliseconds. Minimum is 100ms. Once, activated perf stat prints
events deltas since last printout. All modes are supported.
$ perf stat -I 1000 -e cycles noploop 10
noploop for 10 seconds
 #           time             counts events
      1.000109853      2,388,560,546 cycles
      2.000262846      2,393,332,358 cycles
      3.000354131      2,393,176,537 cycles
      4.000439503      2,393,203,790 cycles
      5.000527075      2,393,167,675 cycles
      6.000609052      2,393,203,670 cycles
      7.000691082      2,393,175,678 cycles
The output format makes it easy to feed into a plotting program such as
gnuplot when the -I option is used in combination with the -x option:
$ perf stat -x, -I 1000 -e cycles noploop 10
noploop for 10 seconds
1.000084113,2378775498,cycles
2.000245798,2391056897,cycles
3.000354445,2392089414,cycles
4.000459115,2390936603,cycles
5.000565341,2392108173,cycles
Signed-off-by: Stephane Eranian <eranian@google.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1359460064-3060-3-git-send-email-eranian@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2013-01-29 12:47:44 +01:00
										 |  |  | 			ps = counter->priv; | 
					
						
							|  |  |  | 			memset(ps->res_stats, 0, sizeof(ps->res_stats)); | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 			read_counter_aggr(counter); | 
					
						
							| 
									
										
											  
											
												perf stat: Add interval printing
This patch adds a new printing mode for perf stat.  It allows interval
printing. That means perf stat can now print event deltas at regular
time interval.  This is useful to detect phases in programs.
The -I option enables interval printing. It expects an interval duration
in milliseconds. Minimum is 100ms. Once, activated perf stat prints
events deltas since last printout. All modes are supported.
$ perf stat -I 1000 -e cycles noploop 10
noploop for 10 seconds
 #           time             counts events
      1.000109853      2,388,560,546 cycles
      2.000262846      2,393,332,358 cycles
      3.000354131      2,393,176,537 cycles
      4.000439503      2,393,203,790 cycles
      5.000527075      2,393,167,675 cycles
      6.000609052      2,393,203,670 cycles
      7.000691082      2,393,175,678 cycles
The output format makes it easy to feed into a plotting program such as
gnuplot when the -I option is used in combination with the -x option:
$ perf stat -x, -I 1000 -e cycles noploop 10
noploop for 10 seconds
1.000084113,2378775498,cycles
2.000245798,2391056897,cycles
3.000354445,2392089414,cycles
4.000459115,2390936603,cycles
5.000565341,2392108173,cycles
Signed-off-by: Stephane Eranian <eranian@google.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1359460064-3060-3-git-send-email-eranian@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2013-01-29 12:47:44 +01:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 	} else	{ | 
					
						
							| 
									
										
										
										
											2014-01-10 10:37:27 -03:00
										 |  |  | 		evlist__for_each(evsel_list, counter) { | 
					
						
							| 
									
										
											  
											
												perf stat: Add interval printing
This patch adds a new printing mode for perf stat.  It allows interval
printing. That means perf stat can now print event deltas at regular
time interval.  This is useful to detect phases in programs.
The -I option enables interval printing. It expects an interval duration
in milliseconds. Minimum is 100ms. Once, activated perf stat prints
events deltas since last printout. All modes are supported.
$ perf stat -I 1000 -e cycles noploop 10
noploop for 10 seconds
 #           time             counts events
      1.000109853      2,388,560,546 cycles
      2.000262846      2,393,332,358 cycles
      3.000354131      2,393,176,537 cycles
      4.000439503      2,393,203,790 cycles
      5.000527075      2,393,167,675 cycles
      6.000609052      2,393,203,670 cycles
      7.000691082      2,393,175,678 cycles
The output format makes it easy to feed into a plotting program such as
gnuplot when the -I option is used in combination with the -x option:
$ perf stat -x, -I 1000 -e cycles noploop 10
noploop for 10 seconds
1.000084113,2378775498,cycles
2.000245798,2391056897,cycles
3.000354445,2392089414,cycles
4.000459115,2390936603,cycles
5.000565341,2392108173,cycles
Signed-off-by: Stephane Eranian <eranian@google.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1359460064-3060-3-git-send-email-eranian@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2013-01-29 12:47:44 +01:00
										 |  |  | 			ps = counter->priv; | 
					
						
							|  |  |  | 			memset(ps->res_stats, 0, sizeof(ps->res_stats)); | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 			read_counter(counter); | 
					
						
							| 
									
										
											  
											
												perf stat: Add interval printing
This patch adds a new printing mode for perf stat.  It allows interval
printing. That means perf stat can now print event deltas at regular
time interval.  This is useful to detect phases in programs.
The -I option enables interval printing. It expects an interval duration
in milliseconds. Minimum is 100ms. Once, activated perf stat prints
events deltas since last printout. All modes are supported.
$ perf stat -I 1000 -e cycles noploop 10
noploop for 10 seconds
 #           time             counts events
      1.000109853      2,388,560,546 cycles
      2.000262846      2,393,332,358 cycles
      3.000354131      2,393,176,537 cycles
      4.000439503      2,393,203,790 cycles
      5.000527075      2,393,167,675 cycles
      6.000609052      2,393,203,670 cycles
      7.000691082      2,393,175,678 cycles
The output format makes it easy to feed into a plotting program such as
gnuplot when the -I option is used in combination with the -x option:
$ perf stat -x, -I 1000 -e cycles noploop 10
noploop for 10 seconds
1.000084113,2378775498,cycles
2.000245798,2391056897,cycles
3.000354445,2392089414,cycles
4.000459115,2390936603,cycles
5.000565341,2392108173,cycles
Signed-off-by: Stephane Eranian <eranian@google.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1359460064-3060-3-git-send-email-eranian@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2013-01-29 12:47:44 +01:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												perf stat: Add interval printing
This patch adds a new printing mode for perf stat.  It allows interval
printing. That means perf stat can now print event deltas at regular
time interval.  This is useful to detect phases in programs.
The -I option enables interval printing. It expects an interval duration
in milliseconds. Minimum is 100ms. Once, activated perf stat prints
events deltas since last printout. All modes are supported.
$ perf stat -I 1000 -e cycles noploop 10
noploop for 10 seconds
 #           time             counts events
      1.000109853      2,388,560,546 cycles
      2.000262846      2,393,332,358 cycles
      3.000354131      2,393,176,537 cycles
      4.000439503      2,393,203,790 cycles
      5.000527075      2,393,167,675 cycles
      6.000609052      2,393,203,670 cycles
      7.000691082      2,393,175,678 cycles
The output format makes it easy to feed into a plotting program such as
gnuplot when the -I option is used in combination with the -x option:
$ perf stat -x, -I 1000 -e cycles noploop 10
noploop for 10 seconds
1.000084113,2378775498,cycles
2.000245798,2391056897,cycles
3.000354445,2392089414,cycles
4.000459115,2390936603,cycles
5.000565341,2392108173,cycles
Signed-off-by: Stephane Eranian <eranian@google.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1359460064-3060-3-git-send-email-eranian@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2013-01-29 12:47:44 +01:00
										 |  |  | 	clock_gettime(CLOCK_MONOTONIC, &ts); | 
					
						
							|  |  |  | 	diff_timespec(&rs, &ts, &ref_time); | 
					
						
							|  |  |  | 	sprintf(prefix, "%6lu.%09lu%s", rs.tv_sec, rs.tv_nsec, csv_sep); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (num_print_interval == 0 && !csv_output) { | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 		switch (aggr_mode) { | 
					
						
							|  |  |  | 		case AGGR_SOCKET: | 
					
						
							| 
									
										
										
										
											2013-11-12 17:58:49 +01:00
										 |  |  | 			fprintf(output, "#           time socket cpus             counts %*s events\n", unit_width, "unit"); | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:29 +01:00
										 |  |  | 		case AGGR_CORE: | 
					
						
							| 
									
										
										
										
											2013-11-12 17:58:49 +01:00
										 |  |  | 			fprintf(output, "#           time core         cpus             counts %*s events\n", unit_width, "unit"); | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:29 +01:00
										 |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 		case AGGR_NONE: | 
					
						
							| 
									
										
										
										
											2013-11-12 17:58:49 +01:00
										 |  |  | 			fprintf(output, "#           time CPU                counts %*s events\n", unit_width, "unit"); | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 			break; | 
					
						
							|  |  |  | 		case AGGR_GLOBAL: | 
					
						
							|  |  |  | 		default: | 
					
						
							| 
									
										
										
										
											2013-11-12 17:58:49 +01:00
										 |  |  | 			fprintf(output, "#           time             counts %*s events\n", unit_width, "unit"); | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 		} | 
					
						
							| 
									
										
											  
											
												perf stat: Add interval printing
This patch adds a new printing mode for perf stat.  It allows interval
printing. That means perf stat can now print event deltas at regular
time interval.  This is useful to detect phases in programs.
The -I option enables interval printing. It expects an interval duration
in milliseconds. Minimum is 100ms. Once, activated perf stat prints
events deltas since last printout. All modes are supported.
$ perf stat -I 1000 -e cycles noploop 10
noploop for 10 seconds
 #           time             counts events
      1.000109853      2,388,560,546 cycles
      2.000262846      2,393,332,358 cycles
      3.000354131      2,393,176,537 cycles
      4.000439503      2,393,203,790 cycles
      5.000527075      2,393,167,675 cycles
      6.000609052      2,393,203,670 cycles
      7.000691082      2,393,175,678 cycles
The output format makes it easy to feed into a plotting program such as
gnuplot when the -I option is used in combination with the -x option:
$ perf stat -x, -I 1000 -e cycles noploop 10
noploop for 10 seconds
1.000084113,2378775498,cycles
2.000245798,2391056897,cycles
3.000354445,2392089414,cycles
4.000459115,2390936603,cycles
5.000565341,2392108173,cycles
Signed-off-by: Stephane Eranian <eranian@google.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1359460064-3060-3-git-send-email-eranian@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2013-01-29 12:47:44 +01:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (++num_print_interval == 25) | 
					
						
							|  |  |  | 		num_print_interval = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 	switch (aggr_mode) { | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:29 +01:00
										 |  |  | 	case AGGR_CORE: | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 	case AGGR_SOCKET: | 
					
						
							|  |  |  | 		print_aggr(prefix); | 
					
						
							|  |  |  | 		break; | 
					
						
							|  |  |  | 	case AGGR_NONE: | 
					
						
							| 
									
										
										
										
											2014-01-10 10:37:27 -03:00
										 |  |  | 		evlist__for_each(evsel_list, counter) | 
					
						
							| 
									
										
											  
											
												perf stat: Add interval printing
This patch adds a new printing mode for perf stat.  It allows interval
printing. That means perf stat can now print event deltas at regular
time interval.  This is useful to detect phases in programs.
The -I option enables interval printing. It expects an interval duration
in milliseconds. Minimum is 100ms. Once, activated perf stat prints
events deltas since last printout. All modes are supported.
$ perf stat -I 1000 -e cycles noploop 10
noploop for 10 seconds
 #           time             counts events
      1.000109853      2,388,560,546 cycles
      2.000262846      2,393,332,358 cycles
      3.000354131      2,393,176,537 cycles
      4.000439503      2,393,203,790 cycles
      5.000527075      2,393,167,675 cycles
      6.000609052      2,393,203,670 cycles
      7.000691082      2,393,175,678 cycles
The output format makes it easy to feed into a plotting program such as
gnuplot when the -I option is used in combination with the -x option:
$ perf stat -x, -I 1000 -e cycles noploop 10
noploop for 10 seconds
1.000084113,2378775498,cycles
2.000245798,2391056897,cycles
3.000354445,2392089414,cycles
4.000459115,2390936603,cycles
5.000565341,2392108173,cycles
Signed-off-by: Stephane Eranian <eranian@google.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1359460064-3060-3-git-send-email-eranian@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2013-01-29 12:47:44 +01:00
										 |  |  | 			print_counter(counter, prefix); | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 		break; | 
					
						
							|  |  |  | 	case AGGR_GLOBAL: | 
					
						
							|  |  |  | 	default: | 
					
						
							| 
									
										
										
										
											2014-01-10 10:37:27 -03:00
										 |  |  | 		evlist__for_each(evsel_list, counter) | 
					
						
							| 
									
										
											  
											
												perf stat: Add interval printing
This patch adds a new printing mode for perf stat.  It allows interval
printing. That means perf stat can now print event deltas at regular
time interval.  This is useful to detect phases in programs.
The -I option enables interval printing. It expects an interval duration
in milliseconds. Minimum is 100ms. Once, activated perf stat prints
events deltas since last printout. All modes are supported.
$ perf stat -I 1000 -e cycles noploop 10
noploop for 10 seconds
 #           time             counts events
      1.000109853      2,388,560,546 cycles
      2.000262846      2,393,332,358 cycles
      3.000354131      2,393,176,537 cycles
      4.000439503      2,393,203,790 cycles
      5.000527075      2,393,167,675 cycles
      6.000609052      2,393,203,670 cycles
      7.000691082      2,393,175,678 cycles
The output format makes it easy to feed into a plotting program such as
gnuplot when the -I option is used in combination with the -x option:
$ perf stat -x, -I 1000 -e cycles noploop 10
noploop for 10 seconds
1.000084113,2378775498,cycles
2.000245798,2391056897,cycles
3.000354445,2392089414,cycles
4.000459115,2390936603,cycles
5.000565341,2392108173,cycles
Signed-off-by: Stephane Eranian <eranian@google.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1359460064-3060-3-git-send-email-eranian@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2013-01-29 12:47:44 +01:00
										 |  |  | 			print_counter_aggr(counter, prefix); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2013-08-02 17:41:12 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	fflush(output); | 
					
						
							| 
									
										
											  
											
												perf stat: Add interval printing
This patch adds a new printing mode for perf stat.  It allows interval
printing. That means perf stat can now print event deltas at regular
time interval.  This is useful to detect phases in programs.
The -I option enables interval printing. It expects an interval duration
in milliseconds. Minimum is 100ms. Once, activated perf stat prints
events deltas since last printout. All modes are supported.
$ perf stat -I 1000 -e cycles noploop 10
noploop for 10 seconds
 #           time             counts events
      1.000109853      2,388,560,546 cycles
      2.000262846      2,393,332,358 cycles
      3.000354131      2,393,176,537 cycles
      4.000439503      2,393,203,790 cycles
      5.000527075      2,393,167,675 cycles
      6.000609052      2,393,203,670 cycles
      7.000691082      2,393,175,678 cycles
The output format makes it easy to feed into a plotting program such as
gnuplot when the -I option is used in combination with the -x option:
$ perf stat -x, -I 1000 -e cycles noploop 10
noploop for 10 seconds
1.000084113,2378775498,cycles
2.000245798,2391056897,cycles
3.000354445,2392089414,cycles
4.000459115,2390936603,cycles
5.000565341,2392108173,cycles
Signed-off-by: Stephane Eranian <eranian@google.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1359460064-3060-3-git-send-email-eranian@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2013-01-29 12:47:44 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-02 17:41:11 -07:00
										 |  |  | static void handle_initial_delay(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	struct perf_evsel *counter; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (initial_delay) { | 
					
						
							|  |  |  | 		const int ncpus = cpu_map__nr(evsel_list->cpus), | 
					
						
							|  |  |  | 			nthreads = thread_map__nr(evsel_list->threads); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		usleep(initial_delay * 1000); | 
					
						
							| 
									
										
										
										
											2014-01-10 10:37:27 -03:00
										 |  |  | 		evlist__for_each(evsel_list, counter) | 
					
						
							| 
									
										
										
										
											2013-08-02 17:41:11 -07:00
										 |  |  | 			perf_evsel__enable(counter, ncpus, nthreads); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-02 15:11:25 -03:00
										 |  |  | static volatile int workload_exec_errno; | 
					
						
							| 
									
										
										
										
											2013-12-28 15:45:08 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * perf_evlist__prepare_workload will send a SIGUSR1 | 
					
						
							|  |  |  |  * if the fork fails, since we asked by setting its | 
					
						
							|  |  |  |  * want_signal to true. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2014-01-02 15:11:25 -03:00
										 |  |  | static void workload_exec_failed_signal(int signo __maybe_unused, siginfo_t *info, | 
					
						
							|  |  |  | 					void *ucontext __maybe_unused) | 
					
						
							| 
									
										
										
										
											2013-12-28 15:45:08 -03:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2014-01-02 15:11:25 -03:00
										 |  |  | 	workload_exec_errno = info->si_value.sival_int; | 
					
						
							| 
									
										
										
										
											2013-12-28 15:45:08 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-11 16:43:18 +09:00
										 |  |  | static int __run_perf_stat(int argc, const char **argv) | 
					
						
							| 
									
										
										
										
											2009-06-13 14:57:28 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-12-13 15:10:58 -03:00
										 |  |  | 	char msg[512]; | 
					
						
							| 
									
										
										
										
											2009-06-13 14:57:28 +02:00
										 |  |  | 	unsigned long long t0, t1; | 
					
						
							| 
									
										
										
										
											2012-11-12 18:34:00 +01:00
										 |  |  | 	struct perf_evsel *counter; | 
					
						
							| 
									
										
											  
											
												perf stat: Add interval printing
This patch adds a new printing mode for perf stat.  It allows interval
printing. That means perf stat can now print event deltas at regular
time interval.  This is useful to detect phases in programs.
The -I option enables interval printing. It expects an interval duration
in milliseconds. Minimum is 100ms. Once, activated perf stat prints
events deltas since last printout. All modes are supported.
$ perf stat -I 1000 -e cycles noploop 10
noploop for 10 seconds
 #           time             counts events
      1.000109853      2,388,560,546 cycles
      2.000262846      2,393,332,358 cycles
      3.000354131      2,393,176,537 cycles
      4.000439503      2,393,203,790 cycles
      5.000527075      2,393,167,675 cycles
      6.000609052      2,393,203,670 cycles
      7.000691082      2,393,175,678 cycles
The output format makes it easy to feed into a plotting program such as
gnuplot when the -I option is used in combination with the -x option:
$ perf stat -x, -I 1000 -e cycles noploop 10
noploop for 10 seconds
1.000084113,2378775498,cycles
2.000245798,2391056897,cycles
3.000354445,2392089414,cycles
4.000459115,2390936603,cycles
5.000565341,2392108173,cycles
Signed-off-by: Stephane Eranian <eranian@google.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1359460064-3060-3-git-send-email-eranian@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2013-01-29 12:47:44 +01:00
										 |  |  | 	struct timespec ts; | 
					
						
							| 
									
										
										
										
											2013-11-12 17:58:49 +01:00
										 |  |  | 	size_t l; | 
					
						
							| 
									
										
										
										
											2009-06-13 14:57:28 +02:00
										 |  |  | 	int status = 0; | 
					
						
							| 
									
										
										
										
											2010-03-18 11:36:03 -03:00
										 |  |  | 	const bool forks = (argc > 0); | 
					
						
							| 
									
										
										
										
											2009-06-13 14:57:28 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												perf stat: Add interval printing
This patch adds a new printing mode for perf stat.  It allows interval
printing. That means perf stat can now print event deltas at regular
time interval.  This is useful to detect phases in programs.
The -I option enables interval printing. It expects an interval duration
in milliseconds. Minimum is 100ms. Once, activated perf stat prints
events deltas since last printout. All modes are supported.
$ perf stat -I 1000 -e cycles noploop 10
noploop for 10 seconds
 #           time             counts events
      1.000109853      2,388,560,546 cycles
      2.000262846      2,393,332,358 cycles
      3.000354131      2,393,176,537 cycles
      4.000439503      2,393,203,790 cycles
      5.000527075      2,393,167,675 cycles
      6.000609052      2,393,203,670 cycles
      7.000691082      2,393,175,678 cycles
The output format makes it easy to feed into a plotting program such as
gnuplot when the -I option is used in combination with the -x option:
$ perf stat -x, -I 1000 -e cycles noploop 10
noploop for 10 seconds
1.000084113,2378775498,cycles
2.000245798,2391056897,cycles
3.000354445,2392089414,cycles
4.000459115,2390936603,cycles
5.000565341,2392108173,cycles
Signed-off-by: Stephane Eranian <eranian@google.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1359460064-3060-3-git-send-email-eranian@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2013-01-29 12:47:44 +01:00
										 |  |  | 	if (interval) { | 
					
						
							|  |  |  | 		ts.tv_sec  = interval / 1000; | 
					
						
							|  |  |  | 		ts.tv_nsec = (interval % 1000) * 1000000; | 
					
						
							|  |  |  | 	} else { | 
					
						
							|  |  |  | 		ts.tv_sec  = 1; | 
					
						
							|  |  |  | 		ts.tv_nsec = 0; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-31 16:05:50 +08:00
										 |  |  | 	if (forks) { | 
					
						
							| 
									
										
										
										
											2014-01-03 14:56:49 -03:00
										 |  |  | 		if (perf_evlist__prepare_workload(evsel_list, &target, argv, false, | 
					
						
							|  |  |  | 						  workload_exec_failed_signal) < 0) { | 
					
						
							| 
									
										
										
										
											2013-03-11 16:43:18 +09:00
										 |  |  | 			perror("failed to prepare workload"); | 
					
						
							|  |  |  | 			return -1; | 
					
						
							| 
									
										
										
										
											2009-12-31 16:05:50 +08:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2013-09-30 18:01:11 +09:00
										 |  |  | 		child_pid = evsel_list->workload.pid; | 
					
						
							| 
									
										
										
										
											2009-06-29 21:13:21 +10:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												perf tools: Enable grouping logic for parsed events
This patch adds a functionality that allows to create event groups
based on the way they are specified on the command line. Adding
functionality to the '{}' group syntax introduced in earlier patch.
The current '--group/-g' option behaviour remains intact. If you
specify it for record/stat/top command, all the specified events
become members of a single group with the first event as a group
leader.
With the new '{}' group syntax you can create group like:
  # perf record -e '{cycles,faults}' ls
resulting in single event group containing 'cycles' and 'faults'
events, with cycles event as group leader.
All groups are created with regards to threads and cpus. Thus
recording an event group within a 2 threads on server with
4 CPUs will create 8 separate groups.
Examples (first event in brackets is group leader):
  # 1 group (cpu-clock,task-clock)
  perf record --group -e cpu-clock,task-clock ls
  perf record -e '{cpu-clock,task-clock}' ls
  # 2 groups (cpu-clock,task-clock) (minor-faults,major-faults)
  perf record -e '{cpu-clock,task-clock},{minor-faults,major-faults}' ls
  # 1 group (cpu-clock,task-clock,minor-faults,major-faults)
  perf record --group -e cpu-clock,task-clock -e minor-faults,major-faults ls
  perf record -e '{cpu-clock,task-clock,minor-faults,major-faults}' ls
  # 2 groups (cpu-clock,task-clock) (minor-faults,major-faults)
  perf record -e '{cpu-clock,task-clock} -e '{minor-faults,major-faults}' \
   -e instructions ls
  # 1 group
  # (cpu-clock,task-clock,minor-faults,major-faults,instructions)
  perf record --group -e cpu-clock,task-clock \
   -e minor-faults,major-faults -e instructions ls perf record -e
'{cpu-clock,task-clock,minor-faults,major-faults,instructions}' ls
It's possible to use standard event modifier for a group, which spans
over all events in the group and updates each event modifier settings,
for example:
  # perf record -r '{faults:k,cache-references}:p'
resulting in ':kp' modifier being used for 'faults' and ':p' modifier
being used for 'cache-references' event.
Reviewed-by: Namhyung Kim <namhyung@kernel.org>
Signed-off-by: Jiri Olsa <jolsa@redhat.com>
Acked-by: Peter Zijlstra <peterz@infradead.org>
Cc: Andi Kleen <andi@firstfloor.org>
Cc: Arnaldo Carvalho de Melo <acme@ghostprotocols.net>
Cc: Corey Ashford <cjashfor@linux.vnet.ibm.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Thomas Gleixner <tglx@linutronix.de>
Cc: Ulrich Drepper <drepper@gmail.com>
Link: http://lkml.kernel.org/n/tip-ho42u0wcr8mn1otkalqi13qp@git.kernel.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2012-08-08 12:22:36 +02:00
										 |  |  | 	if (group) | 
					
						
							| 
									
										
										
										
											2012-08-14 16:35:48 -03:00
										 |  |  | 		perf_evlist__set_leader(evsel_list); | 
					
						
							| 
									
										
											  
											
												perf tools: Enable grouping logic for parsed events
This patch adds a functionality that allows to create event groups
based on the way they are specified on the command line. Adding
functionality to the '{}' group syntax introduced in earlier patch.
The current '--group/-g' option behaviour remains intact. If you
specify it for record/stat/top command, all the specified events
become members of a single group with the first event as a group
leader.
With the new '{}' group syntax you can create group like:
  # perf record -e '{cycles,faults}' ls
resulting in single event group containing 'cycles' and 'faults'
events, with cycles event as group leader.
All groups are created with regards to threads and cpus. Thus
recording an event group within a 2 threads on server with
4 CPUs will create 8 separate groups.
Examples (first event in brackets is group leader):
  # 1 group (cpu-clock,task-clock)
  perf record --group -e cpu-clock,task-clock ls
  perf record -e '{cpu-clock,task-clock}' ls
  # 2 groups (cpu-clock,task-clock) (minor-faults,major-faults)
  perf record -e '{cpu-clock,task-clock},{minor-faults,major-faults}' ls
  # 1 group (cpu-clock,task-clock,minor-faults,major-faults)
  perf record --group -e cpu-clock,task-clock -e minor-faults,major-faults ls
  perf record -e '{cpu-clock,task-clock,minor-faults,major-faults}' ls
  # 2 groups (cpu-clock,task-clock) (minor-faults,major-faults)
  perf record -e '{cpu-clock,task-clock} -e '{minor-faults,major-faults}' \
   -e instructions ls
  # 1 group
  # (cpu-clock,task-clock,minor-faults,major-faults,instructions)
  perf record --group -e cpu-clock,task-clock \
   -e minor-faults,major-faults -e instructions ls perf record -e
'{cpu-clock,task-clock,minor-faults,major-faults,instructions}' ls
It's possible to use standard event modifier for a group, which spans
over all events in the group and updates each event modifier settings,
for example:
  # perf record -r '{faults:k,cache-references}:p'
resulting in ':kp' modifier being used for 'faults' and ':p' modifier
being used for 'cache-references' event.
Reviewed-by: Namhyung Kim <namhyung@kernel.org>
Signed-off-by: Jiri Olsa <jolsa@redhat.com>
Acked-by: Peter Zijlstra <peterz@infradead.org>
Cc: Andi Kleen <andi@firstfloor.org>
Cc: Arnaldo Carvalho de Melo <acme@ghostprotocols.net>
Cc: Corey Ashford <cjashfor@linux.vnet.ibm.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Thomas Gleixner <tglx@linutronix.de>
Cc: Ulrich Drepper <drepper@gmail.com>
Link: http://lkml.kernel.org/n/tip-ho42u0wcr8mn1otkalqi13qp@git.kernel.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2012-08-08 12:22:36 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-10 10:37:27 -03:00
										 |  |  | 	evlist__for_each(evsel_list, counter) { | 
					
						
							| 
									
										
										
										
											2012-11-12 18:34:00 +01:00
										 |  |  | 		if (create_perf_stat_counter(counter) < 0) { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:29:16 -06:00
										 |  |  | 			/*
 | 
					
						
							|  |  |  | 			 * PPC returns ENXIO for HW counters until 2.6.37 | 
					
						
							|  |  |  | 			 * (behavior changed with commit b0a873e). | 
					
						
							|  |  |  | 			 */ | 
					
						
							| 
									
										
										
										
											2011-12-02 09:38:33 +11:00
										 |  |  | 			if (errno == EINVAL || errno == ENOSYS || | 
					
						
							| 
									
										
										
										
											2012-05-08 09:29:16 -06:00
										 |  |  | 			    errno == ENOENT || errno == EOPNOTSUPP || | 
					
						
							|  |  |  | 			    errno == ENXIO) { | 
					
						
							| 
									
										
										
										
											2011-04-29 16:04:15 -06:00
										 |  |  | 				if (verbose) | 
					
						
							|  |  |  | 					ui__warning("%s event is not supported by the kernel.\n", | 
					
						
							| 
									
										
										
										
											2012-06-12 12:34:58 -03:00
										 |  |  | 						    perf_evsel__name(counter)); | 
					
						
							| 
									
										
										
										
											2011-05-30 08:55:59 -06:00
										 |  |  | 				counter->supported = false; | 
					
						
							| 
									
										
										
										
											2011-04-28 08:48:42 +02:00
										 |  |  | 				continue; | 
					
						
							| 
									
										
										
										
											2011-04-29 16:04:15 -06:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2011-04-28 08:48:42 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-13 15:10:58 -03:00
										 |  |  | 			perf_evsel__open_strerror(counter, &target, | 
					
						
							|  |  |  | 						  errno, msg, sizeof(msg)); | 
					
						
							|  |  |  | 			ui__error("%s\n", msg); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-01-03 17:48:12 -02:00
										 |  |  | 			if (child_pid != -1) | 
					
						
							|  |  |  | 				kill(child_pid, SIGTERM); | 
					
						
							| 
									
										
										
										
											2012-08-26 12:24:44 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-01-03 17:48:12 -02:00
										 |  |  | 			return -1; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2011-05-30 08:55:59 -06:00
										 |  |  | 		counter->supported = true; | 
					
						
							| 
									
										
										
										
											2013-11-12 17:58:49 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		l = strlen(counter->unit); | 
					
						
							|  |  |  | 		if (l > unit_width) | 
					
						
							|  |  |  | 			unit_width = l; | 
					
						
							| 
									
										
										
										
											2010-03-22 13:10:28 -03:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-06-13 14:57:28 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-26 14:43:13 -03:00
										 |  |  | 	if (perf_evlist__apply_filters(evsel_list)) { | 
					
						
							| 
									
										
										
										
											2011-03-14 16:40:30 +01:00
										 |  |  | 		error("failed to set filter with %d (%s)\n", errno, | 
					
						
							|  |  |  | 			strerror(errno)); | 
					
						
							|  |  |  | 		return -1; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-13 14:57:28 +02:00
										 |  |  | 	/*
 | 
					
						
							|  |  |  | 	 * Enable counters and exec the command: | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	t0 = rdclock(); | 
					
						
							| 
									
										
											  
											
												perf stat: Add interval printing
This patch adds a new printing mode for perf stat.  It allows interval
printing. That means perf stat can now print event deltas at regular
time interval.  This is useful to detect phases in programs.
The -I option enables interval printing. It expects an interval duration
in milliseconds. Minimum is 100ms. Once, activated perf stat prints
events deltas since last printout. All modes are supported.
$ perf stat -I 1000 -e cycles noploop 10
noploop for 10 seconds
 #           time             counts events
      1.000109853      2,388,560,546 cycles
      2.000262846      2,393,332,358 cycles
      3.000354131      2,393,176,537 cycles
      4.000439503      2,393,203,790 cycles
      5.000527075      2,393,167,675 cycles
      6.000609052      2,393,203,670 cycles
      7.000691082      2,393,175,678 cycles
The output format makes it easy to feed into a plotting program such as
gnuplot when the -I option is used in combination with the -x option:
$ perf stat -x, -I 1000 -e cycles noploop 10
noploop for 10 seconds
1.000084113,2378775498,cycles
2.000245798,2391056897,cycles
3.000354445,2392089414,cycles
4.000459115,2390936603,cycles
5.000565341,2392108173,cycles
Signed-off-by: Stephane Eranian <eranian@google.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1359460064-3060-3-git-send-email-eranian@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2013-01-29 12:47:44 +01:00
										 |  |  | 	clock_gettime(CLOCK_MONOTONIC, &ref_time); | 
					
						
							| 
									
										
										
										
											2009-06-13 14:57:28 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-31 16:05:50 +08:00
										 |  |  | 	if (forks) { | 
					
						
							| 
									
										
										
										
											2013-03-11 16:43:18 +09:00
										 |  |  | 		perf_evlist__start_workload(evsel_list); | 
					
						
							| 
									
										
										
										
											2013-08-02 17:41:11 -07:00
										 |  |  | 		handle_initial_delay(); | 
					
						
							| 
									
										
										
										
											2013-03-11 16:43:18 +09:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												perf stat: Add interval printing
This patch adds a new printing mode for perf stat.  It allows interval
printing. That means perf stat can now print event deltas at regular
time interval.  This is useful to detect phases in programs.
The -I option enables interval printing. It expects an interval duration
in milliseconds. Minimum is 100ms. Once, activated perf stat prints
events deltas since last printout. All modes are supported.
$ perf stat -I 1000 -e cycles noploop 10
noploop for 10 seconds
 #           time             counts events
      1.000109853      2,388,560,546 cycles
      2.000262846      2,393,332,358 cycles
      3.000354131      2,393,176,537 cycles
      4.000439503      2,393,203,790 cycles
      5.000527075      2,393,167,675 cycles
      6.000609052      2,393,203,670 cycles
      7.000691082      2,393,175,678 cycles
The output format makes it easy to feed into a plotting program such as
gnuplot when the -I option is used in combination with the -x option:
$ perf stat -x, -I 1000 -e cycles noploop 10
noploop for 10 seconds
1.000084113,2378775498,cycles
2.000245798,2391056897,cycles
3.000354445,2392089414,cycles
4.000459115,2390936603,cycles
5.000565341,2392108173,cycles
Signed-off-by: Stephane Eranian <eranian@google.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1359460064-3060-3-git-send-email-eranian@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2013-01-29 12:47:44 +01:00
										 |  |  | 		if (interval) { | 
					
						
							|  |  |  | 			while (!waitpid(child_pid, &status, WNOHANG)) { | 
					
						
							|  |  |  | 				nanosleep(&ts, NULL); | 
					
						
							|  |  |  | 				print_interval(); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-12-31 16:05:50 +08:00
										 |  |  | 		wait(&status); | 
					
						
							| 
									
										
										
										
											2013-12-28 15:45:08 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-02 15:11:25 -03:00
										 |  |  | 		if (workload_exec_errno) { | 
					
						
							|  |  |  | 			const char *emsg = strerror_r(workload_exec_errno, msg, sizeof(msg)); | 
					
						
							|  |  |  | 			pr_err("Workload failed: %s\n", emsg); | 
					
						
							| 
									
										
										
										
											2013-12-28 15:45:08 -03:00
										 |  |  | 			return -1; | 
					
						
							| 
									
										
										
										
											2014-01-02 15:11:25 -03:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2013-12-28 15:45:08 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-15 14:31:40 -07:00
										 |  |  | 		if (WIFSIGNALED(status)) | 
					
						
							|  |  |  | 			psignal(WTERMSIG(status), argv[0]); | 
					
						
							| 
									
										
										
										
											2009-12-31 16:05:50 +08:00
										 |  |  | 	} else { | 
					
						
							| 
									
										
										
										
											2013-08-02 17:41:11 -07:00
										 |  |  | 		handle_initial_delay(); | 
					
						
							| 
									
										
											  
											
												perf stat: Add interval printing
This patch adds a new printing mode for perf stat.  It allows interval
printing. That means perf stat can now print event deltas at regular
time interval.  This is useful to detect phases in programs.
The -I option enables interval printing. It expects an interval duration
in milliseconds. Minimum is 100ms. Once, activated perf stat prints
events deltas since last printout. All modes are supported.
$ perf stat -I 1000 -e cycles noploop 10
noploop for 10 seconds
 #           time             counts events
      1.000109853      2,388,560,546 cycles
      2.000262846      2,393,332,358 cycles
      3.000354131      2,393,176,537 cycles
      4.000439503      2,393,203,790 cycles
      5.000527075      2,393,167,675 cycles
      6.000609052      2,393,203,670 cycles
      7.000691082      2,393,175,678 cycles
The output format makes it easy to feed into a plotting program such as
gnuplot when the -I option is used in combination with the -x option:
$ perf stat -x, -I 1000 -e cycles noploop 10
noploop for 10 seconds
1.000084113,2378775498,cycles
2.000245798,2391056897,cycles
3.000354445,2392089414,cycles
4.000459115,2390936603,cycles
5.000565341,2392108173,cycles
Signed-off-by: Stephane Eranian <eranian@google.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1359460064-3060-3-git-send-email-eranian@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2013-01-29 12:47:44 +01:00
										 |  |  | 		while (!done) { | 
					
						
							|  |  |  | 			nanosleep(&ts, NULL); | 
					
						
							|  |  |  | 			if (interval) | 
					
						
							|  |  |  | 				print_interval(); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-12-31 16:05:50 +08:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-06-13 14:57:28 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	t1 = rdclock(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-04 15:36:08 +02:00
										 |  |  | 	update_stats(&walltime_nsecs_stats, t1 - t0); | 
					
						
							| 
									
										
										
										
											2009-06-13 14:57:28 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 	if (aggr_mode == AGGR_GLOBAL) { | 
					
						
							| 
									
										
										
										
											2014-01-10 10:37:27 -03:00
										 |  |  | 		evlist__for_each(evsel_list, counter) { | 
					
						
							| 
									
										
										
										
											2010-11-16 11:05:01 +02:00
										 |  |  | 			read_counter_aggr(counter); | 
					
						
							| 
									
										
										
										
											2012-09-10 15:53:50 +08:00
										 |  |  | 			perf_evsel__close_fd(counter, perf_evsel__nr_cpus(counter), | 
					
						
							| 
									
										
										
										
											2013-03-11 16:43:14 +09:00
										 |  |  | 					     thread_map__nr(evsel_list->threads)); | 
					
						
							| 
									
										
										
										
											2011-01-03 17:45:52 -02:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 	} else { | 
					
						
							| 
									
										
										
										
											2014-01-10 10:37:27 -03:00
										 |  |  | 		evlist__for_each(evsel_list, counter) { | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 			read_counter(counter); | 
					
						
							|  |  |  | 			perf_evsel__close_fd(counter, perf_evsel__nr_cpus(counter), 1); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2010-11-16 11:05:01 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2011-01-03 17:45:52 -02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-13 14:57:28 +02:00
										 |  |  | 	return WEXITSTATUS(status); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-03 17:34:42 -03:00
										 |  |  | static int run_perf_stat(int argc, const char **argv) | 
					
						
							| 
									
										
										
										
											2012-10-23 13:40:14 +02:00
										 |  |  | { | 
					
						
							|  |  |  | 	int ret; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (pre_cmd) { | 
					
						
							|  |  |  | 		ret = system(pre_cmd); | 
					
						
							|  |  |  | 		if (ret) | 
					
						
							|  |  |  | 			return ret; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (sync_run) | 
					
						
							|  |  |  | 		sync(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	ret = __run_perf_stat(argc, argv); | 
					
						
							|  |  |  | 	if (ret) | 
					
						
							|  |  |  | 		return ret; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (post_cmd) { | 
					
						
							|  |  |  | 		ret = system(post_cmd); | 
					
						
							|  |  |  | 		if (ret) | 
					
						
							|  |  |  | 			return ret; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return ret; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-27 05:35:39 +02:00
										 |  |  | static void print_noise_pct(double total, double avg) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-09-17 16:31:14 +08:00
										 |  |  | 	double pct = rel_stddev_stats(total, avg); | 
					
						
							| 
									
										
										
										
											2011-04-27 05:35:39 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												perf stat: Add noise output for csv mode
Previously, when you want perf-stat to output the statistics in
csv mode, no information of the noise will be printed out.
For example right now we output this --repeat information:
 ./perf stat -r3 -x, sleep 1
 1.164789,task-clock
 8,context-switches
 0,CPU-migrations
 219,page-faults
 3337800,cycles
With this patch, the output will be appended with an additional
entry for the noise value:
 ./perf stat -r3 -x, sleep 1
 1.164789,task-clock,3.75%
 8,context-switches,75.00%
 0,CPU-migrations,100.00%
 219,page-faults,0.00%
 3337800,cycles,3.36%
Signed-off-by: Zhengyu He <zhengyuh@google.com>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Arnaldo Carvalho de Melo <acme@ghostprotocols.net>
Cc: Stephane Eranian <eranian@google.com>
Cc: Venkatesh Pallipadi <venki@google.com>
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Link: http://lkml.kernel.org/r/1308861942-4945-1-git-send-email-zhengyuh@google.com
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-06-23 13:45:42 -07:00
										 |  |  | 	if (csv_output) | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 		fprintf(output, "%s%.2f%%", csv_sep, pct); | 
					
						
							| 
									
										
										
										
											2011-09-07 17:14:02 -06:00
										 |  |  | 	else if (pct) | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 		fprintf(output, "  ( +-%6.2f%% )", pct); | 
					
						
							| 
									
										
										
										
											2011-04-27 05:35:39 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-01-03 16:39:04 -02:00
										 |  |  | static void print_noise(struct perf_evsel *evsel, double avg) | 
					
						
							| 
									
										
										
										
											2009-06-13 14:57:28 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-01-03 16:39:04 -02:00
										 |  |  | 	struct perf_stat *ps; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-04 18:23:38 +02:00
										 |  |  | 	if (run_count == 1) | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-01-03 16:39:04 -02:00
										 |  |  | 	ps = evsel->priv; | 
					
						
							| 
									
										
										
										
											2011-04-27 05:35:39 +02:00
										 |  |  | 	print_noise_pct(stddev_stats(&ps->res_stats[0]), avg); | 
					
						
							| 
									
										
										
										
											2009-06-13 14:57:28 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:29 +01:00
										 |  |  | static void aggr_printout(struct perf_evsel *evsel, int id, int nr) | 
					
						
							| 
									
										
										
										
											2009-06-13 13:35:00 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 	switch (aggr_mode) { | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:29 +01:00
										 |  |  | 	case AGGR_CORE: | 
					
						
							|  |  |  | 		fprintf(output, "S%d-C%*d%s%*d%s", | 
					
						
							|  |  |  | 			cpu_map__id_to_socket(id), | 
					
						
							|  |  |  | 			csv_output ? 0 : -8, | 
					
						
							|  |  |  | 			cpu_map__id_to_cpu(id), | 
					
						
							|  |  |  | 			csv_sep, | 
					
						
							|  |  |  | 			csv_output ? 0 : 4, | 
					
						
							|  |  |  | 			nr, | 
					
						
							|  |  |  | 			csv_sep); | 
					
						
							|  |  |  | 		break; | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 	case AGGR_SOCKET: | 
					
						
							|  |  |  | 		fprintf(output, "S%*d%s%*d%s", | 
					
						
							| 
									
										
										
										
											2013-02-06 15:46:02 +01:00
										 |  |  | 			csv_output ? 0 : -5, | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:29 +01:00
										 |  |  | 			id, | 
					
						
							| 
									
										
										
										
											2013-02-06 15:46:02 +01:00
										 |  |  | 			csv_sep, | 
					
						
							|  |  |  | 			csv_output ? 0 : 4, | 
					
						
							|  |  |  | 			nr, | 
					
						
							|  |  |  | 			csv_sep); | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 			break; | 
					
						
							|  |  |  | 	case AGGR_NONE: | 
					
						
							|  |  |  | 		fprintf(output, "CPU%*d%s", | 
					
						
							| 
									
										
											  
											
												perf stat: Add csv-style output
This patch adds an option (-x/--field-separator) to print counts using a
CSV-style output. The user can pass a custom separator. This makes it very easy
to import counts directly into your favorite spreadsheet without having to
write scripts.
Example:
$ perf stat --field-separator=,  -a -- sleep 1
4009.961740,task-clock-msecs
13,context-switches
2,CPU-migrations
189,page-faults
9596385684,cycles
3493659441,instructions
872897069,branches
41562,branch-misses
22424,cache-references
1289,cache-misses
Works also in non-aggregated mode:
$ perf stat -x ,  -a -A -- sleep 1
CPU0,1002.526168,task-clock-msecs
CPU1,1002.528365,task-clock-msecs
CPU2,1002.523360,task-clock-msecs
CPU3,1002.519878,task-clock-msecs
CPU0,1,context-switches
CPU1,5,context-switches
CPU2,5,context-switches
CPU3,6,context-switches
CPU0,0,CPU-migrations
CPU1,1,CPU-migrations
CPU2,0,CPU-migrations
CPU3,1,CPU-migrations
CPU0,2,page-faults
CPU1,6,page-faults
CPU2,9,page-faults
CPU3,174,page-faults
CPU0,2399439771,cycles
CPU1,2380369063,cycles
CPU2,2399142710,cycles
CPU3,2373161192,cycles
CPU0,872900618,instructions
CPU1,873030960,instructions
CPU2,872714525,instructions
CPU3,874460580,instructions
CPU0,221556839,branches
CPU1,218134342,branches
CPU2,218161730,branches
CPU3,218284093,branches
CPU0,18556,branch-misses
CPU1,1449,branch-misses
CPU2,3447,branch-misses
CPU3,12714,branch-misses
CPU0,8330,cache-references
CPU1,313844,cache-references
CPU2,47993728,cache-references
CPU3,826481,cache-references
CPU0,272,cache-misses
CPU1,5360,cache-misses
CPU2,1342193,cache-misses
CPU3,13992,cache-misses
This second version adds the ability to name a separator and uses
field-separator as the long option to be consistent with perf report.
Commiter note: Since we enabled --big-num by default in 201e0b0 and -x can't be
used with it, we need to notice if the user explicitely enabled or disabled -B,
add code to disable big_num if the user didn't explicitely set --big_num when
-x is used.
Cc: David S. Miller <davem@davemloft.net>
Cc: Frederik Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: paulus@samba.org
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Robert Richter <robert.richter@amd.com>
LKML-Reference: <4cf68aa7.0fedd80a.5294.1203@mx.google.com>
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2010-12-01 18:49:05 +02:00
										 |  |  | 			csv_output ? 0 : -4, | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:29 +01:00
										 |  |  | 			perf_evsel__cpus(evsel)->map[id], csv_sep); | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 		break; | 
					
						
							|  |  |  | 	case AGGR_GLOBAL: | 
					
						
							|  |  |  | 	default: | 
					
						
							|  |  |  | 		break; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void nsec_printout(int cpu, int nr, struct perf_evsel *evsel, double avg) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	double msecs = avg / 1e6; | 
					
						
							| 
									
										
										
										
											2013-11-12 17:58:49 +01:00
										 |  |  | 	const char *fmt_v, *fmt_n; | 
					
						
							| 
									
										
										
										
											2013-09-28 14:28:00 -06:00
										 |  |  | 	char name[25]; | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-12 17:58:49 +01:00
										 |  |  | 	fmt_v = csv_output ? "%.6f%s" : "%18.6f%s"; | 
					
						
							|  |  |  | 	fmt_n = csv_output ? "%s" : "%-25s"; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 	aggr_printout(evsel, cpu, nr); | 
					
						
							| 
									
										
											  
											
												perf stat: Add csv-style output
This patch adds an option (-x/--field-separator) to print counts using a
CSV-style output. The user can pass a custom separator. This makes it very easy
to import counts directly into your favorite spreadsheet without having to
write scripts.
Example:
$ perf stat --field-separator=,  -a -- sleep 1
4009.961740,task-clock-msecs
13,context-switches
2,CPU-migrations
189,page-faults
9596385684,cycles
3493659441,instructions
872897069,branches
41562,branch-misses
22424,cache-references
1289,cache-misses
Works also in non-aggregated mode:
$ perf stat -x ,  -a -A -- sleep 1
CPU0,1002.526168,task-clock-msecs
CPU1,1002.528365,task-clock-msecs
CPU2,1002.523360,task-clock-msecs
CPU3,1002.519878,task-clock-msecs
CPU0,1,context-switches
CPU1,5,context-switches
CPU2,5,context-switches
CPU3,6,context-switches
CPU0,0,CPU-migrations
CPU1,1,CPU-migrations
CPU2,0,CPU-migrations
CPU3,1,CPU-migrations
CPU0,2,page-faults
CPU1,6,page-faults
CPU2,9,page-faults
CPU3,174,page-faults
CPU0,2399439771,cycles
CPU1,2380369063,cycles
CPU2,2399142710,cycles
CPU3,2373161192,cycles
CPU0,872900618,instructions
CPU1,873030960,instructions
CPU2,872714525,instructions
CPU3,874460580,instructions
CPU0,221556839,branches
CPU1,218134342,branches
CPU2,218161730,branches
CPU3,218284093,branches
CPU0,18556,branch-misses
CPU1,1449,branch-misses
CPU2,3447,branch-misses
CPU3,12714,branch-misses
CPU0,8330,cache-references
CPU1,313844,cache-references
CPU2,47993728,cache-references
CPU3,826481,cache-references
CPU0,272,cache-misses
CPU1,5360,cache-misses
CPU2,1342193,cache-misses
CPU3,13992,cache-misses
This second version adds the ability to name a separator and uses
field-separator as the long option to be consistent with perf report.
Commiter note: Since we enabled --big-num by default in 201e0b0 and -x can't be
used with it, we need to notice if the user explicitely enabled or disabled -B,
add code to disable big_num if the user didn't explicitely set --big_num when
-x is used.
Cc: David S. Miller <davem@davemloft.net>
Cc: Frederik Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: paulus@samba.org
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Robert Richter <robert.richter@amd.com>
LKML-Reference: <4cf68aa7.0fedd80a.5294.1203@mx.google.com>
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2010-12-01 18:49:05 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-28 14:28:00 -06:00
										 |  |  | 	scnprintf(name, sizeof(name), "%s%s", | 
					
						
							|  |  |  | 		  perf_evsel__name(evsel), csv_output ? "" : " (msec)"); | 
					
						
							| 
									
										
										
										
											2013-11-12 17:58:49 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	fprintf(output, fmt_v, msecs, csv_sep); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (csv_output) | 
					
						
							|  |  |  | 		fprintf(output, "%s%s", evsel->unit, csv_sep); | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 		fprintf(output, "%-*s%s", unit_width, evsel->unit, csv_sep); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	fprintf(output, fmt_n, name); | 
					
						
							| 
									
										
											  
											
												perf stat: Add csv-style output
This patch adds an option (-x/--field-separator) to print counts using a
CSV-style output. The user can pass a custom separator. This makes it very easy
to import counts directly into your favorite spreadsheet without having to
write scripts.
Example:
$ perf stat --field-separator=,  -a -- sleep 1
4009.961740,task-clock-msecs
13,context-switches
2,CPU-migrations
189,page-faults
9596385684,cycles
3493659441,instructions
872897069,branches
41562,branch-misses
22424,cache-references
1289,cache-misses
Works also in non-aggregated mode:
$ perf stat -x ,  -a -A -- sleep 1
CPU0,1002.526168,task-clock-msecs
CPU1,1002.528365,task-clock-msecs
CPU2,1002.523360,task-clock-msecs
CPU3,1002.519878,task-clock-msecs
CPU0,1,context-switches
CPU1,5,context-switches
CPU2,5,context-switches
CPU3,6,context-switches
CPU0,0,CPU-migrations
CPU1,1,CPU-migrations
CPU2,0,CPU-migrations
CPU3,1,CPU-migrations
CPU0,2,page-faults
CPU1,6,page-faults
CPU2,9,page-faults
CPU3,174,page-faults
CPU0,2399439771,cycles
CPU1,2380369063,cycles
CPU2,2399142710,cycles
CPU3,2373161192,cycles
CPU0,872900618,instructions
CPU1,873030960,instructions
CPU2,872714525,instructions
CPU3,874460580,instructions
CPU0,221556839,branches
CPU1,218134342,branches
CPU2,218161730,branches
CPU3,218284093,branches
CPU0,18556,branch-misses
CPU1,1449,branch-misses
CPU2,3447,branch-misses
CPU3,12714,branch-misses
CPU0,8330,cache-references
CPU1,313844,cache-references
CPU2,47993728,cache-references
CPU3,826481,cache-references
CPU0,272,cache-misses
CPU1,5360,cache-misses
CPU2,1342193,cache-misses
CPU3,13992,cache-misses
This second version adds the ability to name a separator and uses
field-separator as the long option to be consistent with perf report.
Commiter note: Since we enabled --big-num by default in 201e0b0 and -x can't be
used with it, we need to notice if the user explicitely enabled or disabled -B,
add code to disable big_num if the user didn't explicitely set --big_num when
-x is used.
Cc: David S. Miller <davem@davemloft.net>
Cc: Frederik Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: paulus@samba.org
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Robert Richter <robert.richter@amd.com>
LKML-Reference: <4cf68aa7.0fedd80a.5294.1203@mx.google.com>
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2010-12-01 18:49:05 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
											
												perf tool: Add cgroup support
This patch adds the ability to filter monitoring based on container groups
(cgroups) for both perf stat and perf record. It is possible to monitor
multiple cgroup in parallel. There is one cgroup per event. The cgroups to
monitor are passed via a new -G option followed by a comma separated list of
cgroup names.
The cgroup filesystem has to be mounted. Given a cgroup name, the perf tool
finds the corresponding directory in the cgroup filesystem and opens it. It
then passes that file descriptor to the kernel.
Example:
$ perf stat -B -a -e cycles:u,cycles:u,cycles:u -G test1,,test2 -- sleep 1
 Performance counter stats for 'sleep 1':
      2,368,667,414  cycles                   test1
      2,369,661,459  cycles
      <not counted>  cycles                   test2
        1.001856890  seconds time elapsed
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
LKML-Reference: <4d590290.825bdf0a.7d0a.4890@mx.google.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-02-14 11:20:01 +02:00
										 |  |  | 	if (evsel->cgrp) | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 		fprintf(output, "%s%s", csv_sep, evsel->cgrp->name); | 
					
						
							| 
									
										
										
											
												perf tool: Add cgroup support
This patch adds the ability to filter monitoring based on container groups
(cgroups) for both perf stat and perf record. It is possible to monitor
multiple cgroup in parallel. There is one cgroup per event. The cgroups to
monitor are passed via a new -G option followed by a comma separated list of
cgroup names.
The cgroup filesystem has to be mounted. Given a cgroup name, the perf tool
finds the corresponding directory in the cgroup filesystem and opens it. It
then passes that file descriptor to the kernel.
Example:
$ perf stat -B -a -e cycles:u,cycles:u,cycles:u -G test1,,test2 -- sleep 1
 Performance counter stats for 'sleep 1':
      2,368,667,414  cycles                   test1
      2,369,661,459  cycles
      <not counted>  cycles                   test2
        1.001856890  seconds time elapsed
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
LKML-Reference: <4d590290.825bdf0a.7d0a.4890@mx.google.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-02-14 11:20:01 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												perf stat: Add interval printing
This patch adds a new printing mode for perf stat.  It allows interval
printing. That means perf stat can now print event deltas at regular
time interval.  This is useful to detect phases in programs.
The -I option enables interval printing. It expects an interval duration
in milliseconds. Minimum is 100ms. Once, activated perf stat prints
events deltas since last printout. All modes are supported.
$ perf stat -I 1000 -e cycles noploop 10
noploop for 10 seconds
 #           time             counts events
      1.000109853      2,388,560,546 cycles
      2.000262846      2,393,332,358 cycles
      3.000354131      2,393,176,537 cycles
      4.000439503      2,393,203,790 cycles
      5.000527075      2,393,167,675 cycles
      6.000609052      2,393,203,670 cycles
      7.000691082      2,393,175,678 cycles
The output format makes it easy to feed into a plotting program such as
gnuplot when the -I option is used in combination with the -x option:
$ perf stat -x, -I 1000 -e cycles noploop 10
noploop for 10 seconds
1.000084113,2378775498,cycles
2.000245798,2391056897,cycles
3.000354445,2392089414,cycles
4.000459115,2390936603,cycles
5.000565341,2392108173,cycles
Signed-off-by: Stephane Eranian <eranian@google.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1359460064-3060-3-git-send-email-eranian@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2013-01-29 12:47:44 +01:00
										 |  |  | 	if (csv_output || interval) | 
					
						
							| 
									
										
											  
											
												perf stat: Add csv-style output
This patch adds an option (-x/--field-separator) to print counts using a
CSV-style output. The user can pass a custom separator. This makes it very easy
to import counts directly into your favorite spreadsheet without having to
write scripts.
Example:
$ perf stat --field-separator=,  -a -- sleep 1
4009.961740,task-clock-msecs
13,context-switches
2,CPU-migrations
189,page-faults
9596385684,cycles
3493659441,instructions
872897069,branches
41562,branch-misses
22424,cache-references
1289,cache-misses
Works also in non-aggregated mode:
$ perf stat -x ,  -a -A -- sleep 1
CPU0,1002.526168,task-clock-msecs
CPU1,1002.528365,task-clock-msecs
CPU2,1002.523360,task-clock-msecs
CPU3,1002.519878,task-clock-msecs
CPU0,1,context-switches
CPU1,5,context-switches
CPU2,5,context-switches
CPU3,6,context-switches
CPU0,0,CPU-migrations
CPU1,1,CPU-migrations
CPU2,0,CPU-migrations
CPU3,1,CPU-migrations
CPU0,2,page-faults
CPU1,6,page-faults
CPU2,9,page-faults
CPU3,174,page-faults
CPU0,2399439771,cycles
CPU1,2380369063,cycles
CPU2,2399142710,cycles
CPU3,2373161192,cycles
CPU0,872900618,instructions
CPU1,873030960,instructions
CPU2,872714525,instructions
CPU3,874460580,instructions
CPU0,221556839,branches
CPU1,218134342,branches
CPU2,218161730,branches
CPU3,218284093,branches
CPU0,18556,branch-misses
CPU1,1449,branch-misses
CPU2,3447,branch-misses
CPU3,12714,branch-misses
CPU0,8330,cache-references
CPU1,313844,cache-references
CPU2,47993728,cache-references
CPU3,826481,cache-references
CPU0,272,cache-misses
CPU1,5360,cache-misses
CPU2,1342193,cache-misses
CPU3,13992,cache-misses
This second version adds the ability to name a separator and uses
field-separator as the long option to be consistent with perf report.
Commiter note: Since we enabled --big-num by default in 201e0b0 and -x can't be
used with it, we need to notice if the user explicitely enabled or disabled -B,
add code to disable big_num if the user didn't explicitely set --big_num when
-x is used.
Cc: David S. Miller <davem@davemloft.net>
Cc: Frederik Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: paulus@samba.org
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Robert Richter <robert.richter@amd.com>
LKML-Reference: <4cf68aa7.0fedd80a.5294.1203@mx.google.com>
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2010-12-01 18:49:05 +02:00
										 |  |  | 		return; | 
					
						
							| 
									
										
										
										
											2009-06-13 13:35:00 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-01-03 16:49:44 -02:00
										 |  |  | 	if (perf_evsel__match(evsel, SOFTWARE, SW_TASK_CLOCK)) | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 		fprintf(output, " # %8.3f CPUs utilized          ", | 
					
						
							|  |  |  | 			avg / avg_stats(&walltime_nsecs_stats)); | 
					
						
							| 
									
										
										
										
											2012-02-06 16:44:45 +09:00
										 |  |  | 	else | 
					
						
							|  |  |  | 		fprintf(output, "                                   "); | 
					
						
							| 
									
										
										
										
											2009-06-13 13:35:00 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-28 00:35:49 +09:00
										 |  |  | /* used for get_ratio_color() */ | 
					
						
							|  |  |  | enum grc_type { | 
					
						
							|  |  |  | 	GRC_STALLED_CYCLES_FE, | 
					
						
							|  |  |  | 	GRC_STALLED_CYCLES_BE, | 
					
						
							|  |  |  | 	GRC_CACHE_MISSES, | 
					
						
							|  |  |  | 	GRC_MAX_NR | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static const char *get_ratio_color(enum grc_type type, double ratio) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	static const double grc_table[GRC_MAX_NR][3] = { | 
					
						
							|  |  |  | 		[GRC_STALLED_CYCLES_FE] = { 50.0, 30.0, 10.0 }, | 
					
						
							|  |  |  | 		[GRC_STALLED_CYCLES_BE] = { 75.0, 50.0, 20.0 }, | 
					
						
							|  |  |  | 		[GRC_CACHE_MISSES] 	= { 20.0, 10.0, 5.0 }, | 
					
						
							|  |  |  | 	}; | 
					
						
							|  |  |  | 	const char *color = PERF_COLOR_NORMAL; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (ratio > grc_table[type][0]) | 
					
						
							|  |  |  | 		color = PERF_COLOR_RED; | 
					
						
							|  |  |  | 	else if (ratio > grc_table[type][1]) | 
					
						
							|  |  |  | 		color = PERF_COLOR_MAGENTA; | 
					
						
							|  |  |  | 	else if (ratio > grc_table[type][2]) | 
					
						
							|  |  |  | 		color = PERF_COLOR_YELLOW; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return color; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-11 01:15:03 +03:00
										 |  |  | static void print_stalled_cycles_frontend(int cpu, | 
					
						
							|  |  |  | 					  struct perf_evsel *evsel | 
					
						
							|  |  |  | 					  __maybe_unused, double avg) | 
					
						
							| 
									
										
										
											
												perf stat: Analyze front-end and back-end stall counts
Sample output:
 Performance counter stats for './loop_1b':
        873.691065 task-clock               #    1.000 CPUs utilized
                 1 context-switches         #    0.000 M/sec
                 1 CPU-migrations           #    0.000 M/sec
                96 page-faults              #    0.000 M/sec
     2,012,637,222 cycles                   #    2.304 GHz                      (66.58%)
     1,001,397,911 stalled-cycles-frontend  #   49.76% frontend cycles idle     (66.58%)
         7,523,398 stalled-cycles-backend   #    0.37%  backend cycles idle     (66.76%)
     2,004,551,046 instructions             #    1.00  insns per cycle
                                            #    0.50  stalled cycles per insn  (66.80%)
     1,001,304,992 branches                 # 1146.063 M/sec                    (66.76%)
            39,453 branch-misses            #    0.00% of all branches          (66.64%)
        0.874046121  seconds time elapsed
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Link: http://lkml.kernel.org/n/tip-7y40wib8n003io7hjpn1dsrm@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-04-29 13:49:08 +02:00
										 |  |  | { | 
					
						
							|  |  |  | 	double total, ratio = 0.0; | 
					
						
							|  |  |  | 	const char *color; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	total = avg_stats(&runtime_cycles_stats[cpu]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (total) | 
					
						
							|  |  |  | 		ratio = avg / total * 100.0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-28 00:35:49 +09:00
										 |  |  | 	color = get_ratio_color(GRC_STALLED_CYCLES_FE, ratio); | 
					
						
							| 
									
										
										
											
												perf stat: Analyze front-end and back-end stall counts
Sample output:
 Performance counter stats for './loop_1b':
        873.691065 task-clock               #    1.000 CPUs utilized
                 1 context-switches         #    0.000 M/sec
                 1 CPU-migrations           #    0.000 M/sec
                96 page-faults              #    0.000 M/sec
     2,012,637,222 cycles                   #    2.304 GHz                      (66.58%)
     1,001,397,911 stalled-cycles-frontend  #   49.76% frontend cycles idle     (66.58%)
         7,523,398 stalled-cycles-backend   #    0.37%  backend cycles idle     (66.76%)
     2,004,551,046 instructions             #    1.00  insns per cycle
                                            #    0.50  stalled cycles per insn  (66.80%)
     1,001,304,992 branches                 # 1146.063 M/sec                    (66.76%)
            39,453 branch-misses            #    0.00% of all branches          (66.64%)
        0.874046121  seconds time elapsed
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Link: http://lkml.kernel.org/n/tip-7y40wib8n003io7hjpn1dsrm@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-04-29 13:49:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 	fprintf(output, " #  "); | 
					
						
							|  |  |  | 	color_fprintf(output, color, "%6.2f%%", ratio); | 
					
						
							|  |  |  | 	fprintf(output, " frontend cycles idle   "); | 
					
						
							| 
									
										
										
											
												perf stat: Analyze front-end and back-end stall counts
Sample output:
 Performance counter stats for './loop_1b':
        873.691065 task-clock               #    1.000 CPUs utilized
                 1 context-switches         #    0.000 M/sec
                 1 CPU-migrations           #    0.000 M/sec
                96 page-faults              #    0.000 M/sec
     2,012,637,222 cycles                   #    2.304 GHz                      (66.58%)
     1,001,397,911 stalled-cycles-frontend  #   49.76% frontend cycles idle     (66.58%)
         7,523,398 stalled-cycles-backend   #    0.37%  backend cycles idle     (66.76%)
     2,004,551,046 instructions             #    1.00  insns per cycle
                                            #    0.50  stalled cycles per insn  (66.80%)
     1,001,304,992 branches                 # 1146.063 M/sec                    (66.76%)
            39,453 branch-misses            #    0.00% of all branches          (66.64%)
        0.874046121  seconds time elapsed
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Link: http://lkml.kernel.org/n/tip-7y40wib8n003io7hjpn1dsrm@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-04-29 13:49:08 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-11 01:15:03 +03:00
										 |  |  | static void print_stalled_cycles_backend(int cpu, | 
					
						
							|  |  |  | 					 struct perf_evsel *evsel | 
					
						
							|  |  |  | 					 __maybe_unused, double avg) | 
					
						
							| 
									
										
										
										
											2011-04-27 05:39:24 +02:00
										 |  |  | { | 
					
						
							|  |  |  | 	double total, ratio = 0.0; | 
					
						
							|  |  |  | 	const char *color; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	total = avg_stats(&runtime_cycles_stats[cpu]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (total) | 
					
						
							|  |  |  | 		ratio = avg / total * 100.0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-28 00:35:49 +09:00
										 |  |  | 	color = get_ratio_color(GRC_STALLED_CYCLES_BE, ratio); | 
					
						
							| 
									
										
										
										
											2011-04-27 05:39:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 	fprintf(output, " #  "); | 
					
						
							|  |  |  | 	color_fprintf(output, color, "%6.2f%%", ratio); | 
					
						
							|  |  |  | 	fprintf(output, " backend  cycles idle   "); | 
					
						
							| 
									
										
										
										
											2011-04-27 05:39:24 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-11 01:15:03 +03:00
										 |  |  | static void print_branch_misses(int cpu, | 
					
						
							|  |  |  | 				struct perf_evsel *evsel __maybe_unused, | 
					
						
							|  |  |  | 				double avg) | 
					
						
							| 
									
										
										
										
											2011-04-27 12:16:10 +02:00
										 |  |  | { | 
					
						
							|  |  |  | 	double total, ratio = 0.0; | 
					
						
							|  |  |  | 	const char *color; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	total = avg_stats(&runtime_branches_stats[cpu]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (total) | 
					
						
							|  |  |  | 		ratio = avg / total * 100.0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-28 00:35:49 +09:00
										 |  |  | 	color = get_ratio_color(GRC_CACHE_MISSES, ratio); | 
					
						
							| 
									
										
										
										
											2011-04-27 12:16:10 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 	fprintf(output, " #  "); | 
					
						
							|  |  |  | 	color_fprintf(output, color, "%6.2f%%", ratio); | 
					
						
							|  |  |  | 	fprintf(output, " of all branches        "); | 
					
						
							| 
									
										
										
										
											2011-04-27 12:16:10 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-11 01:15:03 +03:00
										 |  |  | static void print_l1_dcache_misses(int cpu, | 
					
						
							|  |  |  | 				   struct perf_evsel *evsel __maybe_unused, | 
					
						
							|  |  |  | 				   double avg) | 
					
						
							| 
									
										
											  
											
												perf stat: Print out miss/hit ratio for L1 data-cache events
Print out this kind of l1-dcache-misses percentage:
 Performance counter stats for './bw_tcp localhost':
    29,956,262,201 cycles                   #    3.002 GHz                      (scaled from 85.14%)
     8,255,209,558 stalled-cycles           #   27.56% of all cycles are idle   (scaled from 86.56%)
     1,206,130,308 l1-dcache-misses         #   40.49% of all L1-dcache hits    (scaled from 86.30%)
     2,978,756,779 l1-dcache-refs           #  298.512 M/sec                    (scaled from 70.02%)
     8,861,956,159 instructions             #    0.30  insns per cycle
                                            #    0.93  stalled cycles per insn  (scaled from 84.27%)
     1,644,306,068 branches                 #  164.782 M/sec                    (scaled from 86.43%)
        74,778,443 branch-misses            #    4.55% of all branches          (scaled from 70.69%)
       9978.695711 task-clock               #    0.693 CPUs utilized
       14.404347983  seconds time elapsed
And color the result depending on the severity of cache-trashing.
Acked-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
Acked-by Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Link: http://lkml.kernel.org/n/tip-54gmz0zymaid84zcs7joq02p@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-04-27 13:25:24 +02:00
										 |  |  | { | 
					
						
							|  |  |  | 	double total, ratio = 0.0; | 
					
						
							|  |  |  | 	const char *color; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	total = avg_stats(&runtime_l1_dcache_stats[cpu]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (total) | 
					
						
							|  |  |  | 		ratio = avg / total * 100.0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-28 00:35:49 +09:00
										 |  |  | 	color = get_ratio_color(GRC_CACHE_MISSES, ratio); | 
					
						
							| 
									
										
											  
											
												perf stat: Print out miss/hit ratio for L1 data-cache events
Print out this kind of l1-dcache-misses percentage:
 Performance counter stats for './bw_tcp localhost':
    29,956,262,201 cycles                   #    3.002 GHz                      (scaled from 85.14%)
     8,255,209,558 stalled-cycles           #   27.56% of all cycles are idle   (scaled from 86.56%)
     1,206,130,308 l1-dcache-misses         #   40.49% of all L1-dcache hits    (scaled from 86.30%)
     2,978,756,779 l1-dcache-refs           #  298.512 M/sec                    (scaled from 70.02%)
     8,861,956,159 instructions             #    0.30  insns per cycle
                                            #    0.93  stalled cycles per insn  (scaled from 84.27%)
     1,644,306,068 branches                 #  164.782 M/sec                    (scaled from 86.43%)
        74,778,443 branch-misses            #    4.55% of all branches          (scaled from 70.69%)
       9978.695711 task-clock               #    0.693 CPUs utilized
       14.404347983  seconds time elapsed
And color the result depending on the severity of cache-trashing.
Acked-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
Acked-by Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Link: http://lkml.kernel.org/n/tip-54gmz0zymaid84zcs7joq02p@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-04-27 13:25:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 	fprintf(output, " #  "); | 
					
						
							|  |  |  | 	color_fprintf(output, color, "%6.2f%%", ratio); | 
					
						
							|  |  |  | 	fprintf(output, " of all L1-dcache hits  "); | 
					
						
							| 
									
										
											  
											
												perf stat: Print out miss/hit ratio for L1 data-cache events
Print out this kind of l1-dcache-misses percentage:
 Performance counter stats for './bw_tcp localhost':
    29,956,262,201 cycles                   #    3.002 GHz                      (scaled from 85.14%)
     8,255,209,558 stalled-cycles           #   27.56% of all cycles are idle   (scaled from 86.56%)
     1,206,130,308 l1-dcache-misses         #   40.49% of all L1-dcache hits    (scaled from 86.30%)
     2,978,756,779 l1-dcache-refs           #  298.512 M/sec                    (scaled from 70.02%)
     8,861,956,159 instructions             #    0.30  insns per cycle
                                            #    0.93  stalled cycles per insn  (scaled from 84.27%)
     1,644,306,068 branches                 #  164.782 M/sec                    (scaled from 86.43%)
        74,778,443 branch-misses            #    4.55% of all branches          (scaled from 70.69%)
       9978.695711 task-clock               #    0.693 CPUs utilized
       14.404347983  seconds time elapsed
And color the result depending on the severity of cache-trashing.
Acked-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
Acked-by Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Link: http://lkml.kernel.org/n/tip-54gmz0zymaid84zcs7joq02p@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-04-27 13:25:24 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-11 01:15:03 +03:00
										 |  |  | static void print_l1_icache_misses(int cpu, | 
					
						
							|  |  |  | 				   struct perf_evsel *evsel __maybe_unused, | 
					
						
							|  |  |  | 				   double avg) | 
					
						
							| 
									
										
										
											
												perf stat: Add more cache-miss percentage printouts
Print out the cache-miss percentage as well if the cache refs were
collected, for all the generic cache event types.
Before:
   11,103,723,230 dTLB-loads                #  622.471 M/sec                    ( +-  0.30% )
       87,065,337 dTLB-load-misses          #    4.881 M/sec                    ( +-  0.90% )
After:
   11,353,713,242 dTLB-loads                #  626.020 M/sec                    ( +-  0.35% )
      113,393,472 dTLB-load-misses          #    1.00% of all dTLB cache hits   ( +-  0.49% )
Also ASCII color highlight too high percentages, them when it's executed on the console.
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Steven Rostedt <rostedt@goodmis.org>
Link: http://lkml.kernel.org/n/tip-lkhwxsevdbd9a8nymx0vxc3y@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-05-19 14:01:42 +02:00
										 |  |  | { | 
					
						
							|  |  |  | 	double total, ratio = 0.0; | 
					
						
							|  |  |  | 	const char *color; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	total = avg_stats(&runtime_l1_icache_stats[cpu]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (total) | 
					
						
							|  |  |  | 		ratio = avg / total * 100.0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-28 00:35:49 +09:00
										 |  |  | 	color = get_ratio_color(GRC_CACHE_MISSES, ratio); | 
					
						
							| 
									
										
										
											
												perf stat: Add more cache-miss percentage printouts
Print out the cache-miss percentage as well if the cache refs were
collected, for all the generic cache event types.
Before:
   11,103,723,230 dTLB-loads                #  622.471 M/sec                    ( +-  0.30% )
       87,065,337 dTLB-load-misses          #    4.881 M/sec                    ( +-  0.90% )
After:
   11,353,713,242 dTLB-loads                #  626.020 M/sec                    ( +-  0.35% )
      113,393,472 dTLB-load-misses          #    1.00% of all dTLB cache hits   ( +-  0.49% )
Also ASCII color highlight too high percentages, them when it's executed on the console.
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Steven Rostedt <rostedt@goodmis.org>
Link: http://lkml.kernel.org/n/tip-lkhwxsevdbd9a8nymx0vxc3y@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-05-19 14:01:42 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 	fprintf(output, " #  "); | 
					
						
							|  |  |  | 	color_fprintf(output, color, "%6.2f%%", ratio); | 
					
						
							|  |  |  | 	fprintf(output, " of all L1-icache hits  "); | 
					
						
							| 
									
										
										
											
												perf stat: Add more cache-miss percentage printouts
Print out the cache-miss percentage as well if the cache refs were
collected, for all the generic cache event types.
Before:
   11,103,723,230 dTLB-loads                #  622.471 M/sec                    ( +-  0.30% )
       87,065,337 dTLB-load-misses          #    4.881 M/sec                    ( +-  0.90% )
After:
   11,353,713,242 dTLB-loads                #  626.020 M/sec                    ( +-  0.35% )
      113,393,472 dTLB-load-misses          #    1.00% of all dTLB cache hits   ( +-  0.49% )
Also ASCII color highlight too high percentages, them when it's executed on the console.
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Steven Rostedt <rostedt@goodmis.org>
Link: http://lkml.kernel.org/n/tip-lkhwxsevdbd9a8nymx0vxc3y@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-05-19 14:01:42 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-11 01:15:03 +03:00
										 |  |  | static void print_dtlb_cache_misses(int cpu, | 
					
						
							|  |  |  | 				    struct perf_evsel *evsel __maybe_unused, | 
					
						
							|  |  |  | 				    double avg) | 
					
						
							| 
									
										
										
											
												perf stat: Add more cache-miss percentage printouts
Print out the cache-miss percentage as well if the cache refs were
collected, for all the generic cache event types.
Before:
   11,103,723,230 dTLB-loads                #  622.471 M/sec                    ( +-  0.30% )
       87,065,337 dTLB-load-misses          #    4.881 M/sec                    ( +-  0.90% )
After:
   11,353,713,242 dTLB-loads                #  626.020 M/sec                    ( +-  0.35% )
      113,393,472 dTLB-load-misses          #    1.00% of all dTLB cache hits   ( +-  0.49% )
Also ASCII color highlight too high percentages, them when it's executed on the console.
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Steven Rostedt <rostedt@goodmis.org>
Link: http://lkml.kernel.org/n/tip-lkhwxsevdbd9a8nymx0vxc3y@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-05-19 14:01:42 +02:00
										 |  |  | { | 
					
						
							|  |  |  | 	double total, ratio = 0.0; | 
					
						
							|  |  |  | 	const char *color; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	total = avg_stats(&runtime_dtlb_cache_stats[cpu]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (total) | 
					
						
							|  |  |  | 		ratio = avg / total * 100.0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-28 00:35:49 +09:00
										 |  |  | 	color = get_ratio_color(GRC_CACHE_MISSES, ratio); | 
					
						
							| 
									
										
										
											
												perf stat: Add more cache-miss percentage printouts
Print out the cache-miss percentage as well if the cache refs were
collected, for all the generic cache event types.
Before:
   11,103,723,230 dTLB-loads                #  622.471 M/sec                    ( +-  0.30% )
       87,065,337 dTLB-load-misses          #    4.881 M/sec                    ( +-  0.90% )
After:
   11,353,713,242 dTLB-loads                #  626.020 M/sec                    ( +-  0.35% )
      113,393,472 dTLB-load-misses          #    1.00% of all dTLB cache hits   ( +-  0.49% )
Also ASCII color highlight too high percentages, them when it's executed on the console.
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Steven Rostedt <rostedt@goodmis.org>
Link: http://lkml.kernel.org/n/tip-lkhwxsevdbd9a8nymx0vxc3y@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-05-19 14:01:42 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 	fprintf(output, " #  "); | 
					
						
							|  |  |  | 	color_fprintf(output, color, "%6.2f%%", ratio); | 
					
						
							|  |  |  | 	fprintf(output, " of all dTLB cache hits "); | 
					
						
							| 
									
										
										
											
												perf stat: Add more cache-miss percentage printouts
Print out the cache-miss percentage as well if the cache refs were
collected, for all the generic cache event types.
Before:
   11,103,723,230 dTLB-loads                #  622.471 M/sec                    ( +-  0.30% )
       87,065,337 dTLB-load-misses          #    4.881 M/sec                    ( +-  0.90% )
After:
   11,353,713,242 dTLB-loads                #  626.020 M/sec                    ( +-  0.35% )
      113,393,472 dTLB-load-misses          #    1.00% of all dTLB cache hits   ( +-  0.49% )
Also ASCII color highlight too high percentages, them when it's executed on the console.
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Steven Rostedt <rostedt@goodmis.org>
Link: http://lkml.kernel.org/n/tip-lkhwxsevdbd9a8nymx0vxc3y@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-05-19 14:01:42 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-11 01:15:03 +03:00
										 |  |  | static void print_itlb_cache_misses(int cpu, | 
					
						
							|  |  |  | 				    struct perf_evsel *evsel __maybe_unused, | 
					
						
							|  |  |  | 				    double avg) | 
					
						
							| 
									
										
										
											
												perf stat: Add more cache-miss percentage printouts
Print out the cache-miss percentage as well if the cache refs were
collected, for all the generic cache event types.
Before:
   11,103,723,230 dTLB-loads                #  622.471 M/sec                    ( +-  0.30% )
       87,065,337 dTLB-load-misses          #    4.881 M/sec                    ( +-  0.90% )
After:
   11,353,713,242 dTLB-loads                #  626.020 M/sec                    ( +-  0.35% )
      113,393,472 dTLB-load-misses          #    1.00% of all dTLB cache hits   ( +-  0.49% )
Also ASCII color highlight too high percentages, them when it's executed on the console.
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Steven Rostedt <rostedt@goodmis.org>
Link: http://lkml.kernel.org/n/tip-lkhwxsevdbd9a8nymx0vxc3y@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-05-19 14:01:42 +02:00
										 |  |  | { | 
					
						
							|  |  |  | 	double total, ratio = 0.0; | 
					
						
							|  |  |  | 	const char *color; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	total = avg_stats(&runtime_itlb_cache_stats[cpu]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (total) | 
					
						
							|  |  |  | 		ratio = avg / total * 100.0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-28 00:35:49 +09:00
										 |  |  | 	color = get_ratio_color(GRC_CACHE_MISSES, ratio); | 
					
						
							| 
									
										
										
											
												perf stat: Add more cache-miss percentage printouts
Print out the cache-miss percentage as well if the cache refs were
collected, for all the generic cache event types.
Before:
   11,103,723,230 dTLB-loads                #  622.471 M/sec                    ( +-  0.30% )
       87,065,337 dTLB-load-misses          #    4.881 M/sec                    ( +-  0.90% )
After:
   11,353,713,242 dTLB-loads                #  626.020 M/sec                    ( +-  0.35% )
      113,393,472 dTLB-load-misses          #    1.00% of all dTLB cache hits   ( +-  0.49% )
Also ASCII color highlight too high percentages, them when it's executed on the console.
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Steven Rostedt <rostedt@goodmis.org>
Link: http://lkml.kernel.org/n/tip-lkhwxsevdbd9a8nymx0vxc3y@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-05-19 14:01:42 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 	fprintf(output, " #  "); | 
					
						
							|  |  |  | 	color_fprintf(output, color, "%6.2f%%", ratio); | 
					
						
							|  |  |  | 	fprintf(output, " of all iTLB cache hits "); | 
					
						
							| 
									
										
										
											
												perf stat: Add more cache-miss percentage printouts
Print out the cache-miss percentage as well if the cache refs were
collected, for all the generic cache event types.
Before:
   11,103,723,230 dTLB-loads                #  622.471 M/sec                    ( +-  0.30% )
       87,065,337 dTLB-load-misses          #    4.881 M/sec                    ( +-  0.90% )
After:
   11,353,713,242 dTLB-loads                #  626.020 M/sec                    ( +-  0.35% )
      113,393,472 dTLB-load-misses          #    1.00% of all dTLB cache hits   ( +-  0.49% )
Also ASCII color highlight too high percentages, them when it's executed on the console.
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Steven Rostedt <rostedt@goodmis.org>
Link: http://lkml.kernel.org/n/tip-lkhwxsevdbd9a8nymx0vxc3y@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-05-19 14:01:42 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-11 01:15:03 +03:00
										 |  |  | static void print_ll_cache_misses(int cpu, | 
					
						
							|  |  |  | 				  struct perf_evsel *evsel __maybe_unused, | 
					
						
							|  |  |  | 				  double avg) | 
					
						
							| 
									
										
										
											
												perf stat: Add more cache-miss percentage printouts
Print out the cache-miss percentage as well if the cache refs were
collected, for all the generic cache event types.
Before:
   11,103,723,230 dTLB-loads                #  622.471 M/sec                    ( +-  0.30% )
       87,065,337 dTLB-load-misses          #    4.881 M/sec                    ( +-  0.90% )
After:
   11,353,713,242 dTLB-loads                #  626.020 M/sec                    ( +-  0.35% )
      113,393,472 dTLB-load-misses          #    1.00% of all dTLB cache hits   ( +-  0.49% )
Also ASCII color highlight too high percentages, them when it's executed on the console.
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Steven Rostedt <rostedt@goodmis.org>
Link: http://lkml.kernel.org/n/tip-lkhwxsevdbd9a8nymx0vxc3y@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-05-19 14:01:42 +02:00
										 |  |  | { | 
					
						
							|  |  |  | 	double total, ratio = 0.0; | 
					
						
							|  |  |  | 	const char *color; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	total = avg_stats(&runtime_ll_cache_stats[cpu]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (total) | 
					
						
							|  |  |  | 		ratio = avg / total * 100.0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-28 00:35:49 +09:00
										 |  |  | 	color = get_ratio_color(GRC_CACHE_MISSES, ratio); | 
					
						
							| 
									
										
										
											
												perf stat: Add more cache-miss percentage printouts
Print out the cache-miss percentage as well if the cache refs were
collected, for all the generic cache event types.
Before:
   11,103,723,230 dTLB-loads                #  622.471 M/sec                    ( +-  0.30% )
       87,065,337 dTLB-load-misses          #    4.881 M/sec                    ( +-  0.90% )
After:
   11,353,713,242 dTLB-loads                #  626.020 M/sec                    ( +-  0.35% )
      113,393,472 dTLB-load-misses          #    1.00% of all dTLB cache hits   ( +-  0.49% )
Also ASCII color highlight too high percentages, them when it's executed on the console.
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Steven Rostedt <rostedt@goodmis.org>
Link: http://lkml.kernel.org/n/tip-lkhwxsevdbd9a8nymx0vxc3y@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-05-19 14:01:42 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 	fprintf(output, " #  "); | 
					
						
							|  |  |  | 	color_fprintf(output, color, "%6.2f%%", ratio); | 
					
						
							|  |  |  | 	fprintf(output, " of all LL-cache hits   "); | 
					
						
							| 
									
										
										
											
												perf stat: Add more cache-miss percentage printouts
Print out the cache-miss percentage as well if the cache refs were
collected, for all the generic cache event types.
Before:
   11,103,723,230 dTLB-loads                #  622.471 M/sec                    ( +-  0.30% )
       87,065,337 dTLB-load-misses          #    4.881 M/sec                    ( +-  0.90% )
After:
   11,353,713,242 dTLB-loads                #  626.020 M/sec                    ( +-  0.35% )
      113,393,472 dTLB-load-misses          #    1.00% of all dTLB cache hits   ( +-  0.49% )
Also ASCII color highlight too high percentages, them when it's executed on the console.
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Steven Rostedt <rostedt@goodmis.org>
Link: http://lkml.kernel.org/n/tip-lkhwxsevdbd9a8nymx0vxc3y@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-05-19 14:01:42 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-06 15:46:02 +01:00
										 |  |  | static void abs_printout(int cpu, int nr, struct perf_evsel *evsel, double avg) | 
					
						
							| 
									
										
										
										
											2009-06-13 13:35:00 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2013-08-21 16:47:26 -07:00
										 |  |  | 	double total, ratio = 0.0, total2; | 
					
						
							| 
									
										
										
										
											2013-11-12 17:58:49 +01:00
										 |  |  | 	double sc =  evsel->scale; | 
					
						
							| 
									
										
											  
											
												perf stat: Add csv-style output
This patch adds an option (-x/--field-separator) to print counts using a
CSV-style output. The user can pass a custom separator. This makes it very easy
to import counts directly into your favorite spreadsheet without having to
write scripts.
Example:
$ perf stat --field-separator=,  -a -- sleep 1
4009.961740,task-clock-msecs
13,context-switches
2,CPU-migrations
189,page-faults
9596385684,cycles
3493659441,instructions
872897069,branches
41562,branch-misses
22424,cache-references
1289,cache-misses
Works also in non-aggregated mode:
$ perf stat -x ,  -a -A -- sleep 1
CPU0,1002.526168,task-clock-msecs
CPU1,1002.528365,task-clock-msecs
CPU2,1002.523360,task-clock-msecs
CPU3,1002.519878,task-clock-msecs
CPU0,1,context-switches
CPU1,5,context-switches
CPU2,5,context-switches
CPU3,6,context-switches
CPU0,0,CPU-migrations
CPU1,1,CPU-migrations
CPU2,0,CPU-migrations
CPU3,1,CPU-migrations
CPU0,2,page-faults
CPU1,6,page-faults
CPU2,9,page-faults
CPU3,174,page-faults
CPU0,2399439771,cycles
CPU1,2380369063,cycles
CPU2,2399142710,cycles
CPU3,2373161192,cycles
CPU0,872900618,instructions
CPU1,873030960,instructions
CPU2,872714525,instructions
CPU3,874460580,instructions
CPU0,221556839,branches
CPU1,218134342,branches
CPU2,218161730,branches
CPU3,218284093,branches
CPU0,18556,branch-misses
CPU1,1449,branch-misses
CPU2,3447,branch-misses
CPU3,12714,branch-misses
CPU0,8330,cache-references
CPU1,313844,cache-references
CPU2,47993728,cache-references
CPU3,826481,cache-references
CPU0,272,cache-misses
CPU1,5360,cache-misses
CPU2,1342193,cache-misses
CPU3,13992,cache-misses
This second version adds the ability to name a separator and uses
field-separator as the long option to be consistent with perf report.
Commiter note: Since we enabled --big-num by default in 201e0b0 and -x can't be
used with it, we need to notice if the user explicitely enabled or disabled -B,
add code to disable big_num if the user didn't explicitely set --big_num when
-x is used.
Cc: David S. Miller <davem@davemloft.net>
Cc: Frederik Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: paulus@samba.org
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Robert Richter <robert.richter@amd.com>
LKML-Reference: <4cf68aa7.0fedd80a.5294.1203@mx.google.com>
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2010-12-01 18:49:05 +02:00
										 |  |  | 	const char *fmt; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-12 17:58:49 +01:00
										 |  |  | 	if (csv_output) { | 
					
						
							|  |  |  | 		fmt = sc != 1.0 ?  "%.2f%s" : "%.0f%s"; | 
					
						
							|  |  |  | 	} else { | 
					
						
							|  |  |  | 		if (big_num) | 
					
						
							|  |  |  | 			fmt = sc != 1.0 ? "%'18.2f%s" : "%'18.0f%s"; | 
					
						
							|  |  |  | 		else | 
					
						
							|  |  |  | 			fmt = sc != 1.0 ? "%18.2f%s" : "%18.0f%s"; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-11-16 11:05:01 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 	aggr_printout(evsel, cpu, nr); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (aggr_mode == AGGR_GLOBAL) | 
					
						
							| 
									
										
										
										
											2010-11-16 11:05:01 +02:00
										 |  |  | 		cpu = 0; | 
					
						
							| 
									
										
										
										
											2009-09-22 14:53:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-12 17:58:49 +01:00
										 |  |  | 	fprintf(output, fmt, avg, csv_sep); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (evsel->unit) | 
					
						
							|  |  |  | 		fprintf(output, "%-*s%s", | 
					
						
							|  |  |  | 			csv_output ? 0 : unit_width, | 
					
						
							|  |  |  | 			evsel->unit, csv_sep); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	fprintf(output, "%-*s", csv_output ? 0 : 25, perf_evsel__name(evsel)); | 
					
						
							| 
									
										
											  
											
												perf stat: Add csv-style output
This patch adds an option (-x/--field-separator) to print counts using a
CSV-style output. The user can pass a custom separator. This makes it very easy
to import counts directly into your favorite spreadsheet without having to
write scripts.
Example:
$ perf stat --field-separator=,  -a -- sleep 1
4009.961740,task-clock-msecs
13,context-switches
2,CPU-migrations
189,page-faults
9596385684,cycles
3493659441,instructions
872897069,branches
41562,branch-misses
22424,cache-references
1289,cache-misses
Works also in non-aggregated mode:
$ perf stat -x ,  -a -A -- sleep 1
CPU0,1002.526168,task-clock-msecs
CPU1,1002.528365,task-clock-msecs
CPU2,1002.523360,task-clock-msecs
CPU3,1002.519878,task-clock-msecs
CPU0,1,context-switches
CPU1,5,context-switches
CPU2,5,context-switches
CPU3,6,context-switches
CPU0,0,CPU-migrations
CPU1,1,CPU-migrations
CPU2,0,CPU-migrations
CPU3,1,CPU-migrations
CPU0,2,page-faults
CPU1,6,page-faults
CPU2,9,page-faults
CPU3,174,page-faults
CPU0,2399439771,cycles
CPU1,2380369063,cycles
CPU2,2399142710,cycles
CPU3,2373161192,cycles
CPU0,872900618,instructions
CPU1,873030960,instructions
CPU2,872714525,instructions
CPU3,874460580,instructions
CPU0,221556839,branches
CPU1,218134342,branches
CPU2,218161730,branches
CPU3,218284093,branches
CPU0,18556,branch-misses
CPU1,1449,branch-misses
CPU2,3447,branch-misses
CPU3,12714,branch-misses
CPU0,8330,cache-references
CPU1,313844,cache-references
CPU2,47993728,cache-references
CPU3,826481,cache-references
CPU0,272,cache-misses
CPU1,5360,cache-misses
CPU2,1342193,cache-misses
CPU3,13992,cache-misses
This second version adds the ability to name a separator and uses
field-separator as the long option to be consistent with perf report.
Commiter note: Since we enabled --big-num by default in 201e0b0 and -x can't be
used with it, we need to notice if the user explicitely enabled or disabled -B,
add code to disable big_num if the user didn't explicitely set --big_num when
-x is used.
Cc: David S. Miller <davem@davemloft.net>
Cc: Frederik Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: paulus@samba.org
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Robert Richter <robert.richter@amd.com>
LKML-Reference: <4cf68aa7.0fedd80a.5294.1203@mx.google.com>
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2010-12-01 18:49:05 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
											
												perf tool: Add cgroup support
This patch adds the ability to filter monitoring based on container groups
(cgroups) for both perf stat and perf record. It is possible to monitor
multiple cgroup in parallel. There is one cgroup per event. The cgroups to
monitor are passed via a new -G option followed by a comma separated list of
cgroup names.
The cgroup filesystem has to be mounted. Given a cgroup name, the perf tool
finds the corresponding directory in the cgroup filesystem and opens it. It
then passes that file descriptor to the kernel.
Example:
$ perf stat -B -a -e cycles:u,cycles:u,cycles:u -G test1,,test2 -- sleep 1
 Performance counter stats for 'sleep 1':
      2,368,667,414  cycles                   test1
      2,369,661,459  cycles
      <not counted>  cycles                   test2
        1.001856890  seconds time elapsed
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
LKML-Reference: <4d590290.825bdf0a.7d0a.4890@mx.google.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-02-14 11:20:01 +02:00
										 |  |  | 	if (evsel->cgrp) | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 		fprintf(output, "%s%s", csv_sep, evsel->cgrp->name); | 
					
						
							| 
									
										
										
											
												perf tool: Add cgroup support
This patch adds the ability to filter monitoring based on container groups
(cgroups) for both perf stat and perf record. It is possible to monitor
multiple cgroup in parallel. There is one cgroup per event. The cgroups to
monitor are passed via a new -G option followed by a comma separated list of
cgroup names.
The cgroup filesystem has to be mounted. Given a cgroup name, the perf tool
finds the corresponding directory in the cgroup filesystem and opens it. It
then passes that file descriptor to the kernel.
Example:
$ perf stat -B -a -e cycles:u,cycles:u,cycles:u -G test1,,test2 -- sleep 1
 Performance counter stats for 'sleep 1':
      2,368,667,414  cycles                   test1
      2,369,661,459  cycles
      <not counted>  cycles                   test2
        1.001856890  seconds time elapsed
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
LKML-Reference: <4d590290.825bdf0a.7d0a.4890@mx.google.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-02-14 11:20:01 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												perf stat: Add interval printing
This patch adds a new printing mode for perf stat.  It allows interval
printing. That means perf stat can now print event deltas at regular
time interval.  This is useful to detect phases in programs.
The -I option enables interval printing. It expects an interval duration
in milliseconds. Minimum is 100ms. Once, activated perf stat prints
events deltas since last printout. All modes are supported.
$ perf stat -I 1000 -e cycles noploop 10
noploop for 10 seconds
 #           time             counts events
      1.000109853      2,388,560,546 cycles
      2.000262846      2,393,332,358 cycles
      3.000354131      2,393,176,537 cycles
      4.000439503      2,393,203,790 cycles
      5.000527075      2,393,167,675 cycles
      6.000609052      2,393,203,670 cycles
      7.000691082      2,393,175,678 cycles
The output format makes it easy to feed into a plotting program such as
gnuplot when the -I option is used in combination with the -x option:
$ perf stat -x, -I 1000 -e cycles noploop 10
noploop for 10 seconds
1.000084113,2378775498,cycles
2.000245798,2391056897,cycles
3.000354445,2392089414,cycles
4.000459115,2390936603,cycles
5.000565341,2392108173,cycles
Signed-off-by: Stephane Eranian <eranian@google.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1359460064-3060-3-git-send-email-eranian@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2013-01-29 12:47:44 +01:00
										 |  |  | 	if (csv_output || interval) | 
					
						
							| 
									
										
											  
											
												perf stat: Add csv-style output
This patch adds an option (-x/--field-separator) to print counts using a
CSV-style output. The user can pass a custom separator. This makes it very easy
to import counts directly into your favorite spreadsheet without having to
write scripts.
Example:
$ perf stat --field-separator=,  -a -- sleep 1
4009.961740,task-clock-msecs
13,context-switches
2,CPU-migrations
189,page-faults
9596385684,cycles
3493659441,instructions
872897069,branches
41562,branch-misses
22424,cache-references
1289,cache-misses
Works also in non-aggregated mode:
$ perf stat -x ,  -a -A -- sleep 1
CPU0,1002.526168,task-clock-msecs
CPU1,1002.528365,task-clock-msecs
CPU2,1002.523360,task-clock-msecs
CPU3,1002.519878,task-clock-msecs
CPU0,1,context-switches
CPU1,5,context-switches
CPU2,5,context-switches
CPU3,6,context-switches
CPU0,0,CPU-migrations
CPU1,1,CPU-migrations
CPU2,0,CPU-migrations
CPU3,1,CPU-migrations
CPU0,2,page-faults
CPU1,6,page-faults
CPU2,9,page-faults
CPU3,174,page-faults
CPU0,2399439771,cycles
CPU1,2380369063,cycles
CPU2,2399142710,cycles
CPU3,2373161192,cycles
CPU0,872900618,instructions
CPU1,873030960,instructions
CPU2,872714525,instructions
CPU3,874460580,instructions
CPU0,221556839,branches
CPU1,218134342,branches
CPU2,218161730,branches
CPU3,218284093,branches
CPU0,18556,branch-misses
CPU1,1449,branch-misses
CPU2,3447,branch-misses
CPU3,12714,branch-misses
CPU0,8330,cache-references
CPU1,313844,cache-references
CPU2,47993728,cache-references
CPU3,826481,cache-references
CPU0,272,cache-misses
CPU1,5360,cache-misses
CPU2,1342193,cache-misses
CPU3,13992,cache-misses
This second version adds the ability to name a separator and uses
field-separator as the long option to be consistent with perf report.
Commiter note: Since we enabled --big-num by default in 201e0b0 and -x can't be
used with it, we need to notice if the user explicitely enabled or disabled -B,
add code to disable big_num if the user didn't explicitely set --big_num when
-x is used.
Cc: David S. Miller <davem@davemloft.net>
Cc: Frederik Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: paulus@samba.org
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Robert Richter <robert.richter@amd.com>
LKML-Reference: <4cf68aa7.0fedd80a.5294.1203@mx.google.com>
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2010-12-01 18:49:05 +02:00
										 |  |  | 		return; | 
					
						
							| 
									
										
										
										
											2009-06-13 13:35:00 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-01-03 16:49:44 -02:00
										 |  |  | 	if (perf_evsel__match(evsel, HARDWARE, HW_INSTRUCTIONS)) { | 
					
						
							| 
									
										
										
										
											2010-11-16 11:05:01 +02:00
										 |  |  | 		total = avg_stats(&runtime_cycles_stats[cpu]); | 
					
						
							| 
									
										
										
										
											2013-10-01 14:06:44 +05:30
										 |  |  | 		if (total) { | 
					
						
							| 
									
										
										
										
											2009-09-22 14:53:51 +02:00
										 |  |  | 			ratio = avg / total; | 
					
						
							| 
									
										
										
										
											2013-10-01 14:06:44 +05:30
										 |  |  | 			fprintf(output, " #   %5.2f  insns per cycle        ", ratio); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
											
												perf stat: Analyze front-end and back-end stall counts
Sample output:
 Performance counter stats for './loop_1b':
        873.691065 task-clock               #    1.000 CPUs utilized
                 1 context-switches         #    0.000 M/sec
                 1 CPU-migrations           #    0.000 M/sec
                96 page-faults              #    0.000 M/sec
     2,012,637,222 cycles                   #    2.304 GHz                      (66.58%)
     1,001,397,911 stalled-cycles-frontend  #   49.76% frontend cycles idle     (66.58%)
         7,523,398 stalled-cycles-backend   #    0.37%  backend cycles idle     (66.76%)
     2,004,551,046 instructions             #    1.00  insns per cycle
                                            #    0.50  stalled cycles per insn  (66.80%)
     1,001,304,992 branches                 # 1146.063 M/sec                    (66.76%)
            39,453 branch-misses            #    0.00% of all branches          (66.64%)
        0.874046121  seconds time elapsed
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Link: http://lkml.kernel.org/n/tip-7y40wib8n003io7hjpn1dsrm@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-04-29 13:49:08 +02:00
										 |  |  | 		total = avg_stats(&runtime_stalled_cycles_front_stats[cpu]); | 
					
						
							|  |  |  | 		total = max(total, avg_stats(&runtime_stalled_cycles_back_stats[cpu])); | 
					
						
							| 
									
										
											  
											
												perf stat: Add stalled cycles accounting, prettify the resulting output
Add stalled cycles accounting and use it to print the "cycles stalled per
instruction" value.
Also change the unit of the cycles output from M/sec to GHz - this is more
intuitive.
Prettify the output to:
 Performance counter stats for './loop_1b_instructions':
        239.775036 task-clock               #    0.997 CPUs utilized
       761,903,912 cycles                   #    3.178 GHz
       356,620,620 stalled-cycles           #   46.81% of all cycles are idle
     1,001,578,351 instructions             #    1.31  insns per cycle
                                            #    0.36  stalled cycles per insn
            14,782 cache-references         #    0.062 M/sec
             5,694 cache-misses             #   38.520 % of all cache refs
        0.240493656  seconds time elapsed
Also adjust the --repeat output to make the percentages align vertically:
 Performance counter stats for './loop_1b_instructions' (10 runs):
        236.096793 task-clock               #    0.997 CPUs utilized             ( +-   0.011% )
       756,553,086 cycles                   #    3.204 GHz                       ( +-   0.002% )
       354,942,692 stalled-cycles           #   46.92% of all cycles are idle    ( +-   0.008% )
     1,001,389,700 instructions             #    1.32  insns per cycle
                                            #    0.35  stalled cycles per insn   ( +-   0.000% )
            10,166 cache-references         #    0.043 M/sec                     ( +-   0.742% )
               468 cache-misses             #    4.608 % of all cache refs       ( +-  13.385% )
        0.236874136  seconds time elapsed   ( +- 0.01% )
Acked-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
Acked-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Link: http://lkml.kernel.org/n/tip-uapziqny39601apdmmhoz7hk@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-04-27 04:34:16 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		if (total && avg) { | 
					
						
							|  |  |  | 			ratio = total / avg; | 
					
						
							| 
									
										
										
										
											2013-11-12 17:58:49 +01:00
										 |  |  | 			fprintf(output, "\n"); | 
					
						
							|  |  |  | 			if (aggr_mode == AGGR_NONE) | 
					
						
							|  |  |  | 				fprintf(output, "        "); | 
					
						
							|  |  |  | 			fprintf(output, "                                                  #   %5.2f  stalled cycles per insn", ratio); | 
					
						
							| 
									
										
											  
											
												perf stat: Add stalled cycles accounting, prettify the resulting output
Add stalled cycles accounting and use it to print the "cycles stalled per
instruction" value.
Also change the unit of the cycles output from M/sec to GHz - this is more
intuitive.
Prettify the output to:
 Performance counter stats for './loop_1b_instructions':
        239.775036 task-clock               #    0.997 CPUs utilized
       761,903,912 cycles                   #    3.178 GHz
       356,620,620 stalled-cycles           #   46.81% of all cycles are idle
     1,001,578,351 instructions             #    1.31  insns per cycle
                                            #    0.36  stalled cycles per insn
            14,782 cache-references         #    0.062 M/sec
             5,694 cache-misses             #   38.520 % of all cache refs
        0.240493656  seconds time elapsed
Also adjust the --repeat output to make the percentages align vertically:
 Performance counter stats for './loop_1b_instructions' (10 runs):
        236.096793 task-clock               #    0.997 CPUs utilized             ( +-   0.011% )
       756,553,086 cycles                   #    3.204 GHz                       ( +-   0.002% )
       354,942,692 stalled-cycles           #   46.92% of all cycles are idle    ( +-   0.008% )
     1,001,389,700 instructions             #    1.32  insns per cycle
                                            #    0.35  stalled cycles per insn   ( +-   0.000% )
            10,166 cache-references         #    0.043 M/sec                     ( +-   0.742% )
               468 cache-misses             #    4.608 % of all cache refs       ( +-  13.385% )
        0.236874136  seconds time elapsed   ( +- 0.01% )
Acked-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
Acked-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Link: http://lkml.kernel.org/n/tip-uapziqny39601apdmmhoz7hk@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-04-27 04:34:16 +02:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-01-03 16:49:44 -02:00
										 |  |  | 	} else if (perf_evsel__match(evsel, HARDWARE, HW_BRANCH_MISSES) && | 
					
						
							| 
									
										
										
										
											2010-11-16 11:05:01 +02:00
										 |  |  | 			runtime_branches_stats[cpu].n != 0) { | 
					
						
							| 
									
										
										
										
											2011-04-27 12:16:10 +02:00
										 |  |  | 		print_branch_misses(cpu, evsel, avg); | 
					
						
							| 
									
										
											  
											
												perf stat: Print out miss/hit ratio for L1 data-cache events
Print out this kind of l1-dcache-misses percentage:
 Performance counter stats for './bw_tcp localhost':
    29,956,262,201 cycles                   #    3.002 GHz                      (scaled from 85.14%)
     8,255,209,558 stalled-cycles           #   27.56% of all cycles are idle   (scaled from 86.56%)
     1,206,130,308 l1-dcache-misses         #   40.49% of all L1-dcache hits    (scaled from 86.30%)
     2,978,756,779 l1-dcache-refs           #  298.512 M/sec                    (scaled from 70.02%)
     8,861,956,159 instructions             #    0.30  insns per cycle
                                            #    0.93  stalled cycles per insn  (scaled from 84.27%)
     1,644,306,068 branches                 #  164.782 M/sec                    (scaled from 86.43%)
        74,778,443 branch-misses            #    4.55% of all branches          (scaled from 70.69%)
       9978.695711 task-clock               #    0.693 CPUs utilized
       14.404347983  seconds time elapsed
And color the result depending on the severity of cache-trashing.
Acked-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
Acked-by Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Link: http://lkml.kernel.org/n/tip-54gmz0zymaid84zcs7joq02p@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-04-27 13:25:24 +02:00
										 |  |  | 	} else if ( | 
					
						
							|  |  |  | 		evsel->attr.type == PERF_TYPE_HW_CACHE && | 
					
						
							|  |  |  | 		evsel->attr.config ==  ( PERF_COUNT_HW_CACHE_L1D | | 
					
						
							|  |  |  | 					((PERF_COUNT_HW_CACHE_OP_READ) << 8) | | 
					
						
							|  |  |  | 					((PERF_COUNT_HW_CACHE_RESULT_MISS) << 16)) && | 
					
						
							| 
									
										
											  
											
												perf stat: Add -d/--detailed flag to run with a lot of events
Add the new -d/--detailed flag, which generates a pretty detailed event list:
 Performance counter stats for './hackbench 10' (10 runs):
       1514.287888 task-clock               #   10.897 CPUs utilized            ( +-  3.05% )
            39,698 context-switches         #    0.026 M/sec                    ( +- 12.19% )
             8,147 CPU-migrations           #    0.005 M/sec                    ( +- 16.55% )
            17,918 page-faults              #    0.012 M/sec                    ( +-  0.37% )
     2,944,504,050 cycles                   #    1.944 GHz                      ( +-  3.89% )  (32.60%)
     1,043,971,283 stalled-cycles           #   35.45% of all cycles are idle   ( +-  5.22% )  (44.48%)
     1,655,906,768 instructions             #    0.56  insns per cycle
                                            #    0.63  stalled cycles per insn  ( +-  1.95% )  (55.09%)
       338,832,373 branches                 #  223.757 M/sec                    ( +-  1.96% )  (64.47%)
         3,892,416 branch-misses            #    1.15% of all branches          ( +-  5.49% )  (73.12%)
       606,410,482 L1-dcache-loads          #  400.459 M/sec                    ( +-  1.29% )  (71.21%)
        31,204,395 L1-dcache-load-misses    #    5.15% of all L1-dcache hits    ( +-  3.04% )  (60.43%)
         3,922,751 LLC-loads                #    2.590 M/sec                    ( +-  6.80% )  (46.87%)
         5,037,288 LLC-load-misses          #    3.327 M/sec                    ( +-  3.56% )  (13.00%)
        0.138966828  seconds time elapsed  ( +-  4.11% )
This can be used "at a glance" for narrower analysis.
-d can also be used in addition to other -e events, to further expand an event list.
Acked-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
Acked-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Link: http://lkml.kernel.org/n/tip-cxs98quixs3qyvdqx3goojc4@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-04-27 13:50:47 +02:00
										 |  |  | 			runtime_l1_dcache_stats[cpu].n != 0) { | 
					
						
							| 
									
										
											  
											
												perf stat: Print out miss/hit ratio for L1 data-cache events
Print out this kind of l1-dcache-misses percentage:
 Performance counter stats for './bw_tcp localhost':
    29,956,262,201 cycles                   #    3.002 GHz                      (scaled from 85.14%)
     8,255,209,558 stalled-cycles           #   27.56% of all cycles are idle   (scaled from 86.56%)
     1,206,130,308 l1-dcache-misses         #   40.49% of all L1-dcache hits    (scaled from 86.30%)
     2,978,756,779 l1-dcache-refs           #  298.512 M/sec                    (scaled from 70.02%)
     8,861,956,159 instructions             #    0.30  insns per cycle
                                            #    0.93  stalled cycles per insn  (scaled from 84.27%)
     1,644,306,068 branches                 #  164.782 M/sec                    (scaled from 86.43%)
        74,778,443 branch-misses            #    4.55% of all branches          (scaled from 70.69%)
       9978.695711 task-clock               #    0.693 CPUs utilized
       14.404347983  seconds time elapsed
And color the result depending on the severity of cache-trashing.
Acked-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
Acked-by Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Link: http://lkml.kernel.org/n/tip-54gmz0zymaid84zcs7joq02p@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-04-27 13:25:24 +02:00
										 |  |  | 		print_l1_dcache_misses(cpu, evsel, avg); | 
					
						
							| 
									
										
										
											
												perf stat: Add more cache-miss percentage printouts
Print out the cache-miss percentage as well if the cache refs were
collected, for all the generic cache event types.
Before:
   11,103,723,230 dTLB-loads                #  622.471 M/sec                    ( +-  0.30% )
       87,065,337 dTLB-load-misses          #    4.881 M/sec                    ( +-  0.90% )
After:
   11,353,713,242 dTLB-loads                #  626.020 M/sec                    ( +-  0.35% )
      113,393,472 dTLB-load-misses          #    1.00% of all dTLB cache hits   ( +-  0.49% )
Also ASCII color highlight too high percentages, them when it's executed on the console.
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Steven Rostedt <rostedt@goodmis.org>
Link: http://lkml.kernel.org/n/tip-lkhwxsevdbd9a8nymx0vxc3y@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-05-19 14:01:42 +02:00
										 |  |  | 	} else if ( | 
					
						
							|  |  |  | 		evsel->attr.type == PERF_TYPE_HW_CACHE && | 
					
						
							|  |  |  | 		evsel->attr.config ==  ( PERF_COUNT_HW_CACHE_L1I | | 
					
						
							|  |  |  | 					((PERF_COUNT_HW_CACHE_OP_READ) << 8) | | 
					
						
							|  |  |  | 					((PERF_COUNT_HW_CACHE_RESULT_MISS) << 16)) && | 
					
						
							|  |  |  | 			runtime_l1_icache_stats[cpu].n != 0) { | 
					
						
							|  |  |  | 		print_l1_icache_misses(cpu, evsel, avg); | 
					
						
							|  |  |  | 	} else if ( | 
					
						
							|  |  |  | 		evsel->attr.type == PERF_TYPE_HW_CACHE && | 
					
						
							|  |  |  | 		evsel->attr.config ==  ( PERF_COUNT_HW_CACHE_DTLB | | 
					
						
							|  |  |  | 					((PERF_COUNT_HW_CACHE_OP_READ) << 8) | | 
					
						
							|  |  |  | 					((PERF_COUNT_HW_CACHE_RESULT_MISS) << 16)) && | 
					
						
							|  |  |  | 			runtime_dtlb_cache_stats[cpu].n != 0) { | 
					
						
							|  |  |  | 		print_dtlb_cache_misses(cpu, evsel, avg); | 
					
						
							|  |  |  | 	} else if ( | 
					
						
							|  |  |  | 		evsel->attr.type == PERF_TYPE_HW_CACHE && | 
					
						
							|  |  |  | 		evsel->attr.config ==  ( PERF_COUNT_HW_CACHE_ITLB | | 
					
						
							|  |  |  | 					((PERF_COUNT_HW_CACHE_OP_READ) << 8) | | 
					
						
							|  |  |  | 					((PERF_COUNT_HW_CACHE_RESULT_MISS) << 16)) && | 
					
						
							|  |  |  | 			runtime_itlb_cache_stats[cpu].n != 0) { | 
					
						
							|  |  |  | 		print_itlb_cache_misses(cpu, evsel, avg); | 
					
						
							|  |  |  | 	} else if ( | 
					
						
							|  |  |  | 		evsel->attr.type == PERF_TYPE_HW_CACHE && | 
					
						
							|  |  |  | 		evsel->attr.config ==  ( PERF_COUNT_HW_CACHE_LL | | 
					
						
							|  |  |  | 					((PERF_COUNT_HW_CACHE_OP_READ) << 8) | | 
					
						
							|  |  |  | 					((PERF_COUNT_HW_CACHE_RESULT_MISS) << 16)) && | 
					
						
							|  |  |  | 			runtime_ll_cache_stats[cpu].n != 0) { | 
					
						
							|  |  |  | 		print_ll_cache_misses(cpu, evsel, avg); | 
					
						
							| 
									
										
										
										
											2011-04-27 03:42:18 +02:00
										 |  |  | 	} else if (perf_evsel__match(evsel, HARDWARE, HW_CACHE_MISSES) && | 
					
						
							|  |  |  | 			runtime_cacherefs_stats[cpu].n != 0) { | 
					
						
							|  |  |  | 		total = avg_stats(&runtime_cacherefs_stats[cpu]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (total) | 
					
						
							|  |  |  | 			ratio = avg * 100 / total; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 		fprintf(output, " # %8.3f %% of all cache refs    ", ratio); | 
					
						
							| 
									
										
										
										
											2011-04-27 03:42:18 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
											
												perf stat: Analyze front-end and back-end stall counts
Sample output:
 Performance counter stats for './loop_1b':
        873.691065 task-clock               #    1.000 CPUs utilized
                 1 context-switches         #    0.000 M/sec
                 1 CPU-migrations           #    0.000 M/sec
                96 page-faults              #    0.000 M/sec
     2,012,637,222 cycles                   #    2.304 GHz                      (66.58%)
     1,001,397,911 stalled-cycles-frontend  #   49.76% frontend cycles idle     (66.58%)
         7,523,398 stalled-cycles-backend   #    0.37%  backend cycles idle     (66.76%)
     2,004,551,046 instructions             #    1.00  insns per cycle
                                            #    0.50  stalled cycles per insn  (66.80%)
     1,001,304,992 branches                 # 1146.063 M/sec                    (66.76%)
            39,453 branch-misses            #    0.00% of all branches          (66.64%)
        0.874046121  seconds time elapsed
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Link: http://lkml.kernel.org/n/tip-7y40wib8n003io7hjpn1dsrm@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-04-29 13:49:08 +02:00
										 |  |  | 	} else if (perf_evsel__match(evsel, HARDWARE, HW_STALLED_CYCLES_FRONTEND)) { | 
					
						
							|  |  |  | 		print_stalled_cycles_frontend(cpu, evsel, avg); | 
					
						
							| 
									
										
										
										
											2011-04-29 14:41:28 +02:00
										 |  |  | 	} else if (perf_evsel__match(evsel, HARDWARE, HW_STALLED_CYCLES_BACKEND)) { | 
					
						
							| 
									
										
										
											
												perf stat: Analyze front-end and back-end stall counts
Sample output:
 Performance counter stats for './loop_1b':
        873.691065 task-clock               #    1.000 CPUs utilized
                 1 context-switches         #    0.000 M/sec
                 1 CPU-migrations           #    0.000 M/sec
                96 page-faults              #    0.000 M/sec
     2,012,637,222 cycles                   #    2.304 GHz                      (66.58%)
     1,001,397,911 stalled-cycles-frontend  #   49.76% frontend cycles idle     (66.58%)
         7,523,398 stalled-cycles-backend   #    0.37%  backend cycles idle     (66.76%)
     2,004,551,046 instructions             #    1.00  insns per cycle
                                            #    0.50  stalled cycles per insn  (66.80%)
     1,001,304,992 branches                 # 1146.063 M/sec                    (66.76%)
            39,453 branch-misses            #    0.00% of all branches          (66.64%)
        0.874046121  seconds time elapsed
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Link: http://lkml.kernel.org/n/tip-7y40wib8n003io7hjpn1dsrm@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-04-29 13:49:08 +02:00
										 |  |  | 		print_stalled_cycles_backend(cpu, evsel, avg); | 
					
						
							| 
									
										
											  
											
												perf stat: Add stalled cycles accounting, prettify the resulting output
Add stalled cycles accounting and use it to print the "cycles stalled per
instruction" value.
Also change the unit of the cycles output from M/sec to GHz - this is more
intuitive.
Prettify the output to:
 Performance counter stats for './loop_1b_instructions':
        239.775036 task-clock               #    0.997 CPUs utilized
       761,903,912 cycles                   #    3.178 GHz
       356,620,620 stalled-cycles           #   46.81% of all cycles are idle
     1,001,578,351 instructions             #    1.31  insns per cycle
                                            #    0.36  stalled cycles per insn
            14,782 cache-references         #    0.062 M/sec
             5,694 cache-misses             #   38.520 % of all cache refs
        0.240493656  seconds time elapsed
Also adjust the --repeat output to make the percentages align vertically:
 Performance counter stats for './loop_1b_instructions' (10 runs):
        236.096793 task-clock               #    0.997 CPUs utilized             ( +-   0.011% )
       756,553,086 cycles                   #    3.204 GHz                       ( +-   0.002% )
       354,942,692 stalled-cycles           #   46.92% of all cycles are idle    ( +-   0.008% )
     1,001,389,700 instructions             #    1.32  insns per cycle
                                            #    0.35  stalled cycles per insn   ( +-   0.000% )
            10,166 cache-references         #    0.043 M/sec                     ( +-   0.742% )
               468 cache-misses             #    4.608 % of all cache refs       ( +-  13.385% )
        0.236874136  seconds time elapsed   ( +- 0.01% )
Acked-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
Acked-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Link: http://lkml.kernel.org/n/tip-uapziqny39601apdmmhoz7hk@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-04-27 04:34:16 +02:00
										 |  |  | 	} else if (perf_evsel__match(evsel, HARDWARE, HW_CPU_CYCLES)) { | 
					
						
							| 
									
										
										
										
											2010-11-16 11:05:01 +02:00
										 |  |  | 		total = avg_stats(&runtime_nsecs_stats[cpu]); | 
					
						
							| 
									
										
										
										
											2009-09-22 14:53:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-30 16:43:05 +05:30
										 |  |  | 		if (total) { | 
					
						
							|  |  |  | 			ratio = avg / total; | 
					
						
							|  |  |  | 			fprintf(output, " # %8.3f GHz                    ", ratio); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2013-08-21 16:47:26 -07:00
										 |  |  | 	} else if (transaction_run && | 
					
						
							|  |  |  | 		   perf_evsel__cmp(evsel, nth_evsel(T_CYCLES_IN_TX))) { | 
					
						
							|  |  |  | 		total = avg_stats(&runtime_cycles_stats[cpu]); | 
					
						
							|  |  |  | 		if (total) | 
					
						
							|  |  |  | 			fprintf(output, | 
					
						
							|  |  |  | 				" #   %5.2f%% transactional cycles   ", | 
					
						
							|  |  |  | 				100.0 * (avg / total)); | 
					
						
							|  |  |  | 	} else if (transaction_run && | 
					
						
							|  |  |  | 		   perf_evsel__cmp(evsel, nth_evsel(T_CYCLES_IN_TX_CP))) { | 
					
						
							|  |  |  | 		total = avg_stats(&runtime_cycles_stats[cpu]); | 
					
						
							|  |  |  | 		total2 = avg_stats(&runtime_cycles_in_tx_stats[cpu]); | 
					
						
							|  |  |  | 		if (total2 < avg) | 
					
						
							|  |  |  | 			total2 = avg; | 
					
						
							|  |  |  | 		if (total) | 
					
						
							|  |  |  | 			fprintf(output, | 
					
						
							|  |  |  | 				" #   %5.2f%% aborted cycles         ", | 
					
						
							|  |  |  | 				100.0 * ((total2-avg) / total)); | 
					
						
							|  |  |  | 	} else if (transaction_run && | 
					
						
							|  |  |  | 		   perf_evsel__cmp(evsel, nth_evsel(T_TRANSACTION_START)) && | 
					
						
							|  |  |  | 		   avg > 0 && | 
					
						
							|  |  |  | 		   runtime_cycles_in_tx_stats[cpu].n != 0) { | 
					
						
							|  |  |  | 		total = avg_stats(&runtime_cycles_in_tx_stats[cpu]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (total) | 
					
						
							|  |  |  | 			ratio = total / avg; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		fprintf(output, " # %8.0f cycles / transaction   ", ratio); | 
					
						
							|  |  |  | 	} else if (transaction_run && | 
					
						
							|  |  |  | 		   perf_evsel__cmp(evsel, nth_evsel(T_ELISION_START)) && | 
					
						
							|  |  |  | 		   avg > 0 && | 
					
						
							|  |  |  | 		   runtime_cycles_in_tx_stats[cpu].n != 0) { | 
					
						
							|  |  |  | 		total = avg_stats(&runtime_cycles_in_tx_stats[cpu]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (total) | 
					
						
							|  |  |  | 			ratio = total / avg; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		fprintf(output, " # %8.0f cycles / elision       ", ratio); | 
					
						
							| 
									
										
											  
											
												perf stat: Add stalled cycles accounting, prettify the resulting output
Add stalled cycles accounting and use it to print the "cycles stalled per
instruction" value.
Also change the unit of the cycles output from M/sec to GHz - this is more
intuitive.
Prettify the output to:
 Performance counter stats for './loop_1b_instructions':
        239.775036 task-clock               #    0.997 CPUs utilized
       761,903,912 cycles                   #    3.178 GHz
       356,620,620 stalled-cycles           #   46.81% of all cycles are idle
     1,001,578,351 instructions             #    1.31  insns per cycle
                                            #    0.36  stalled cycles per insn
            14,782 cache-references         #    0.062 M/sec
             5,694 cache-misses             #   38.520 % of all cache refs
        0.240493656  seconds time elapsed
Also adjust the --repeat output to make the percentages align vertically:
 Performance counter stats for './loop_1b_instructions' (10 runs):
        236.096793 task-clock               #    0.997 CPUs utilized             ( +-   0.011% )
       756,553,086 cycles                   #    3.204 GHz                       ( +-   0.002% )
       354,942,692 stalled-cycles           #   46.92% of all cycles are idle    ( +-   0.008% )
     1,001,389,700 instructions             #    1.32  insns per cycle
                                            #    0.35  stalled cycles per insn   ( +-   0.000% )
            10,166 cache-references         #    0.043 M/sec                     ( +-   0.742% )
               468 cache-misses             #    4.608 % of all cache refs       ( +-  13.385% )
        0.236874136  seconds time elapsed   ( +- 0.01% )
Acked-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
Acked-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Link: http://lkml.kernel.org/n/tip-uapziqny39601apdmmhoz7hk@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-04-27 04:34:16 +02:00
										 |  |  | 	} else if (runtime_nsecs_stats[cpu].n != 0) { | 
					
						
							| 
									
										
										
										
											2012-02-06 16:44:44 +09:00
										 |  |  | 		char unit = 'M'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												perf stat: Add stalled cycles accounting, prettify the resulting output
Add stalled cycles accounting and use it to print the "cycles stalled per
instruction" value.
Also change the unit of the cycles output from M/sec to GHz - this is more
intuitive.
Prettify the output to:
 Performance counter stats for './loop_1b_instructions':
        239.775036 task-clock               #    0.997 CPUs utilized
       761,903,912 cycles                   #    3.178 GHz
       356,620,620 stalled-cycles           #   46.81% of all cycles are idle
     1,001,578,351 instructions             #    1.31  insns per cycle
                                            #    0.36  stalled cycles per insn
            14,782 cache-references         #    0.062 M/sec
             5,694 cache-misses             #   38.520 % of all cache refs
        0.240493656  seconds time elapsed
Also adjust the --repeat output to make the percentages align vertically:
 Performance counter stats for './loop_1b_instructions' (10 runs):
        236.096793 task-clock               #    0.997 CPUs utilized             ( +-   0.011% )
       756,553,086 cycles                   #    3.204 GHz                       ( +-   0.002% )
       354,942,692 stalled-cycles           #   46.92% of all cycles are idle    ( +-   0.008% )
     1,001,389,700 instructions             #    1.32  insns per cycle
                                            #    0.35  stalled cycles per insn   ( +-   0.000% )
            10,166 cache-references         #    0.043 M/sec                     ( +-   0.742% )
               468 cache-misses             #    4.608 % of all cache refs       ( +-  13.385% )
        0.236874136  seconds time elapsed   ( +- 0.01% )
Acked-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
Acked-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Link: http://lkml.kernel.org/n/tip-uapziqny39601apdmmhoz7hk@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-04-27 04:34:16 +02:00
										 |  |  | 		total = avg_stats(&runtime_nsecs_stats[cpu]); | 
					
						
							| 
									
										
										
										
											2011-04-24 15:05:10 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		if (total) | 
					
						
							| 
									
										
											  
											
												perf stat: Add stalled cycles accounting, prettify the resulting output
Add stalled cycles accounting and use it to print the "cycles stalled per
instruction" value.
Also change the unit of the cycles output from M/sec to GHz - this is more
intuitive.
Prettify the output to:
 Performance counter stats for './loop_1b_instructions':
        239.775036 task-clock               #    0.997 CPUs utilized
       761,903,912 cycles                   #    3.178 GHz
       356,620,620 stalled-cycles           #   46.81% of all cycles are idle
     1,001,578,351 instructions             #    1.31  insns per cycle
                                            #    0.36  stalled cycles per insn
            14,782 cache-references         #    0.062 M/sec
             5,694 cache-misses             #   38.520 % of all cache refs
        0.240493656  seconds time elapsed
Also adjust the --repeat output to make the percentages align vertically:
 Performance counter stats for './loop_1b_instructions' (10 runs):
        236.096793 task-clock               #    0.997 CPUs utilized             ( +-   0.011% )
       756,553,086 cycles                   #    3.204 GHz                       ( +-   0.002% )
       354,942,692 stalled-cycles           #   46.92% of all cycles are idle    ( +-   0.008% )
     1,001,389,700 instructions             #    1.32  insns per cycle
                                            #    0.35  stalled cycles per insn   ( +-   0.000% )
            10,166 cache-references         #    0.043 M/sec                     ( +-   0.742% )
               468 cache-misses             #    4.608 % of all cache refs       ( +-  13.385% )
        0.236874136  seconds time elapsed   ( +- 0.01% )
Acked-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
Acked-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Link: http://lkml.kernel.org/n/tip-uapziqny39601apdmmhoz7hk@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-04-27 04:34:16 +02:00
										 |  |  | 			ratio = 1000.0 * avg / total; | 
					
						
							| 
									
										
										
										
											2012-02-06 16:44:44 +09:00
										 |  |  | 		if (ratio < 0.001) { | 
					
						
							|  |  |  | 			ratio *= 1000; | 
					
						
							|  |  |  | 			unit = 'K'; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2011-04-24 15:05:10 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-06 16:44:44 +09:00
										 |  |  | 		fprintf(output, " # %8.3f %c/sec                  ", ratio, unit); | 
					
						
							| 
									
										
										
										
											2011-04-27 05:39:24 +02:00
										 |  |  | 	} else { | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 		fprintf(output, "                                   "); | 
					
						
							| 
									
										
										
										
											2009-06-13 13:35:00 +02:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | static void print_aggr(char *prefix) | 
					
						
							| 
									
										
										
										
											2013-02-06 15:46:02 +01:00
										 |  |  | { | 
					
						
							|  |  |  | 	struct perf_evsel *counter; | 
					
						
							| 
									
										
										
										
											2013-07-05 19:06:45 +02:00
										 |  |  | 	int cpu, cpu2, s, s2, id, nr; | 
					
						
							| 
									
										
										
										
											2013-11-12 17:58:49 +01:00
										 |  |  | 	double uval; | 
					
						
							| 
									
										
										
										
											2013-02-06 15:46:02 +01:00
										 |  |  | 	u64 ena, run, val; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 	if (!(aggr_map || aggr_get_id)) | 
					
						
							| 
									
										
										
										
											2013-02-06 15:46:02 +01:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 	for (s = 0; s < aggr_map->nr; s++) { | 
					
						
							|  |  |  | 		id = aggr_map->map[s]; | 
					
						
							| 
									
										
										
										
											2014-01-10 10:37:27 -03:00
										 |  |  | 		evlist__for_each(evsel_list, counter) { | 
					
						
							| 
									
										
										
										
											2013-02-06 15:46:02 +01:00
										 |  |  | 			val = ena = run = 0; | 
					
						
							|  |  |  | 			nr = 0; | 
					
						
							|  |  |  | 			for (cpu = 0; cpu < perf_evsel__nr_cpus(counter); cpu++) { | 
					
						
							| 
									
										
										
										
											2013-07-05 19:06:45 +02:00
										 |  |  | 				cpu2 = perf_evsel__cpus(counter)->map[cpu]; | 
					
						
							|  |  |  | 				s2 = aggr_get_id(evsel_list->cpus, cpu2); | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 				if (s2 != id) | 
					
						
							| 
									
										
										
										
											2013-02-06 15:46:02 +01:00
										 |  |  | 					continue; | 
					
						
							|  |  |  | 				val += counter->counts->cpu[cpu].val; | 
					
						
							|  |  |  | 				ena += counter->counts->cpu[cpu].ena; | 
					
						
							|  |  |  | 				run += counter->counts->cpu[cpu].run; | 
					
						
							|  |  |  | 				nr++; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			if (prefix) | 
					
						
							|  |  |  | 				fprintf(output, "%s", prefix); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			if (run == 0 || ena == 0) { | 
					
						
							| 
									
										
										
										
											2013-07-05 19:06:45 +02:00
										 |  |  | 				aggr_printout(counter, id, nr); | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-12 17:58:49 +01:00
										 |  |  | 				fprintf(output, "%*s%s", | 
					
						
							| 
									
										
										
										
											2013-02-06 15:46:02 +01:00
										 |  |  | 					csv_output ? 0 : 18, | 
					
						
							|  |  |  | 					counter->supported ? CNTR_NOT_COUNTED : CNTR_NOT_SUPPORTED, | 
					
						
							| 
									
										
										
										
											2013-11-12 17:58:49 +01:00
										 |  |  | 					csv_sep); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				fprintf(output, "%-*s%s", | 
					
						
							|  |  |  | 					csv_output ? 0 : unit_width, | 
					
						
							|  |  |  | 					counter->unit, csv_sep); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				fprintf(output, "%*s", | 
					
						
							|  |  |  | 					csv_output ? 0 : -25, | 
					
						
							| 
									
										
										
										
											2013-02-06 15:46:02 +01:00
										 |  |  | 					perf_evsel__name(counter)); | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-06 15:46:02 +01:00
										 |  |  | 				if (counter->cgrp) | 
					
						
							|  |  |  | 					fprintf(output, "%s%s", | 
					
						
							|  |  |  | 						csv_sep, counter->cgrp->name); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				fputc('\n', output); | 
					
						
							|  |  |  | 				continue; | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2013-11-12 17:58:49 +01:00
										 |  |  | 			uval = val * counter->scale; | 
					
						
							| 
									
										
										
										
											2013-02-06 15:46:02 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			if (nsec_counter(counter)) | 
					
						
							| 
									
										
										
										
											2013-11-12 17:58:49 +01:00
										 |  |  | 				nsec_printout(id, nr, counter, uval); | 
					
						
							| 
									
										
										
										
											2013-02-06 15:46:02 +01:00
										 |  |  | 			else | 
					
						
							| 
									
										
										
										
											2013-11-12 17:58:49 +01:00
										 |  |  | 				abs_printout(id, nr, counter, uval); | 
					
						
							| 
									
										
										
										
											2013-02-06 15:46:02 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			if (!csv_output) { | 
					
						
							|  |  |  | 				print_noise(counter, 1.0); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				if (run != ena) | 
					
						
							|  |  |  | 					fprintf(output, "  (%.2f%%)", | 
					
						
							|  |  |  | 						100.0 * run / ena); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			fputc('\n', output); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-29 09:10:54 +02:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * Print out the results of a single counter: | 
					
						
							| 
									
										
										
										
											2010-11-16 11:05:01 +02:00
										 |  |  |  * aggregated counts in system-wide mode | 
					
						
							| 
									
										
										
										
											2009-05-29 09:10:54 +02:00
										 |  |  |  */ | 
					
						
							| 
									
										
											  
											
												perf stat: Add interval printing
This patch adds a new printing mode for perf stat.  It allows interval
printing. That means perf stat can now print event deltas at regular
time interval.  This is useful to detect phases in programs.
The -I option enables interval printing. It expects an interval duration
in milliseconds. Minimum is 100ms. Once, activated perf stat prints
events deltas since last printout. All modes are supported.
$ perf stat -I 1000 -e cycles noploop 10
noploop for 10 seconds
 #           time             counts events
      1.000109853      2,388,560,546 cycles
      2.000262846      2,393,332,358 cycles
      3.000354131      2,393,176,537 cycles
      4.000439503      2,393,203,790 cycles
      5.000527075      2,393,167,675 cycles
      6.000609052      2,393,203,670 cycles
      7.000691082      2,393,175,678 cycles
The output format makes it easy to feed into a plotting program such as
gnuplot when the -I option is used in combination with the -x option:
$ perf stat -x, -I 1000 -e cycles noploop 10
noploop for 10 seconds
1.000084113,2378775498,cycles
2.000245798,2391056897,cycles
3.000354445,2392089414,cycles
4.000459115,2390936603,cycles
5.000565341,2392108173,cycles
Signed-off-by: Stephane Eranian <eranian@google.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1359460064-3060-3-git-send-email-eranian@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2013-01-29 12:47:44 +01:00
										 |  |  | static void print_counter_aggr(struct perf_evsel *counter, char *prefix) | 
					
						
							| 
									
										
										
										
											2009-05-29 09:10:54 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-01-03 16:39:04 -02:00
										 |  |  | 	struct perf_stat *ps = counter->priv; | 
					
						
							|  |  |  | 	double avg = avg_stats(&ps->res_stats[0]); | 
					
						
							| 
									
										
										
										
											2011-01-03 17:45:52 -02:00
										 |  |  | 	int scaled = counter->counts->scaled; | 
					
						
							| 
									
										
										
										
											2013-11-12 17:58:49 +01:00
										 |  |  | 	double uval; | 
					
						
							| 
									
										
										
										
											2009-05-29 09:10:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												perf stat: Add interval printing
This patch adds a new printing mode for perf stat.  It allows interval
printing. That means perf stat can now print event deltas at regular
time interval.  This is useful to detect phases in programs.
The -I option enables interval printing. It expects an interval duration
in milliseconds. Minimum is 100ms. Once, activated perf stat prints
events deltas since last printout. All modes are supported.
$ perf stat -I 1000 -e cycles noploop 10
noploop for 10 seconds
 #           time             counts events
      1.000109853      2,388,560,546 cycles
      2.000262846      2,393,332,358 cycles
      3.000354131      2,393,176,537 cycles
      4.000439503      2,393,203,790 cycles
      5.000527075      2,393,167,675 cycles
      6.000609052      2,393,203,670 cycles
      7.000691082      2,393,175,678 cycles
The output format makes it easy to feed into a plotting program such as
gnuplot when the -I option is used in combination with the -x option:
$ perf stat -x, -I 1000 -e cycles noploop 10
noploop for 10 seconds
1.000084113,2378775498,cycles
2.000245798,2391056897,cycles
3.000354445,2392089414,cycles
4.000459115,2390936603,cycles
5.000565341,2392108173,cycles
Signed-off-by: Stephane Eranian <eranian@google.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1359460064-3060-3-git-send-email-eranian@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2013-01-29 12:47:44 +01:00
										 |  |  | 	if (prefix) | 
					
						
							|  |  |  | 		fprintf(output, "%s", prefix); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-29 09:10:54 +02:00
										 |  |  | 	if (scaled == -1) { | 
					
						
							| 
									
										
										
										
											2013-11-12 17:58:49 +01:00
										 |  |  | 		fprintf(output, "%*s%s", | 
					
						
							| 
									
										
											  
											
												perf stat: Add csv-style output
This patch adds an option (-x/--field-separator) to print counts using a
CSV-style output. The user can pass a custom separator. This makes it very easy
to import counts directly into your favorite spreadsheet without having to
write scripts.
Example:
$ perf stat --field-separator=,  -a -- sleep 1
4009.961740,task-clock-msecs
13,context-switches
2,CPU-migrations
189,page-faults
9596385684,cycles
3493659441,instructions
872897069,branches
41562,branch-misses
22424,cache-references
1289,cache-misses
Works also in non-aggregated mode:
$ perf stat -x ,  -a -A -- sleep 1
CPU0,1002.526168,task-clock-msecs
CPU1,1002.528365,task-clock-msecs
CPU2,1002.523360,task-clock-msecs
CPU3,1002.519878,task-clock-msecs
CPU0,1,context-switches
CPU1,5,context-switches
CPU2,5,context-switches
CPU3,6,context-switches
CPU0,0,CPU-migrations
CPU1,1,CPU-migrations
CPU2,0,CPU-migrations
CPU3,1,CPU-migrations
CPU0,2,page-faults
CPU1,6,page-faults
CPU2,9,page-faults
CPU3,174,page-faults
CPU0,2399439771,cycles
CPU1,2380369063,cycles
CPU2,2399142710,cycles
CPU3,2373161192,cycles
CPU0,872900618,instructions
CPU1,873030960,instructions
CPU2,872714525,instructions
CPU3,874460580,instructions
CPU0,221556839,branches
CPU1,218134342,branches
CPU2,218161730,branches
CPU3,218284093,branches
CPU0,18556,branch-misses
CPU1,1449,branch-misses
CPU2,3447,branch-misses
CPU3,12714,branch-misses
CPU0,8330,cache-references
CPU1,313844,cache-references
CPU2,47993728,cache-references
CPU3,826481,cache-references
CPU0,272,cache-misses
CPU1,5360,cache-misses
CPU2,1342193,cache-misses
CPU3,13992,cache-misses
This second version adds the ability to name a separator and uses
field-separator as the long option to be consistent with perf report.
Commiter note: Since we enabled --big-num by default in 201e0b0 and -x can't be
used with it, we need to notice if the user explicitely enabled or disabled -B,
add code to disable big_num if the user didn't explicitely set --big_num when
-x is used.
Cc: David S. Miller <davem@davemloft.net>
Cc: Frederik Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: paulus@samba.org
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Robert Richter <robert.richter@amd.com>
LKML-Reference: <4cf68aa7.0fedd80a.5294.1203@mx.google.com>
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2010-12-01 18:49:05 +02:00
										 |  |  | 			csv_output ? 0 : 18, | 
					
						
							| 
									
										
										
										
											2011-05-30 08:55:59 -06:00
										 |  |  | 			counter->supported ? CNTR_NOT_COUNTED : CNTR_NOT_SUPPORTED, | 
					
						
							| 
									
										
										
										
											2013-11-12 17:58:49 +01:00
										 |  |  | 			csv_sep); | 
					
						
							|  |  |  | 		fprintf(output, "%-*s%s", | 
					
						
							|  |  |  | 			csv_output ? 0 : unit_width, | 
					
						
							|  |  |  | 			counter->unit, csv_sep); | 
					
						
							|  |  |  | 		fprintf(output, "%*s", | 
					
						
							|  |  |  | 			csv_output ? 0 : -25, | 
					
						
							| 
									
										
										
										
											2012-06-12 12:34:58 -03:00
										 |  |  | 			perf_evsel__name(counter)); | 
					
						
							| 
									
										
										
											
												perf tool: Add cgroup support
This patch adds the ability to filter monitoring based on container groups
(cgroups) for both perf stat and perf record. It is possible to monitor
multiple cgroup in parallel. There is one cgroup per event. The cgroups to
monitor are passed via a new -G option followed by a comma separated list of
cgroup names.
The cgroup filesystem has to be mounted. Given a cgroup name, the perf tool
finds the corresponding directory in the cgroup filesystem and opens it. It
then passes that file descriptor to the kernel.
Example:
$ perf stat -B -a -e cycles:u,cycles:u,cycles:u -G test1,,test2 -- sleep 1
 Performance counter stats for 'sleep 1':
      2,368,667,414  cycles                   test1
      2,369,661,459  cycles
      <not counted>  cycles                   test2
        1.001856890  seconds time elapsed
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
LKML-Reference: <4d590290.825bdf0a.7d0a.4890@mx.google.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-02-14 11:20:01 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		if (counter->cgrp) | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 			fprintf(output, "%s%s", csv_sep, counter->cgrp->name); | 
					
						
							| 
									
										
										
											
												perf tool: Add cgroup support
This patch adds the ability to filter monitoring based on container groups
(cgroups) for both perf stat and perf record. It is possible to monitor
multiple cgroup in parallel. There is one cgroup per event. The cgroups to
monitor are passed via a new -G option followed by a comma separated list of
cgroup names.
The cgroup filesystem has to be mounted. Given a cgroup name, the perf tool
finds the corresponding directory in the cgroup filesystem and opens it. It
then passes that file descriptor to the kernel.
Example:
$ perf stat -B -a -e cycles:u,cycles:u,cycles:u -G test1,,test2 -- sleep 1
 Performance counter stats for 'sleep 1':
      2,368,667,414  cycles                   test1
      2,369,661,459  cycles
      <not counted>  cycles                   test2
        1.001856890  seconds time elapsed
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
LKML-Reference: <4d590290.825bdf0a.7d0a.4890@mx.google.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-02-14 11:20:01 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 		fputc('\n', output); | 
					
						
							| 
									
										
										
										
											2009-05-29 09:10:54 +02:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-05-29 09:10:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-12 17:58:49 +01:00
										 |  |  | 	uval = avg * counter->scale; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-13 13:35:00 +02:00
										 |  |  | 	if (nsec_counter(counter)) | 
					
						
							| 
									
										
										
										
											2013-11-12 17:58:49 +01:00
										 |  |  | 		nsec_printout(-1, 0, counter, uval); | 
					
						
							| 
									
										
										
										
											2009-06-13 13:35:00 +02:00
										 |  |  | 	else | 
					
						
							| 
									
										
										
										
											2013-11-12 17:58:49 +01:00
										 |  |  | 		abs_printout(-1, 0, counter, uval); | 
					
						
							| 
									
										
										
										
											2009-09-04 18:23:38 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												perf stat: Add noise output for csv mode
Previously, when you want perf-stat to output the statistics in
csv mode, no information of the noise will be printed out.
For example right now we output this --repeat information:
 ./perf stat -r3 -x, sleep 1
 1.164789,task-clock
 8,context-switches
 0,CPU-migrations
 219,page-faults
 3337800,cycles
With this patch, the output will be appended with an additional
entry for the noise value:
 ./perf stat -r3 -x, sleep 1
 1.164789,task-clock,3.75%
 8,context-switches,75.00%
 0,CPU-migrations,100.00%
 219,page-faults,0.00%
 3337800,cycles,3.36%
Signed-off-by: Zhengyu He <zhengyuh@google.com>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Arnaldo Carvalho de Melo <acme@ghostprotocols.net>
Cc: Stephane Eranian <eranian@google.com>
Cc: Venkatesh Pallipadi <venki@google.com>
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Link: http://lkml.kernel.org/r/1308861942-4945-1-git-send-email-zhengyuh@google.com
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-06-23 13:45:42 -07:00
										 |  |  | 	print_noise(counter, avg); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												perf stat: Add csv-style output
This patch adds an option (-x/--field-separator) to print counts using a
CSV-style output. The user can pass a custom separator. This makes it very easy
to import counts directly into your favorite spreadsheet without having to
write scripts.
Example:
$ perf stat --field-separator=,  -a -- sleep 1
4009.961740,task-clock-msecs
13,context-switches
2,CPU-migrations
189,page-faults
9596385684,cycles
3493659441,instructions
872897069,branches
41562,branch-misses
22424,cache-references
1289,cache-misses
Works also in non-aggregated mode:
$ perf stat -x ,  -a -A -- sleep 1
CPU0,1002.526168,task-clock-msecs
CPU1,1002.528365,task-clock-msecs
CPU2,1002.523360,task-clock-msecs
CPU3,1002.519878,task-clock-msecs
CPU0,1,context-switches
CPU1,5,context-switches
CPU2,5,context-switches
CPU3,6,context-switches
CPU0,0,CPU-migrations
CPU1,1,CPU-migrations
CPU2,0,CPU-migrations
CPU3,1,CPU-migrations
CPU0,2,page-faults
CPU1,6,page-faults
CPU2,9,page-faults
CPU3,174,page-faults
CPU0,2399439771,cycles
CPU1,2380369063,cycles
CPU2,2399142710,cycles
CPU3,2373161192,cycles
CPU0,872900618,instructions
CPU1,873030960,instructions
CPU2,872714525,instructions
CPU3,874460580,instructions
CPU0,221556839,branches
CPU1,218134342,branches
CPU2,218161730,branches
CPU3,218284093,branches
CPU0,18556,branch-misses
CPU1,1449,branch-misses
CPU2,3447,branch-misses
CPU3,12714,branch-misses
CPU0,8330,cache-references
CPU1,313844,cache-references
CPU2,47993728,cache-references
CPU3,826481,cache-references
CPU0,272,cache-misses
CPU1,5360,cache-misses
CPU2,1342193,cache-misses
CPU3,13992,cache-misses
This second version adds the ability to name a separator and uses
field-separator as the long option to be consistent with perf report.
Commiter note: Since we enabled --big-num by default in 201e0b0 and -x can't be
used with it, we need to notice if the user explicitely enabled or disabled -B,
add code to disable big_num if the user didn't explicitely set --big_num when
-x is used.
Cc: David S. Miller <davem@davemloft.net>
Cc: Frederik Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: paulus@samba.org
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Robert Richter <robert.richter@amd.com>
LKML-Reference: <4cf68aa7.0fedd80a.5294.1203@mx.google.com>
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2010-12-01 18:49:05 +02:00
										 |  |  | 	if (csv_output) { | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 		fputc('\n', output); | 
					
						
							| 
									
										
											  
											
												perf stat: Add csv-style output
This patch adds an option (-x/--field-separator) to print counts using a
CSV-style output. The user can pass a custom separator. This makes it very easy
to import counts directly into your favorite spreadsheet without having to
write scripts.
Example:
$ perf stat --field-separator=,  -a -- sleep 1
4009.961740,task-clock-msecs
13,context-switches
2,CPU-migrations
189,page-faults
9596385684,cycles
3493659441,instructions
872897069,branches
41562,branch-misses
22424,cache-references
1289,cache-misses
Works also in non-aggregated mode:
$ perf stat -x ,  -a -A -- sleep 1
CPU0,1002.526168,task-clock-msecs
CPU1,1002.528365,task-clock-msecs
CPU2,1002.523360,task-clock-msecs
CPU3,1002.519878,task-clock-msecs
CPU0,1,context-switches
CPU1,5,context-switches
CPU2,5,context-switches
CPU3,6,context-switches
CPU0,0,CPU-migrations
CPU1,1,CPU-migrations
CPU2,0,CPU-migrations
CPU3,1,CPU-migrations
CPU0,2,page-faults
CPU1,6,page-faults
CPU2,9,page-faults
CPU3,174,page-faults
CPU0,2399439771,cycles
CPU1,2380369063,cycles
CPU2,2399142710,cycles
CPU3,2373161192,cycles
CPU0,872900618,instructions
CPU1,873030960,instructions
CPU2,872714525,instructions
CPU3,874460580,instructions
CPU0,221556839,branches
CPU1,218134342,branches
CPU2,218161730,branches
CPU3,218284093,branches
CPU0,18556,branch-misses
CPU1,1449,branch-misses
CPU2,3447,branch-misses
CPU3,12714,branch-misses
CPU0,8330,cache-references
CPU1,313844,cache-references
CPU2,47993728,cache-references
CPU3,826481,cache-references
CPU0,272,cache-misses
CPU1,5360,cache-misses
CPU2,1342193,cache-misses
CPU3,13992,cache-misses
This second version adds the ability to name a separator and uses
field-separator as the long option to be consistent with perf report.
Commiter note: Since we enabled --big-num by default in 201e0b0 and -x can't be
used with it, we need to notice if the user explicitely enabled or disabled -B,
add code to disable big_num if the user didn't explicitely set --big_num when
-x is used.
Cc: David S. Miller <davem@davemloft.net>
Cc: Frederik Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: paulus@samba.org
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Robert Richter <robert.richter@amd.com>
LKML-Reference: <4cf68aa7.0fedd80a.5294.1203@mx.google.com>
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2010-12-01 18:49:05 +02:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-04 15:36:12 +02:00
										 |  |  | 	if (scaled) { | 
					
						
							|  |  |  | 		double avg_enabled, avg_running; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-01-03 16:39:04 -02:00
										 |  |  | 		avg_enabled = avg_stats(&ps->res_stats[1]); | 
					
						
							|  |  |  | 		avg_running = avg_stats(&ps->res_stats[2]); | 
					
						
							| 
									
										
										
										
											2009-05-30 12:38:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 		fprintf(output, " [%5.2f%%]", 100 * avg_running / avg_enabled); | 
					
						
							| 
									
										
										
										
											2009-09-04 15:36:12 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 	fprintf(output, "\n"); | 
					
						
							| 
									
										
										
										
											2009-05-29 09:10:54 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-16 11:05:01 +02:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * Print out the results of a single counter: | 
					
						
							|  |  |  |  * does not use aggregated count in system-wide | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												perf stat: Add interval printing
This patch adds a new printing mode for perf stat.  It allows interval
printing. That means perf stat can now print event deltas at regular
time interval.  This is useful to detect phases in programs.
The -I option enables interval printing. It expects an interval duration
in milliseconds. Minimum is 100ms. Once, activated perf stat prints
events deltas since last printout. All modes are supported.
$ perf stat -I 1000 -e cycles noploop 10
noploop for 10 seconds
 #           time             counts events
      1.000109853      2,388,560,546 cycles
      2.000262846      2,393,332,358 cycles
      3.000354131      2,393,176,537 cycles
      4.000439503      2,393,203,790 cycles
      5.000527075      2,393,167,675 cycles
      6.000609052      2,393,203,670 cycles
      7.000691082      2,393,175,678 cycles
The output format makes it easy to feed into a plotting program such as
gnuplot when the -I option is used in combination with the -x option:
$ perf stat -x, -I 1000 -e cycles noploop 10
noploop for 10 seconds
1.000084113,2378775498,cycles
2.000245798,2391056897,cycles
3.000354445,2392089414,cycles
4.000459115,2390936603,cycles
5.000565341,2392108173,cycles
Signed-off-by: Stephane Eranian <eranian@google.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1359460064-3060-3-git-send-email-eranian@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2013-01-29 12:47:44 +01:00
										 |  |  | static void print_counter(struct perf_evsel *counter, char *prefix) | 
					
						
							| 
									
										
										
										
											2010-11-16 11:05:01 +02:00
										 |  |  | { | 
					
						
							|  |  |  | 	u64 ena, run, val; | 
					
						
							| 
									
										
										
										
											2013-11-12 17:58:49 +01:00
										 |  |  | 	double uval; | 
					
						
							| 
									
										
										
										
											2010-11-16 11:05:01 +02:00
										 |  |  | 	int cpu; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-10 15:53:50 +08:00
										 |  |  | 	for (cpu = 0; cpu < perf_evsel__nr_cpus(counter); cpu++) { | 
					
						
							| 
									
										
										
										
											2011-01-03 17:45:52 -02:00
										 |  |  | 		val = counter->counts->cpu[cpu].val; | 
					
						
							|  |  |  | 		ena = counter->counts->cpu[cpu].ena; | 
					
						
							|  |  |  | 		run = counter->counts->cpu[cpu].run; | 
					
						
							| 
									
										
											  
											
												perf stat: Add interval printing
This patch adds a new printing mode for perf stat.  It allows interval
printing. That means perf stat can now print event deltas at regular
time interval.  This is useful to detect phases in programs.
The -I option enables interval printing. It expects an interval duration
in milliseconds. Minimum is 100ms. Once, activated perf stat prints
events deltas since last printout. All modes are supported.
$ perf stat -I 1000 -e cycles noploop 10
noploop for 10 seconds
 #           time             counts events
      1.000109853      2,388,560,546 cycles
      2.000262846      2,393,332,358 cycles
      3.000354131      2,393,176,537 cycles
      4.000439503      2,393,203,790 cycles
      5.000527075      2,393,167,675 cycles
      6.000609052      2,393,203,670 cycles
      7.000691082      2,393,175,678 cycles
The output format makes it easy to feed into a plotting program such as
gnuplot when the -I option is used in combination with the -x option:
$ perf stat -x, -I 1000 -e cycles noploop 10
noploop for 10 seconds
1.000084113,2378775498,cycles
2.000245798,2391056897,cycles
3.000354445,2392089414,cycles
4.000459115,2390936603,cycles
5.000565341,2392108173,cycles
Signed-off-by: Stephane Eranian <eranian@google.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1359460064-3060-3-git-send-email-eranian@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2013-01-29 12:47:44 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		if (prefix) | 
					
						
							|  |  |  | 			fprintf(output, "%s", prefix); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-16 11:05:01 +02:00
										 |  |  | 		if (run == 0 || ena == 0) { | 
					
						
							| 
									
										
										
										
											2013-11-12 17:58:49 +01:00
										 |  |  | 			fprintf(output, "CPU%*d%s%*s%s", | 
					
						
							| 
									
										
											  
											
												perf stat: Add csv-style output
This patch adds an option (-x/--field-separator) to print counts using a
CSV-style output. The user can pass a custom separator. This makes it very easy
to import counts directly into your favorite spreadsheet without having to
write scripts.
Example:
$ perf stat --field-separator=,  -a -- sleep 1
4009.961740,task-clock-msecs
13,context-switches
2,CPU-migrations
189,page-faults
9596385684,cycles
3493659441,instructions
872897069,branches
41562,branch-misses
22424,cache-references
1289,cache-misses
Works also in non-aggregated mode:
$ perf stat -x ,  -a -A -- sleep 1
CPU0,1002.526168,task-clock-msecs
CPU1,1002.528365,task-clock-msecs
CPU2,1002.523360,task-clock-msecs
CPU3,1002.519878,task-clock-msecs
CPU0,1,context-switches
CPU1,5,context-switches
CPU2,5,context-switches
CPU3,6,context-switches
CPU0,0,CPU-migrations
CPU1,1,CPU-migrations
CPU2,0,CPU-migrations
CPU3,1,CPU-migrations
CPU0,2,page-faults
CPU1,6,page-faults
CPU2,9,page-faults
CPU3,174,page-faults
CPU0,2399439771,cycles
CPU1,2380369063,cycles
CPU2,2399142710,cycles
CPU3,2373161192,cycles
CPU0,872900618,instructions
CPU1,873030960,instructions
CPU2,872714525,instructions
CPU3,874460580,instructions
CPU0,221556839,branches
CPU1,218134342,branches
CPU2,218161730,branches
CPU3,218284093,branches
CPU0,18556,branch-misses
CPU1,1449,branch-misses
CPU2,3447,branch-misses
CPU3,12714,branch-misses
CPU0,8330,cache-references
CPU1,313844,cache-references
CPU2,47993728,cache-references
CPU3,826481,cache-references
CPU0,272,cache-misses
CPU1,5360,cache-misses
CPU2,1342193,cache-misses
CPU3,13992,cache-misses
This second version adds the ability to name a separator and uses
field-separator as the long option to be consistent with perf report.
Commiter note: Since we enabled --big-num by default in 201e0b0 and -x can't be
used with it, we need to notice if the user explicitely enabled or disabled -B,
add code to disable big_num if the user didn't explicitely set --big_num when
-x is used.
Cc: David S. Miller <davem@davemloft.net>
Cc: Frederik Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: paulus@samba.org
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Robert Richter <robert.richter@amd.com>
LKML-Reference: <4cf68aa7.0fedd80a.5294.1203@mx.google.com>
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2010-12-01 18:49:05 +02:00
										 |  |  | 				csv_output ? 0 : -4, | 
					
						
							| 
									
										
										
										
											2012-09-10 15:53:50 +08:00
										 |  |  | 				perf_evsel__cpus(counter)->map[cpu], csv_sep, | 
					
						
							| 
									
										
											  
											
												perf stat: Add csv-style output
This patch adds an option (-x/--field-separator) to print counts using a
CSV-style output. The user can pass a custom separator. This makes it very easy
to import counts directly into your favorite spreadsheet without having to
write scripts.
Example:
$ perf stat --field-separator=,  -a -- sleep 1
4009.961740,task-clock-msecs
13,context-switches
2,CPU-migrations
189,page-faults
9596385684,cycles
3493659441,instructions
872897069,branches
41562,branch-misses
22424,cache-references
1289,cache-misses
Works also in non-aggregated mode:
$ perf stat -x ,  -a -A -- sleep 1
CPU0,1002.526168,task-clock-msecs
CPU1,1002.528365,task-clock-msecs
CPU2,1002.523360,task-clock-msecs
CPU3,1002.519878,task-clock-msecs
CPU0,1,context-switches
CPU1,5,context-switches
CPU2,5,context-switches
CPU3,6,context-switches
CPU0,0,CPU-migrations
CPU1,1,CPU-migrations
CPU2,0,CPU-migrations
CPU3,1,CPU-migrations
CPU0,2,page-faults
CPU1,6,page-faults
CPU2,9,page-faults
CPU3,174,page-faults
CPU0,2399439771,cycles
CPU1,2380369063,cycles
CPU2,2399142710,cycles
CPU3,2373161192,cycles
CPU0,872900618,instructions
CPU1,873030960,instructions
CPU2,872714525,instructions
CPU3,874460580,instructions
CPU0,221556839,branches
CPU1,218134342,branches
CPU2,218161730,branches
CPU3,218284093,branches
CPU0,18556,branch-misses
CPU1,1449,branch-misses
CPU2,3447,branch-misses
CPU3,12714,branch-misses
CPU0,8330,cache-references
CPU1,313844,cache-references
CPU2,47993728,cache-references
CPU3,826481,cache-references
CPU0,272,cache-misses
CPU1,5360,cache-misses
CPU2,1342193,cache-misses
CPU3,13992,cache-misses
This second version adds the ability to name a separator and uses
field-separator as the long option to be consistent with perf report.
Commiter note: Since we enabled --big-num by default in 201e0b0 and -x can't be
used with it, we need to notice if the user explicitely enabled or disabled -B,
add code to disable big_num if the user didn't explicitely set --big_num when
-x is used.
Cc: David S. Miller <davem@davemloft.net>
Cc: Frederik Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: paulus@samba.org
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Robert Richter <robert.richter@amd.com>
LKML-Reference: <4cf68aa7.0fedd80a.5294.1203@mx.google.com>
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2010-12-01 18:49:05 +02:00
										 |  |  | 				csv_output ? 0 : 18, | 
					
						
							| 
									
										
										
										
											2011-05-30 08:55:59 -06:00
										 |  |  | 				counter->supported ? CNTR_NOT_COUNTED : CNTR_NOT_SUPPORTED, | 
					
						
							| 
									
										
										
										
											2013-11-12 17:58:49 +01:00
										 |  |  | 				csv_sep); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				fprintf(output, "%-*s%s", | 
					
						
							|  |  |  | 					csv_output ? 0 : unit_width, | 
					
						
							|  |  |  | 					counter->unit, csv_sep); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				fprintf(output, "%*s", | 
					
						
							|  |  |  | 					csv_output ? 0 : -25, | 
					
						
							|  |  |  | 					perf_evsel__name(counter)); | 
					
						
							| 
									
										
										
										
											2010-11-16 11:05:01 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
											
												perf tool: Add cgroup support
This patch adds the ability to filter monitoring based on container groups
(cgroups) for both perf stat and perf record. It is possible to monitor
multiple cgroup in parallel. There is one cgroup per event. The cgroups to
monitor are passed via a new -G option followed by a comma separated list of
cgroup names.
The cgroup filesystem has to be mounted. Given a cgroup name, the perf tool
finds the corresponding directory in the cgroup filesystem and opens it. It
then passes that file descriptor to the kernel.
Example:
$ perf stat -B -a -e cycles:u,cycles:u,cycles:u -G test1,,test2 -- sleep 1
 Performance counter stats for 'sleep 1':
      2,368,667,414  cycles                   test1
      2,369,661,459  cycles
      <not counted>  cycles                   test2
        1.001856890  seconds time elapsed
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
LKML-Reference: <4d590290.825bdf0a.7d0a.4890@mx.google.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-02-14 11:20:01 +02:00
										 |  |  | 			if (counter->cgrp) | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 				fprintf(output, "%s%s", | 
					
						
							|  |  |  | 					csv_sep, counter->cgrp->name); | 
					
						
							| 
									
										
										
											
												perf tool: Add cgroup support
This patch adds the ability to filter monitoring based on container groups
(cgroups) for both perf stat and perf record. It is possible to monitor
multiple cgroup in parallel. There is one cgroup per event. The cgroups to
monitor are passed via a new -G option followed by a comma separated list of
cgroup names.
The cgroup filesystem has to be mounted. Given a cgroup name, the perf tool
finds the corresponding directory in the cgroup filesystem and opens it. It
then passes that file descriptor to the kernel.
Example:
$ perf stat -B -a -e cycles:u,cycles:u,cycles:u -G test1,,test2 -- sleep 1
 Performance counter stats for 'sleep 1':
      2,368,667,414  cycles                   test1
      2,369,661,459  cycles
      <not counted>  cycles                   test2
        1.001856890  seconds time elapsed
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
LKML-Reference: <4d590290.825bdf0a.7d0a.4890@mx.google.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-02-14 11:20:01 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 			fputc('\n', output); | 
					
						
							| 
									
										
										
										
											2010-11-16 11:05:01 +02:00
										 |  |  | 			continue; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-12 17:58:49 +01:00
										 |  |  | 		uval = val * counter->scale; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-16 11:05:01 +02:00
										 |  |  | 		if (nsec_counter(counter)) | 
					
						
							| 
									
										
										
										
											2013-11-12 17:58:49 +01:00
										 |  |  | 			nsec_printout(cpu, 0, counter, uval); | 
					
						
							| 
									
										
										
										
											2010-11-16 11:05:01 +02:00
										 |  |  | 		else | 
					
						
							| 
									
										
										
										
											2013-11-12 17:58:49 +01:00
										 |  |  | 			abs_printout(cpu, 0, counter, uval); | 
					
						
							| 
									
										
										
										
											2010-11-16 11:05:01 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												perf stat: Add csv-style output
This patch adds an option (-x/--field-separator) to print counts using a
CSV-style output. The user can pass a custom separator. This makes it very easy
to import counts directly into your favorite spreadsheet without having to
write scripts.
Example:
$ perf stat --field-separator=,  -a -- sleep 1
4009.961740,task-clock-msecs
13,context-switches
2,CPU-migrations
189,page-faults
9596385684,cycles
3493659441,instructions
872897069,branches
41562,branch-misses
22424,cache-references
1289,cache-misses
Works also in non-aggregated mode:
$ perf stat -x ,  -a -A -- sleep 1
CPU0,1002.526168,task-clock-msecs
CPU1,1002.528365,task-clock-msecs
CPU2,1002.523360,task-clock-msecs
CPU3,1002.519878,task-clock-msecs
CPU0,1,context-switches
CPU1,5,context-switches
CPU2,5,context-switches
CPU3,6,context-switches
CPU0,0,CPU-migrations
CPU1,1,CPU-migrations
CPU2,0,CPU-migrations
CPU3,1,CPU-migrations
CPU0,2,page-faults
CPU1,6,page-faults
CPU2,9,page-faults
CPU3,174,page-faults
CPU0,2399439771,cycles
CPU1,2380369063,cycles
CPU2,2399142710,cycles
CPU3,2373161192,cycles
CPU0,872900618,instructions
CPU1,873030960,instructions
CPU2,872714525,instructions
CPU3,874460580,instructions
CPU0,221556839,branches
CPU1,218134342,branches
CPU2,218161730,branches
CPU3,218284093,branches
CPU0,18556,branch-misses
CPU1,1449,branch-misses
CPU2,3447,branch-misses
CPU3,12714,branch-misses
CPU0,8330,cache-references
CPU1,313844,cache-references
CPU2,47993728,cache-references
CPU3,826481,cache-references
CPU0,272,cache-misses
CPU1,5360,cache-misses
CPU2,1342193,cache-misses
CPU3,13992,cache-misses
This second version adds the ability to name a separator and uses
field-separator as the long option to be consistent with perf report.
Commiter note: Since we enabled --big-num by default in 201e0b0 and -x can't be
used with it, we need to notice if the user explicitely enabled or disabled -B,
add code to disable big_num if the user didn't explicitely set --big_num when
-x is used.
Cc: David S. Miller <davem@davemloft.net>
Cc: Frederik Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: paulus@samba.org
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Robert Richter <robert.richter@amd.com>
LKML-Reference: <4cf68aa7.0fedd80a.5294.1203@mx.google.com>
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2010-12-01 18:49:05 +02:00
										 |  |  | 		if (!csv_output) { | 
					
						
							|  |  |  | 			print_noise(counter, 1.0); | 
					
						
							| 
									
										
										
										
											2010-11-16 11:05:01 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												perf stat: Add -d/--detailed flag to run with a lot of events
Add the new -d/--detailed flag, which generates a pretty detailed event list:
 Performance counter stats for './hackbench 10' (10 runs):
       1514.287888 task-clock               #   10.897 CPUs utilized            ( +-  3.05% )
            39,698 context-switches         #    0.026 M/sec                    ( +- 12.19% )
             8,147 CPU-migrations           #    0.005 M/sec                    ( +- 16.55% )
            17,918 page-faults              #    0.012 M/sec                    ( +-  0.37% )
     2,944,504,050 cycles                   #    1.944 GHz                      ( +-  3.89% )  (32.60%)
     1,043,971,283 stalled-cycles           #   35.45% of all cycles are idle   ( +-  5.22% )  (44.48%)
     1,655,906,768 instructions             #    0.56  insns per cycle
                                            #    0.63  stalled cycles per insn  ( +-  1.95% )  (55.09%)
       338,832,373 branches                 #  223.757 M/sec                    ( +-  1.96% )  (64.47%)
         3,892,416 branch-misses            #    1.15% of all branches          ( +-  5.49% )  (73.12%)
       606,410,482 L1-dcache-loads          #  400.459 M/sec                    ( +-  1.29% )  (71.21%)
        31,204,395 L1-dcache-load-misses    #    5.15% of all L1-dcache hits    ( +-  3.04% )  (60.43%)
         3,922,751 LLC-loads                #    2.590 M/sec                    ( +-  6.80% )  (46.87%)
         5,037,288 LLC-load-misses          #    3.327 M/sec                    ( +-  3.56% )  (13.00%)
        0.138966828  seconds time elapsed  ( +-  4.11% )
This can be used "at a glance" for narrower analysis.
-d can also be used in addition to other -e events, to further expand an event list.
Acked-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
Acked-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Link: http://lkml.kernel.org/n/tip-cxs98quixs3qyvdqx3goojc4@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-04-27 13:50:47 +02:00
										 |  |  | 			if (run != ena) | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 				fprintf(output, "  (%.2f%%)", | 
					
						
							|  |  |  | 					100.0 * run / ena); | 
					
						
							| 
									
										
										
										
											2010-11-16 11:05:01 +02:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 		fputc('\n', output); | 
					
						
							| 
									
										
										
										
											2010-11-16 11:05:01 +02:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-13 14:57:28 +02:00
										 |  |  | static void print_stat(int argc, const char **argv) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2011-01-03 16:39:04 -02:00
										 |  |  | 	struct perf_evsel *counter; | 
					
						
							|  |  |  | 	int i; | 
					
						
							| 
									
										
										
										
											2009-06-13 14:57:28 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-20 15:37:32 +02:00
										 |  |  | 	fflush(stdout); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												perf stat: Add csv-style output
This patch adds an option (-x/--field-separator) to print counts using a
CSV-style output. The user can pass a custom separator. This makes it very easy
to import counts directly into your favorite spreadsheet without having to
write scripts.
Example:
$ perf stat --field-separator=,  -a -- sleep 1
4009.961740,task-clock-msecs
13,context-switches
2,CPU-migrations
189,page-faults
9596385684,cycles
3493659441,instructions
872897069,branches
41562,branch-misses
22424,cache-references
1289,cache-misses
Works also in non-aggregated mode:
$ perf stat -x ,  -a -A -- sleep 1
CPU0,1002.526168,task-clock-msecs
CPU1,1002.528365,task-clock-msecs
CPU2,1002.523360,task-clock-msecs
CPU3,1002.519878,task-clock-msecs
CPU0,1,context-switches
CPU1,5,context-switches
CPU2,5,context-switches
CPU3,6,context-switches
CPU0,0,CPU-migrations
CPU1,1,CPU-migrations
CPU2,0,CPU-migrations
CPU3,1,CPU-migrations
CPU0,2,page-faults
CPU1,6,page-faults
CPU2,9,page-faults
CPU3,174,page-faults
CPU0,2399439771,cycles
CPU1,2380369063,cycles
CPU2,2399142710,cycles
CPU3,2373161192,cycles
CPU0,872900618,instructions
CPU1,873030960,instructions
CPU2,872714525,instructions
CPU3,874460580,instructions
CPU0,221556839,branches
CPU1,218134342,branches
CPU2,218161730,branches
CPU3,218284093,branches
CPU0,18556,branch-misses
CPU1,1449,branch-misses
CPU2,3447,branch-misses
CPU3,12714,branch-misses
CPU0,8330,cache-references
CPU1,313844,cache-references
CPU2,47993728,cache-references
CPU3,826481,cache-references
CPU0,272,cache-misses
CPU1,5360,cache-misses
CPU2,1342193,cache-misses
CPU3,13992,cache-misses
This second version adds the ability to name a separator and uses
field-separator as the long option to be consistent with perf report.
Commiter note: Since we enabled --big-num by default in 201e0b0 and -x can't be
used with it, we need to notice if the user explicitely enabled or disabled -B,
add code to disable big_num if the user didn't explicitely set --big_num when
-x is used.
Cc: David S. Miller <davem@davemloft.net>
Cc: Frederik Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: paulus@samba.org
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Robert Richter <robert.richter@amd.com>
LKML-Reference: <4cf68aa7.0fedd80a.5294.1203@mx.google.com>
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2010-12-01 18:49:05 +02:00
										 |  |  | 	if (!csv_output) { | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 		fprintf(output, "\n"); | 
					
						
							|  |  |  | 		fprintf(output, " Performance counter stats for "); | 
					
						
							| 
									
										
										
										
											2013-09-28 14:27:58 -06:00
										 |  |  | 		if (target.system_wide) | 
					
						
							|  |  |  | 			fprintf(output, "\'system wide"); | 
					
						
							|  |  |  | 		else if (target.cpu_list) | 
					
						
							|  |  |  | 			fprintf(output, "\'CPU(s) %s", target.cpu_list); | 
					
						
							| 
									
										
										
										
											2013-11-12 16:46:16 -03:00
										 |  |  | 		else if (!target__has_task(&target)) { | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 			fprintf(output, "\'%s", argv[0]); | 
					
						
							| 
									
										
											  
											
												perf stat: Add csv-style output
This patch adds an option (-x/--field-separator) to print counts using a
CSV-style output. The user can pass a custom separator. This makes it very easy
to import counts directly into your favorite spreadsheet without having to
write scripts.
Example:
$ perf stat --field-separator=,  -a -- sleep 1
4009.961740,task-clock-msecs
13,context-switches
2,CPU-migrations
189,page-faults
9596385684,cycles
3493659441,instructions
872897069,branches
41562,branch-misses
22424,cache-references
1289,cache-misses
Works also in non-aggregated mode:
$ perf stat -x ,  -a -A -- sleep 1
CPU0,1002.526168,task-clock-msecs
CPU1,1002.528365,task-clock-msecs
CPU2,1002.523360,task-clock-msecs
CPU3,1002.519878,task-clock-msecs
CPU0,1,context-switches
CPU1,5,context-switches
CPU2,5,context-switches
CPU3,6,context-switches
CPU0,0,CPU-migrations
CPU1,1,CPU-migrations
CPU2,0,CPU-migrations
CPU3,1,CPU-migrations
CPU0,2,page-faults
CPU1,6,page-faults
CPU2,9,page-faults
CPU3,174,page-faults
CPU0,2399439771,cycles
CPU1,2380369063,cycles
CPU2,2399142710,cycles
CPU3,2373161192,cycles
CPU0,872900618,instructions
CPU1,873030960,instructions
CPU2,872714525,instructions
CPU3,874460580,instructions
CPU0,221556839,branches
CPU1,218134342,branches
CPU2,218161730,branches
CPU3,218284093,branches
CPU0,18556,branch-misses
CPU1,1449,branch-misses
CPU2,3447,branch-misses
CPU3,12714,branch-misses
CPU0,8330,cache-references
CPU1,313844,cache-references
CPU2,47993728,cache-references
CPU3,826481,cache-references
CPU0,272,cache-misses
CPU1,5360,cache-misses
CPU2,1342193,cache-misses
CPU3,13992,cache-misses
This second version adds the ability to name a separator and uses
field-separator as the long option to be consistent with perf report.
Commiter note: Since we enabled --big-num by default in 201e0b0 and -x can't be
used with it, we need to notice if the user explicitely enabled or disabled -B,
add code to disable big_num if the user didn't explicitely set --big_num when
-x is used.
Cc: David S. Miller <davem@davemloft.net>
Cc: Frederik Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: paulus@samba.org
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Robert Richter <robert.richter@amd.com>
LKML-Reference: <4cf68aa7.0fedd80a.5294.1203@mx.google.com>
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2010-12-01 18:49:05 +02:00
										 |  |  | 			for (i = 1; i < argc; i++) | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 				fprintf(output, " %s", argv[i]); | 
					
						
							| 
									
										
										
										
											2012-04-26 14:15:16 +09:00
										 |  |  | 		} else if (target.pid) | 
					
						
							|  |  |  | 			fprintf(output, "process id \'%s", target.pid); | 
					
						
							| 
									
										
											  
											
												perf stat: Add csv-style output
This patch adds an option (-x/--field-separator) to print counts using a
CSV-style output. The user can pass a custom separator. This makes it very easy
to import counts directly into your favorite spreadsheet without having to
write scripts.
Example:
$ perf stat --field-separator=,  -a -- sleep 1
4009.961740,task-clock-msecs
13,context-switches
2,CPU-migrations
189,page-faults
9596385684,cycles
3493659441,instructions
872897069,branches
41562,branch-misses
22424,cache-references
1289,cache-misses
Works also in non-aggregated mode:
$ perf stat -x ,  -a -A -- sleep 1
CPU0,1002.526168,task-clock-msecs
CPU1,1002.528365,task-clock-msecs
CPU2,1002.523360,task-clock-msecs
CPU3,1002.519878,task-clock-msecs
CPU0,1,context-switches
CPU1,5,context-switches
CPU2,5,context-switches
CPU3,6,context-switches
CPU0,0,CPU-migrations
CPU1,1,CPU-migrations
CPU2,0,CPU-migrations
CPU3,1,CPU-migrations
CPU0,2,page-faults
CPU1,6,page-faults
CPU2,9,page-faults
CPU3,174,page-faults
CPU0,2399439771,cycles
CPU1,2380369063,cycles
CPU2,2399142710,cycles
CPU3,2373161192,cycles
CPU0,872900618,instructions
CPU1,873030960,instructions
CPU2,872714525,instructions
CPU3,874460580,instructions
CPU0,221556839,branches
CPU1,218134342,branches
CPU2,218161730,branches
CPU3,218284093,branches
CPU0,18556,branch-misses
CPU1,1449,branch-misses
CPU2,3447,branch-misses
CPU3,12714,branch-misses
CPU0,8330,cache-references
CPU1,313844,cache-references
CPU2,47993728,cache-references
CPU3,826481,cache-references
CPU0,272,cache-misses
CPU1,5360,cache-misses
CPU2,1342193,cache-misses
CPU3,13992,cache-misses
This second version adds the ability to name a separator and uses
field-separator as the long option to be consistent with perf report.
Commiter note: Since we enabled --big-num by default in 201e0b0 and -x can't be
used with it, we need to notice if the user explicitely enabled or disabled -B,
add code to disable big_num if the user didn't explicitely set --big_num when
-x is used.
Cc: David S. Miller <davem@davemloft.net>
Cc: Frederik Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: paulus@samba.org
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Robert Richter <robert.richter@amd.com>
LKML-Reference: <4cf68aa7.0fedd80a.5294.1203@mx.google.com>
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2010-12-01 18:49:05 +02:00
										 |  |  | 		else | 
					
						
							| 
									
										
										
										
											2012-04-26 14:15:16 +09:00
										 |  |  | 			fprintf(output, "thread id \'%s", target.tid); | 
					
						
							| 
									
										
										
										
											2009-06-03 19:36:07 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 		fprintf(output, "\'"); | 
					
						
							| 
									
										
											  
											
												perf stat: Add csv-style output
This patch adds an option (-x/--field-separator) to print counts using a
CSV-style output. The user can pass a custom separator. This makes it very easy
to import counts directly into your favorite spreadsheet without having to
write scripts.
Example:
$ perf stat --field-separator=,  -a -- sleep 1
4009.961740,task-clock-msecs
13,context-switches
2,CPU-migrations
189,page-faults
9596385684,cycles
3493659441,instructions
872897069,branches
41562,branch-misses
22424,cache-references
1289,cache-misses
Works also in non-aggregated mode:
$ perf stat -x ,  -a -A -- sleep 1
CPU0,1002.526168,task-clock-msecs
CPU1,1002.528365,task-clock-msecs
CPU2,1002.523360,task-clock-msecs
CPU3,1002.519878,task-clock-msecs
CPU0,1,context-switches
CPU1,5,context-switches
CPU2,5,context-switches
CPU3,6,context-switches
CPU0,0,CPU-migrations
CPU1,1,CPU-migrations
CPU2,0,CPU-migrations
CPU3,1,CPU-migrations
CPU0,2,page-faults
CPU1,6,page-faults
CPU2,9,page-faults
CPU3,174,page-faults
CPU0,2399439771,cycles
CPU1,2380369063,cycles
CPU2,2399142710,cycles
CPU3,2373161192,cycles
CPU0,872900618,instructions
CPU1,873030960,instructions
CPU2,872714525,instructions
CPU3,874460580,instructions
CPU0,221556839,branches
CPU1,218134342,branches
CPU2,218161730,branches
CPU3,218284093,branches
CPU0,18556,branch-misses
CPU1,1449,branch-misses
CPU2,3447,branch-misses
CPU3,12714,branch-misses
CPU0,8330,cache-references
CPU1,313844,cache-references
CPU2,47993728,cache-references
CPU3,826481,cache-references
CPU0,272,cache-misses
CPU1,5360,cache-misses
CPU2,1342193,cache-misses
CPU3,13992,cache-misses
This second version adds the ability to name a separator and uses
field-separator as the long option to be consistent with perf report.
Commiter note: Since we enabled --big-num by default in 201e0b0 and -x can't be
used with it, we need to notice if the user explicitely enabled or disabled -B,
add code to disable big_num if the user didn't explicitely set --big_num when
-x is used.
Cc: David S. Miller <davem@davemloft.net>
Cc: Frederik Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: paulus@samba.org
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Robert Richter <robert.richter@amd.com>
LKML-Reference: <4cf68aa7.0fedd80a.5294.1203@mx.google.com>
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2010-12-01 18:49:05 +02:00
										 |  |  | 		if (run_count > 1) | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 			fprintf(output, " (%d runs)", run_count); | 
					
						
							|  |  |  | 		fprintf(output, ":\n\n"); | 
					
						
							| 
									
										
											  
											
												perf stat: Add csv-style output
This patch adds an option (-x/--field-separator) to print counts using a
CSV-style output. The user can pass a custom separator. This makes it very easy
to import counts directly into your favorite spreadsheet without having to
write scripts.
Example:
$ perf stat --field-separator=,  -a -- sleep 1
4009.961740,task-clock-msecs
13,context-switches
2,CPU-migrations
189,page-faults
9596385684,cycles
3493659441,instructions
872897069,branches
41562,branch-misses
22424,cache-references
1289,cache-misses
Works also in non-aggregated mode:
$ perf stat -x ,  -a -A -- sleep 1
CPU0,1002.526168,task-clock-msecs
CPU1,1002.528365,task-clock-msecs
CPU2,1002.523360,task-clock-msecs
CPU3,1002.519878,task-clock-msecs
CPU0,1,context-switches
CPU1,5,context-switches
CPU2,5,context-switches
CPU3,6,context-switches
CPU0,0,CPU-migrations
CPU1,1,CPU-migrations
CPU2,0,CPU-migrations
CPU3,1,CPU-migrations
CPU0,2,page-faults
CPU1,6,page-faults
CPU2,9,page-faults
CPU3,174,page-faults
CPU0,2399439771,cycles
CPU1,2380369063,cycles
CPU2,2399142710,cycles
CPU3,2373161192,cycles
CPU0,872900618,instructions
CPU1,873030960,instructions
CPU2,872714525,instructions
CPU3,874460580,instructions
CPU0,221556839,branches
CPU1,218134342,branches
CPU2,218161730,branches
CPU3,218284093,branches
CPU0,18556,branch-misses
CPU1,1449,branch-misses
CPU2,3447,branch-misses
CPU3,12714,branch-misses
CPU0,8330,cache-references
CPU1,313844,cache-references
CPU2,47993728,cache-references
CPU3,826481,cache-references
CPU0,272,cache-misses
CPU1,5360,cache-misses
CPU2,1342193,cache-misses
CPU3,13992,cache-misses
This second version adds the ability to name a separator and uses
field-separator as the long option to be consistent with perf report.
Commiter note: Since we enabled --big-num by default in 201e0b0 and -x can't be
used with it, we need to notice if the user explicitely enabled or disabled -B,
add code to disable big_num if the user didn't explicitely set --big_num when
-x is used.
Cc: David S. Miller <davem@davemloft.net>
Cc: Frederik Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: paulus@samba.org
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Robert Richter <robert.richter@amd.com>
LKML-Reference: <4cf68aa7.0fedd80a.5294.1203@mx.google.com>
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2010-12-01 18:49:05 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-05-29 09:10:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 	switch (aggr_mode) { | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:29 +01:00
										 |  |  | 	case AGGR_CORE: | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 	case AGGR_SOCKET: | 
					
						
							|  |  |  | 		print_aggr(NULL); | 
					
						
							|  |  |  | 		break; | 
					
						
							|  |  |  | 	case AGGR_GLOBAL: | 
					
						
							| 
									
										
										
										
											2014-01-10 10:37:27 -03:00
										 |  |  | 		evlist__for_each(evsel_list, counter) | 
					
						
							| 
									
										
											  
											
												perf stat: Add interval printing
This patch adds a new printing mode for perf stat.  It allows interval
printing. That means perf stat can now print event deltas at regular
time interval.  This is useful to detect phases in programs.
The -I option enables interval printing. It expects an interval duration
in milliseconds. Minimum is 100ms. Once, activated perf stat prints
events deltas since last printout. All modes are supported.
$ perf stat -I 1000 -e cycles noploop 10
noploop for 10 seconds
 #           time             counts events
      1.000109853      2,388,560,546 cycles
      2.000262846      2,393,332,358 cycles
      3.000354131      2,393,176,537 cycles
      4.000439503      2,393,203,790 cycles
      5.000527075      2,393,167,675 cycles
      6.000609052      2,393,203,670 cycles
      7.000691082      2,393,175,678 cycles
The output format makes it easy to feed into a plotting program such as
gnuplot when the -I option is used in combination with the -x option:
$ perf stat -x, -I 1000 -e cycles noploop 10
noploop for 10 seconds
1.000084113,2378775498,cycles
2.000245798,2391056897,cycles
3.000354445,2392089414,cycles
4.000459115,2390936603,cycles
5.000565341,2392108173,cycles
Signed-off-by: Stephane Eranian <eranian@google.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1359460064-3060-3-git-send-email-eranian@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2013-01-29 12:47:44 +01:00
										 |  |  | 			print_counter_aggr(counter, NULL); | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 		break; | 
					
						
							|  |  |  | 	case AGGR_NONE: | 
					
						
							| 
									
										
										
										
											2014-01-10 10:37:27 -03:00
										 |  |  | 		evlist__for_each(evsel_list, counter) | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 			print_counter(counter, NULL); | 
					
						
							|  |  |  | 		break; | 
					
						
							|  |  |  | 	default: | 
					
						
							|  |  |  | 		break; | 
					
						
							| 
									
										
										
										
											2010-11-16 11:05:01 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-04-20 15:37:32 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												perf stat: Add csv-style output
This patch adds an option (-x/--field-separator) to print counts using a
CSV-style output. The user can pass a custom separator. This makes it very easy
to import counts directly into your favorite spreadsheet without having to
write scripts.
Example:
$ perf stat --field-separator=,  -a -- sleep 1
4009.961740,task-clock-msecs
13,context-switches
2,CPU-migrations
189,page-faults
9596385684,cycles
3493659441,instructions
872897069,branches
41562,branch-misses
22424,cache-references
1289,cache-misses
Works also in non-aggregated mode:
$ perf stat -x ,  -a -A -- sleep 1
CPU0,1002.526168,task-clock-msecs
CPU1,1002.528365,task-clock-msecs
CPU2,1002.523360,task-clock-msecs
CPU3,1002.519878,task-clock-msecs
CPU0,1,context-switches
CPU1,5,context-switches
CPU2,5,context-switches
CPU3,6,context-switches
CPU0,0,CPU-migrations
CPU1,1,CPU-migrations
CPU2,0,CPU-migrations
CPU3,1,CPU-migrations
CPU0,2,page-faults
CPU1,6,page-faults
CPU2,9,page-faults
CPU3,174,page-faults
CPU0,2399439771,cycles
CPU1,2380369063,cycles
CPU2,2399142710,cycles
CPU3,2373161192,cycles
CPU0,872900618,instructions
CPU1,873030960,instructions
CPU2,872714525,instructions
CPU3,874460580,instructions
CPU0,221556839,branches
CPU1,218134342,branches
CPU2,218161730,branches
CPU3,218284093,branches
CPU0,18556,branch-misses
CPU1,1449,branch-misses
CPU2,3447,branch-misses
CPU3,12714,branch-misses
CPU0,8330,cache-references
CPU1,313844,cache-references
CPU2,47993728,cache-references
CPU3,826481,cache-references
CPU0,272,cache-misses
CPU1,5360,cache-misses
CPU2,1342193,cache-misses
CPU3,13992,cache-misses
This second version adds the ability to name a separator and uses
field-separator as the long option to be consistent with perf report.
Commiter note: Since we enabled --big-num by default in 201e0b0 and -x can't be
used with it, we need to notice if the user explicitely enabled or disabled -B,
add code to disable big_num if the user didn't explicitely set --big_num when
-x is used.
Cc: David S. Miller <davem@davemloft.net>
Cc: Frederik Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: paulus@samba.org
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Robert Richter <robert.richter@amd.com>
LKML-Reference: <4cf68aa7.0fedd80a.5294.1203@mx.google.com>
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2010-12-01 18:49:05 +02:00
										 |  |  | 	if (!csv_output) { | 
					
						
							| 
									
										
										
											
												perf stat: Add more cache-miss percentage printouts
Print out the cache-miss percentage as well if the cache refs were
collected, for all the generic cache event types.
Before:
   11,103,723,230 dTLB-loads                #  622.471 M/sec                    ( +-  0.30% )
       87,065,337 dTLB-load-misses          #    4.881 M/sec                    ( +-  0.90% )
After:
   11,353,713,242 dTLB-loads                #  626.020 M/sec                    ( +-  0.35% )
      113,393,472 dTLB-load-misses          #    1.00% of all dTLB cache hits   ( +-  0.49% )
Also ASCII color highlight too high percentages, them when it's executed on the console.
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Steven Rostedt <rostedt@goodmis.org>
Link: http://lkml.kernel.org/n/tip-lkhwxsevdbd9a8nymx0vxc3y@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-05-19 14:01:42 +02:00
										 |  |  | 		if (!null_run) | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 			fprintf(output, "\n"); | 
					
						
							|  |  |  | 		fprintf(output, " %17.9f seconds time elapsed", | 
					
						
							| 
									
										
											  
											
												perf stat: Add csv-style output
This patch adds an option (-x/--field-separator) to print counts using a
CSV-style output. The user can pass a custom separator. This makes it very easy
to import counts directly into your favorite spreadsheet without having to
write scripts.
Example:
$ perf stat --field-separator=,  -a -- sleep 1
4009.961740,task-clock-msecs
13,context-switches
2,CPU-migrations
189,page-faults
9596385684,cycles
3493659441,instructions
872897069,branches
41562,branch-misses
22424,cache-references
1289,cache-misses
Works also in non-aggregated mode:
$ perf stat -x ,  -a -A -- sleep 1
CPU0,1002.526168,task-clock-msecs
CPU1,1002.528365,task-clock-msecs
CPU2,1002.523360,task-clock-msecs
CPU3,1002.519878,task-clock-msecs
CPU0,1,context-switches
CPU1,5,context-switches
CPU2,5,context-switches
CPU3,6,context-switches
CPU0,0,CPU-migrations
CPU1,1,CPU-migrations
CPU2,0,CPU-migrations
CPU3,1,CPU-migrations
CPU0,2,page-faults
CPU1,6,page-faults
CPU2,9,page-faults
CPU3,174,page-faults
CPU0,2399439771,cycles
CPU1,2380369063,cycles
CPU2,2399142710,cycles
CPU3,2373161192,cycles
CPU0,872900618,instructions
CPU1,873030960,instructions
CPU2,872714525,instructions
CPU3,874460580,instructions
CPU0,221556839,branches
CPU1,218134342,branches
CPU2,218161730,branches
CPU3,218284093,branches
CPU0,18556,branch-misses
CPU1,1449,branch-misses
CPU2,3447,branch-misses
CPU3,12714,branch-misses
CPU0,8330,cache-references
CPU1,313844,cache-references
CPU2,47993728,cache-references
CPU3,826481,cache-references
CPU0,272,cache-misses
CPU1,5360,cache-misses
CPU2,1342193,cache-misses
CPU3,13992,cache-misses
This second version adds the ability to name a separator and uses
field-separator as the long option to be consistent with perf report.
Commiter note: Since we enabled --big-num by default in 201e0b0 and -x can't be
used with it, we need to notice if the user explicitely enabled or disabled -B,
add code to disable big_num if the user didn't explicitely set --big_num when
-x is used.
Cc: David S. Miller <davem@davemloft.net>
Cc: Frederik Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: paulus@samba.org
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Robert Richter <robert.richter@amd.com>
LKML-Reference: <4cf68aa7.0fedd80a.5294.1203@mx.google.com>
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2010-12-01 18:49:05 +02:00
										 |  |  | 				avg_stats(&walltime_nsecs_stats)/1e9); | 
					
						
							|  |  |  | 		if (run_count > 1) { | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 			fprintf(output, "                                        "); | 
					
						
							| 
									
										
										
										
											2011-04-27 05:35:39 +02:00
										 |  |  | 			print_noise_pct(stddev_stats(&walltime_nsecs_stats), | 
					
						
							|  |  |  | 					avg_stats(&walltime_nsecs_stats)); | 
					
						
							| 
									
										
											  
											
												perf stat: Add csv-style output
This patch adds an option (-x/--field-separator) to print counts using a
CSV-style output. The user can pass a custom separator. This makes it very easy
to import counts directly into your favorite spreadsheet without having to
write scripts.
Example:
$ perf stat --field-separator=,  -a -- sleep 1
4009.961740,task-clock-msecs
13,context-switches
2,CPU-migrations
189,page-faults
9596385684,cycles
3493659441,instructions
872897069,branches
41562,branch-misses
22424,cache-references
1289,cache-misses
Works also in non-aggregated mode:
$ perf stat -x ,  -a -A -- sleep 1
CPU0,1002.526168,task-clock-msecs
CPU1,1002.528365,task-clock-msecs
CPU2,1002.523360,task-clock-msecs
CPU3,1002.519878,task-clock-msecs
CPU0,1,context-switches
CPU1,5,context-switches
CPU2,5,context-switches
CPU3,6,context-switches
CPU0,0,CPU-migrations
CPU1,1,CPU-migrations
CPU2,0,CPU-migrations
CPU3,1,CPU-migrations
CPU0,2,page-faults
CPU1,6,page-faults
CPU2,9,page-faults
CPU3,174,page-faults
CPU0,2399439771,cycles
CPU1,2380369063,cycles
CPU2,2399142710,cycles
CPU3,2373161192,cycles
CPU0,872900618,instructions
CPU1,873030960,instructions
CPU2,872714525,instructions
CPU3,874460580,instructions
CPU0,221556839,branches
CPU1,218134342,branches
CPU2,218161730,branches
CPU3,218284093,branches
CPU0,18556,branch-misses
CPU1,1449,branch-misses
CPU2,3447,branch-misses
CPU3,12714,branch-misses
CPU0,8330,cache-references
CPU1,313844,cache-references
CPU2,47993728,cache-references
CPU3,826481,cache-references
CPU0,272,cache-misses
CPU1,5360,cache-misses
CPU2,1342193,cache-misses
CPU3,13992,cache-misses
This second version adds the ability to name a separator and uses
field-separator as the long option to be consistent with perf report.
Commiter note: Since we enabled --big-num by default in 201e0b0 and -x can't be
used with it, we need to notice if the user explicitely enabled or disabled -B,
add code to disable big_num if the user didn't explicitely set --big_num when
-x is used.
Cc: David S. Miller <davem@davemloft.net>
Cc: Frederik Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: paulus@samba.org
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Robert Richter <robert.richter@amd.com>
LKML-Reference: <4cf68aa7.0fedd80a.5294.1203@mx.google.com>
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2010-12-01 18:49:05 +02:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 		fprintf(output, "\n\n"); | 
					
						
							| 
									
										
										
										
											2009-06-27 06:24:32 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-04-20 15:37:32 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-10 15:55:59 +02:00
										 |  |  | static volatile int signr = -1; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-26 09:17:18 +02:00
										 |  |  | static void skip_signal(int signo) | 
					
						
							| 
									
										
										
										
											2009-04-20 15:37:32 +02:00
										 |  |  | { | 
					
						
							| 
									
										
											  
											
												perf stat: Add interval printing
This patch adds a new printing mode for perf stat.  It allows interval
printing. That means perf stat can now print event deltas at regular
time interval.  This is useful to detect phases in programs.
The -I option enables interval printing. It expects an interval duration
in milliseconds. Minimum is 100ms. Once, activated perf stat prints
events deltas since last printout. All modes are supported.
$ perf stat -I 1000 -e cycles noploop 10
noploop for 10 seconds
 #           time             counts events
      1.000109853      2,388,560,546 cycles
      2.000262846      2,393,332,358 cycles
      3.000354131      2,393,176,537 cycles
      4.000439503      2,393,203,790 cycles
      5.000527075      2,393,167,675 cycles
      6.000609052      2,393,203,670 cycles
      7.000691082      2,393,175,678 cycles
The output format makes it easy to feed into a plotting program such as
gnuplot when the -I option is used in combination with the -x option:
$ perf stat -x, -I 1000 -e cycles noploop 10
noploop for 10 seconds
1.000084113,2378775498,cycles
2.000245798,2391056897,cycles
3.000354445,2392089414,cycles
4.000459115,2390936603,cycles
5.000565341,2392108173,cycles
Signed-off-by: Stephane Eranian <eranian@google.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1359460064-3060-3-git-send-email-eranian@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2013-01-29 12:47:44 +01:00
										 |  |  | 	if ((child_pid == -1) || interval) | 
					
						
							| 
									
										
										
										
											2009-12-31 16:05:50 +08:00
										 |  |  | 		done = 1; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-10 15:55:59 +02:00
										 |  |  | 	signr = signo; | 
					
						
							| 
									
										
										
										
											2013-06-04 17:44:26 +02:00
										 |  |  | 	/*
 | 
					
						
							|  |  |  | 	 * render child_pid harmless | 
					
						
							|  |  |  | 	 * won't send SIGTERM to a random | 
					
						
							|  |  |  | 	 * process in case of race condition | 
					
						
							|  |  |  | 	 * and fast PID recycling | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	child_pid = -1; | 
					
						
							| 
									
										
										
										
											2009-06-10 15:55:59 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void sig_atexit(void) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2013-06-04 17:44:26 +02:00
										 |  |  | 	sigset_t set, oset; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/*
 | 
					
						
							|  |  |  | 	 * avoid race condition with SIGCHLD handler | 
					
						
							|  |  |  | 	 * in skip_signal() which is modifying child_pid | 
					
						
							|  |  |  | 	 * goal is to avoid send SIGTERM to a random | 
					
						
							|  |  |  | 	 * process | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	sigemptyset(&set); | 
					
						
							|  |  |  | 	sigaddset(&set, SIGCHLD); | 
					
						
							|  |  |  | 	sigprocmask(SIG_BLOCK, &set, &oset); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-04 01:35:01 +01:00
										 |  |  | 	if (child_pid != -1) | 
					
						
							|  |  |  | 		kill(child_pid, SIGTERM); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-06-04 17:44:26 +02:00
										 |  |  | 	sigprocmask(SIG_SETMASK, &oset, NULL); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-10 15:55:59 +02:00
										 |  |  | 	if (signr == -1) | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	signal(signr, SIG_DFL); | 
					
						
							|  |  |  | 	kill(getpid(), signr); | 
					
						
							| 
									
										
										
										
											2009-05-26 09:17:18 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-11 01:15:03 +03:00
										 |  |  | static int stat__set_big_num(const struct option *opt __maybe_unused, | 
					
						
							|  |  |  | 			     const char *s __maybe_unused, int unset) | 
					
						
							| 
									
										
											  
											
												perf stat: Add csv-style output
This patch adds an option (-x/--field-separator) to print counts using a
CSV-style output. The user can pass a custom separator. This makes it very easy
to import counts directly into your favorite spreadsheet without having to
write scripts.
Example:
$ perf stat --field-separator=,  -a -- sleep 1
4009.961740,task-clock-msecs
13,context-switches
2,CPU-migrations
189,page-faults
9596385684,cycles
3493659441,instructions
872897069,branches
41562,branch-misses
22424,cache-references
1289,cache-misses
Works also in non-aggregated mode:
$ perf stat -x ,  -a -A -- sleep 1
CPU0,1002.526168,task-clock-msecs
CPU1,1002.528365,task-clock-msecs
CPU2,1002.523360,task-clock-msecs
CPU3,1002.519878,task-clock-msecs
CPU0,1,context-switches
CPU1,5,context-switches
CPU2,5,context-switches
CPU3,6,context-switches
CPU0,0,CPU-migrations
CPU1,1,CPU-migrations
CPU2,0,CPU-migrations
CPU3,1,CPU-migrations
CPU0,2,page-faults
CPU1,6,page-faults
CPU2,9,page-faults
CPU3,174,page-faults
CPU0,2399439771,cycles
CPU1,2380369063,cycles
CPU2,2399142710,cycles
CPU3,2373161192,cycles
CPU0,872900618,instructions
CPU1,873030960,instructions
CPU2,872714525,instructions
CPU3,874460580,instructions
CPU0,221556839,branches
CPU1,218134342,branches
CPU2,218161730,branches
CPU3,218284093,branches
CPU0,18556,branch-misses
CPU1,1449,branch-misses
CPU2,3447,branch-misses
CPU3,12714,branch-misses
CPU0,8330,cache-references
CPU1,313844,cache-references
CPU2,47993728,cache-references
CPU3,826481,cache-references
CPU0,272,cache-misses
CPU1,5360,cache-misses
CPU2,1342193,cache-misses
CPU3,13992,cache-misses
This second version adds the ability to name a separator and uses
field-separator as the long option to be consistent with perf report.
Commiter note: Since we enabled --big-num by default in 201e0b0 and -x can't be
used with it, we need to notice if the user explicitely enabled or disabled -B,
add code to disable big_num if the user didn't explicitely set --big_num when
-x is used.
Cc: David S. Miller <davem@davemloft.net>
Cc: Frederik Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: paulus@samba.org
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Robert Richter <robert.richter@amd.com>
LKML-Reference: <4cf68aa7.0fedd80a.5294.1203@mx.google.com>
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2010-12-01 18:49:05 +02:00
										 |  |  | { | 
					
						
							|  |  |  | 	big_num_opt = unset ? 0 : 1; | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | static int perf_stat_init_aggr_mode(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	switch (aggr_mode) { | 
					
						
							|  |  |  | 	case AGGR_SOCKET: | 
					
						
							|  |  |  | 		if (cpu_map__build_socket_map(evsel_list->cpus, &aggr_map)) { | 
					
						
							|  |  |  | 			perror("cannot build socket map"); | 
					
						
							|  |  |  | 			return -1; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		aggr_get_id = cpu_map__get_socket; | 
					
						
							|  |  |  | 		break; | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:29 +01:00
										 |  |  | 	case AGGR_CORE: | 
					
						
							|  |  |  | 		if (cpu_map__build_core_map(evsel_list->cpus, &aggr_map)) { | 
					
						
							|  |  |  | 			perror("cannot build core map"); | 
					
						
							|  |  |  | 			return -1; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		aggr_get_id = cpu_map__get_core; | 
					
						
							|  |  |  | 		break; | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 	case AGGR_NONE: | 
					
						
							|  |  |  | 	case AGGR_GLOBAL: | 
					
						
							|  |  |  | 	default: | 
					
						
							|  |  |  | 		break; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-21 16:47:26 -07:00
										 |  |  | static int setup_events(const char * const *attrs, unsigned len) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	unsigned i; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for (i = 0; i < len; i++) { | 
					
						
							|  |  |  | 		if (parse_events(evsel_list, attrs[i])) | 
					
						
							|  |  |  | 			return -1; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												perf stat: Add -d -d and -d -d -d options to show more CPU events
Print even more detailed statistics if requested via perf stat -d:
       -d:          detailed events, L1 and LLC data cache
    -d -d:     more detailed events, dTLB and iTLB events
 -d -d -d:     very detailed events, adding prefetch events
Full output looks like this now:
 Performance counter stats for '/home/mingo/hackbench 10' (5 runs):
       1703.674707 task-clock                #    8.709 CPUs utilized            ( +-  4.19% )
            49,068 context-switches          #    0.029 M/sec                    ( +- 16.66% )
             8,303 CPU-migrations            #    0.005 M/sec                    ( +- 24.90% )
            17,397 page-faults               #    0.010 M/sec                    ( +-  0.46% )
     2,345,389,239 cycles                    #    1.377 GHz                      ( +-  4.61% ) [55.90%]
     1,884,503,527 stalled-cycles-frontend   #   80.35% frontend cycles idle     ( +-  5.67% ) [50.39%]
       743,919,737 stalled-cycles-backend    #   31.72% backend  cycles idle     ( +-  8.75% ) [49.91%]
     1,314,416,379 instructions              #    0.56  insns per cycle
                                             #    1.43  stalled cycles per insn  ( +-  2.53% ) [60.87%]
       272,592,567 branches                  #  160.003 M/sec                    ( +-  1.74% ) [56.56%]
         3,794,846 branch-misses             #    1.39% of all branches          ( +-  6.59% ) [58.50%]
       449,982,778 L1-dcache-loads           #  264.125 M/sec                    ( +-  2.47% ) [49.88%]
        22,404,961 L1-dcache-load-misses     #    4.98% of all L1-dcache hits    ( +-  6.08% ) [55.05%]
         6,204,750 LLC-loads                 #    3.642 M/sec                    ( +-  8.91% ) [43.75%]
         1,837,411 LLC-load-misses           #    1.078 M/sec                    ( +-  7.27% ) [12.07%]
       411,440,421 L1-icache-loads           #  241.502 M/sec                    ( +-  5.60% ) [36.52%]
        27,556,832 L1-icache-load-misses     #   16.175 M/sec                    ( +-  7.46% ) [46.72%]
       464,067,627 dTLB-loads                #  272.392 M/sec                    ( +-  4.46% ) [54.17%]
        10,765,648 dTLB-load-misses          #    6.319 M/sec                    ( +-  3.18% ) [48.68%]
     1,273,080,386 iTLB-loads                #  747.256 M/sec                    ( +-  3.38% ) [47.53%]
           117,481 iTLB-load-misses          #    0.069 M/sec                    ( +- 14.99% ) [47.01%]
         4,590,653 L1-dcache-prefetches      #    2.695 M/sec                    ( +-  4.49% ) [46.19%]
         1,712,660 L1-dcache-prefetch-misses #    1.005 M/sec                    ( +-  3.75% ) [44.82%]
        0.195622057  seconds time elapsed  ( +-  6.84% )
Also clean up the attribute construction code to be appending, and factor
it out into add_default_attributes().
Tweak the coverage percentage printout a bit, so that it's easier to view it
alongside the +- sttddev colum.
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Steven Rostedt <rostedt@goodmis.org>
Link: http://lkml.kernel.org/n/tip-to3kgu04449s64062val8b62@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-05-19 13:30:56 +02:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * Add default attributes, if there were no attributes specified or | 
					
						
							|  |  |  |  * if -d/--detailed, -d -d or -d -d -d is used: | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | static int add_default_attributes(void) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-10-01 15:20:58 -03:00
										 |  |  | 	struct perf_event_attr default_attrs[] = { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   { .type = PERF_TYPE_SOFTWARE, .config = PERF_COUNT_SW_TASK_CLOCK		}, | 
					
						
							|  |  |  |   { .type = PERF_TYPE_SOFTWARE, .config = PERF_COUNT_SW_CONTEXT_SWITCHES	}, | 
					
						
							|  |  |  |   { .type = PERF_TYPE_SOFTWARE, .config = PERF_COUNT_SW_CPU_MIGRATIONS		}, | 
					
						
							|  |  |  |   { .type = PERF_TYPE_SOFTWARE, .config = PERF_COUNT_SW_PAGE_FAULTS		}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   { .type = PERF_TYPE_HARDWARE, .config = PERF_COUNT_HW_CPU_CYCLES		}, | 
					
						
							|  |  |  |   { .type = PERF_TYPE_HARDWARE, .config = PERF_COUNT_HW_STALLED_CYCLES_FRONTEND	}, | 
					
						
							|  |  |  |   { .type = PERF_TYPE_HARDWARE, .config = PERF_COUNT_HW_STALLED_CYCLES_BACKEND	}, | 
					
						
							|  |  |  |   { .type = PERF_TYPE_HARDWARE, .config = PERF_COUNT_HW_INSTRUCTIONS		}, | 
					
						
							|  |  |  |   { .type = PERF_TYPE_HARDWARE, .config = PERF_COUNT_HW_BRANCH_INSTRUCTIONS	}, | 
					
						
							|  |  |  |   { .type = PERF_TYPE_HARDWARE, .config = PERF_COUNT_HW_BRANCH_MISSES		}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * Detailed stats (-d), covering the L1 and last level data caches: | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 	struct perf_event_attr detailed_attrs[] = { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   { .type = PERF_TYPE_HW_CACHE, | 
					
						
							|  |  |  |     .config = | 
					
						
							|  |  |  | 	 PERF_COUNT_HW_CACHE_L1D		<<  0  | | 
					
						
							|  |  |  | 	(PERF_COUNT_HW_CACHE_OP_READ		<<  8) | | 
					
						
							|  |  |  | 	(PERF_COUNT_HW_CACHE_RESULT_ACCESS	<< 16)				}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   { .type = PERF_TYPE_HW_CACHE, | 
					
						
							|  |  |  |     .config = | 
					
						
							|  |  |  | 	 PERF_COUNT_HW_CACHE_L1D		<<  0  | | 
					
						
							|  |  |  | 	(PERF_COUNT_HW_CACHE_OP_READ		<<  8) | | 
					
						
							|  |  |  | 	(PERF_COUNT_HW_CACHE_RESULT_MISS	<< 16)				}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   { .type = PERF_TYPE_HW_CACHE, | 
					
						
							|  |  |  |     .config = | 
					
						
							|  |  |  | 	 PERF_COUNT_HW_CACHE_LL			<<  0  | | 
					
						
							|  |  |  | 	(PERF_COUNT_HW_CACHE_OP_READ		<<  8) | | 
					
						
							|  |  |  | 	(PERF_COUNT_HW_CACHE_RESULT_ACCESS	<< 16)				}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   { .type = PERF_TYPE_HW_CACHE, | 
					
						
							|  |  |  |     .config = | 
					
						
							|  |  |  | 	 PERF_COUNT_HW_CACHE_LL			<<  0  | | 
					
						
							|  |  |  | 	(PERF_COUNT_HW_CACHE_OP_READ		<<  8) | | 
					
						
							|  |  |  | 	(PERF_COUNT_HW_CACHE_RESULT_MISS	<< 16)				}, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * Very detailed stats (-d -d), covering the instruction cache and the TLB caches: | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 	struct perf_event_attr very_detailed_attrs[] = { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   { .type = PERF_TYPE_HW_CACHE, | 
					
						
							|  |  |  |     .config = | 
					
						
							|  |  |  | 	 PERF_COUNT_HW_CACHE_L1I		<<  0  | | 
					
						
							|  |  |  | 	(PERF_COUNT_HW_CACHE_OP_READ		<<  8) | | 
					
						
							|  |  |  | 	(PERF_COUNT_HW_CACHE_RESULT_ACCESS	<< 16)				}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   { .type = PERF_TYPE_HW_CACHE, | 
					
						
							|  |  |  |     .config = | 
					
						
							|  |  |  | 	 PERF_COUNT_HW_CACHE_L1I		<<  0  | | 
					
						
							|  |  |  | 	(PERF_COUNT_HW_CACHE_OP_READ		<<  8) | | 
					
						
							|  |  |  | 	(PERF_COUNT_HW_CACHE_RESULT_MISS	<< 16)				}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   { .type = PERF_TYPE_HW_CACHE, | 
					
						
							|  |  |  |     .config = | 
					
						
							|  |  |  | 	 PERF_COUNT_HW_CACHE_DTLB		<<  0  | | 
					
						
							|  |  |  | 	(PERF_COUNT_HW_CACHE_OP_READ		<<  8) | | 
					
						
							|  |  |  | 	(PERF_COUNT_HW_CACHE_RESULT_ACCESS	<< 16)				}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   { .type = PERF_TYPE_HW_CACHE, | 
					
						
							|  |  |  |     .config = | 
					
						
							|  |  |  | 	 PERF_COUNT_HW_CACHE_DTLB		<<  0  | | 
					
						
							|  |  |  | 	(PERF_COUNT_HW_CACHE_OP_READ		<<  8) | | 
					
						
							|  |  |  | 	(PERF_COUNT_HW_CACHE_RESULT_MISS	<< 16)				}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   { .type = PERF_TYPE_HW_CACHE, | 
					
						
							|  |  |  |     .config = | 
					
						
							|  |  |  | 	 PERF_COUNT_HW_CACHE_ITLB		<<  0  | | 
					
						
							|  |  |  | 	(PERF_COUNT_HW_CACHE_OP_READ		<<  8) | | 
					
						
							|  |  |  | 	(PERF_COUNT_HW_CACHE_RESULT_ACCESS	<< 16)				}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   { .type = PERF_TYPE_HW_CACHE, | 
					
						
							|  |  |  |     .config = | 
					
						
							|  |  |  | 	 PERF_COUNT_HW_CACHE_ITLB		<<  0  | | 
					
						
							|  |  |  | 	(PERF_COUNT_HW_CACHE_OP_READ		<<  8) | | 
					
						
							|  |  |  | 	(PERF_COUNT_HW_CACHE_RESULT_MISS	<< 16)				}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * Very, very detailed stats (-d -d -d), adding prefetch events: | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 	struct perf_event_attr very_very_detailed_attrs[] = { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   { .type = PERF_TYPE_HW_CACHE, | 
					
						
							|  |  |  |     .config = | 
					
						
							|  |  |  | 	 PERF_COUNT_HW_CACHE_L1D		<<  0  | | 
					
						
							|  |  |  | 	(PERF_COUNT_HW_CACHE_OP_PREFETCH	<<  8) | | 
					
						
							|  |  |  | 	(PERF_COUNT_HW_CACHE_RESULT_ACCESS	<< 16)				}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   { .type = PERF_TYPE_HW_CACHE, | 
					
						
							|  |  |  |     .config = | 
					
						
							|  |  |  | 	 PERF_COUNT_HW_CACHE_L1D		<<  0  | | 
					
						
							|  |  |  | 	(PERF_COUNT_HW_CACHE_OP_PREFETCH	<<  8) | | 
					
						
							|  |  |  | 	(PERF_COUNT_HW_CACHE_RESULT_MISS	<< 16)				}, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												perf stat: Add -d -d and -d -d -d options to show more CPU events
Print even more detailed statistics if requested via perf stat -d:
       -d:          detailed events, L1 and LLC data cache
    -d -d:     more detailed events, dTLB and iTLB events
 -d -d -d:     very detailed events, adding prefetch events
Full output looks like this now:
 Performance counter stats for '/home/mingo/hackbench 10' (5 runs):
       1703.674707 task-clock                #    8.709 CPUs utilized            ( +-  4.19% )
            49,068 context-switches          #    0.029 M/sec                    ( +- 16.66% )
             8,303 CPU-migrations            #    0.005 M/sec                    ( +- 24.90% )
            17,397 page-faults               #    0.010 M/sec                    ( +-  0.46% )
     2,345,389,239 cycles                    #    1.377 GHz                      ( +-  4.61% ) [55.90%]
     1,884,503,527 stalled-cycles-frontend   #   80.35% frontend cycles idle     ( +-  5.67% ) [50.39%]
       743,919,737 stalled-cycles-backend    #   31.72% backend  cycles idle     ( +-  8.75% ) [49.91%]
     1,314,416,379 instructions              #    0.56  insns per cycle
                                             #    1.43  stalled cycles per insn  ( +-  2.53% ) [60.87%]
       272,592,567 branches                  #  160.003 M/sec                    ( +-  1.74% ) [56.56%]
         3,794,846 branch-misses             #    1.39% of all branches          ( +-  6.59% ) [58.50%]
       449,982,778 L1-dcache-loads           #  264.125 M/sec                    ( +-  2.47% ) [49.88%]
        22,404,961 L1-dcache-load-misses     #    4.98% of all L1-dcache hits    ( +-  6.08% ) [55.05%]
         6,204,750 LLC-loads                 #    3.642 M/sec                    ( +-  8.91% ) [43.75%]
         1,837,411 LLC-load-misses           #    1.078 M/sec                    ( +-  7.27% ) [12.07%]
       411,440,421 L1-icache-loads           #  241.502 M/sec                    ( +-  5.60% ) [36.52%]
        27,556,832 L1-icache-load-misses     #   16.175 M/sec                    ( +-  7.46% ) [46.72%]
       464,067,627 dTLB-loads                #  272.392 M/sec                    ( +-  4.46% ) [54.17%]
        10,765,648 dTLB-load-misses          #    6.319 M/sec                    ( +-  3.18% ) [48.68%]
     1,273,080,386 iTLB-loads                #  747.256 M/sec                    ( +-  3.38% ) [47.53%]
           117,481 iTLB-load-misses          #    0.069 M/sec                    ( +- 14.99% ) [47.01%]
         4,590,653 L1-dcache-prefetches      #    2.695 M/sec                    ( +-  4.49% ) [46.19%]
         1,712,660 L1-dcache-prefetch-misses #    1.005 M/sec                    ( +-  3.75% ) [44.82%]
        0.195622057  seconds time elapsed  ( +-  6.84% )
Also clean up the attribute construction code to be appending, and factor
it out into add_default_attributes().
Tweak the coverage percentage printout a bit, so that it's easier to view it
alongside the +- sttddev colum.
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Steven Rostedt <rostedt@goodmis.org>
Link: http://lkml.kernel.org/n/tip-to3kgu04449s64062val8b62@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-05-19 13:30:56 +02:00
										 |  |  | 	/* Set attrs if no event is selected and !null_run: */ | 
					
						
							|  |  |  | 	if (null_run) | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-21 16:47:26 -07:00
										 |  |  | 	if (transaction_run) { | 
					
						
							|  |  |  | 		int err; | 
					
						
							|  |  |  | 		if (pmu_have_event("cpu", "cycles-ct") && | 
					
						
							|  |  |  | 		    pmu_have_event("cpu", "el-start")) | 
					
						
							|  |  |  | 			err = setup_events(transaction_attrs, | 
					
						
							|  |  |  | 					ARRAY_SIZE(transaction_attrs)); | 
					
						
							|  |  |  | 		else | 
					
						
							|  |  |  | 			err = setup_events(transaction_limited_attrs, | 
					
						
							|  |  |  | 				 ARRAY_SIZE(transaction_limited_attrs)); | 
					
						
							|  |  |  | 		if (err < 0) { | 
					
						
							|  |  |  | 			fprintf(stderr, "Cannot set up transaction events\n"); | 
					
						
							|  |  |  | 			return -1; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												perf stat: Add -d -d and -d -d -d options to show more CPU events
Print even more detailed statistics if requested via perf stat -d:
       -d:          detailed events, L1 and LLC data cache
    -d -d:     more detailed events, dTLB and iTLB events
 -d -d -d:     very detailed events, adding prefetch events
Full output looks like this now:
 Performance counter stats for '/home/mingo/hackbench 10' (5 runs):
       1703.674707 task-clock                #    8.709 CPUs utilized            ( +-  4.19% )
            49,068 context-switches          #    0.029 M/sec                    ( +- 16.66% )
             8,303 CPU-migrations            #    0.005 M/sec                    ( +- 24.90% )
            17,397 page-faults               #    0.010 M/sec                    ( +-  0.46% )
     2,345,389,239 cycles                    #    1.377 GHz                      ( +-  4.61% ) [55.90%]
     1,884,503,527 stalled-cycles-frontend   #   80.35% frontend cycles idle     ( +-  5.67% ) [50.39%]
       743,919,737 stalled-cycles-backend    #   31.72% backend  cycles idle     ( +-  8.75% ) [49.91%]
     1,314,416,379 instructions              #    0.56  insns per cycle
                                             #    1.43  stalled cycles per insn  ( +-  2.53% ) [60.87%]
       272,592,567 branches                  #  160.003 M/sec                    ( +-  1.74% ) [56.56%]
         3,794,846 branch-misses             #    1.39% of all branches          ( +-  6.59% ) [58.50%]
       449,982,778 L1-dcache-loads           #  264.125 M/sec                    ( +-  2.47% ) [49.88%]
        22,404,961 L1-dcache-load-misses     #    4.98% of all L1-dcache hits    ( +-  6.08% ) [55.05%]
         6,204,750 LLC-loads                 #    3.642 M/sec                    ( +-  8.91% ) [43.75%]
         1,837,411 LLC-load-misses           #    1.078 M/sec                    ( +-  7.27% ) [12.07%]
       411,440,421 L1-icache-loads           #  241.502 M/sec                    ( +-  5.60% ) [36.52%]
        27,556,832 L1-icache-load-misses     #   16.175 M/sec                    ( +-  7.46% ) [46.72%]
       464,067,627 dTLB-loads                #  272.392 M/sec                    ( +-  4.46% ) [54.17%]
        10,765,648 dTLB-load-misses          #    6.319 M/sec                    ( +-  3.18% ) [48.68%]
     1,273,080,386 iTLB-loads                #  747.256 M/sec                    ( +-  3.38% ) [47.53%]
           117,481 iTLB-load-misses          #    0.069 M/sec                    ( +- 14.99% ) [47.01%]
         4,590,653 L1-dcache-prefetches      #    2.695 M/sec                    ( +-  4.49% ) [46.19%]
         1,712,660 L1-dcache-prefetch-misses #    1.005 M/sec                    ( +-  3.75% ) [44.82%]
        0.195622057  seconds time elapsed  ( +-  6.84% )
Also clean up the attribute construction code to be appending, and factor
it out into add_default_attributes().
Tweak the coverage percentage printout a bit, so that it's easier to view it
alongside the +- sttddev colum.
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Steven Rostedt <rostedt@goodmis.org>
Link: http://lkml.kernel.org/n/tip-to3kgu04449s64062val8b62@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-05-19 13:30:56 +02:00
										 |  |  | 	if (!evsel_list->nr_entries) { | 
					
						
							| 
									
										
											  
											
												perf stat: Initialize default events wrt exclude_{guest,host}
When no event is specified the tools use perf_evlist__add_default(), that will
call event_attr_init to initialize the KVM exclusion bits.
When the change was made to the tools so that by default guest samples would be
excluded, the changes were made just to the parsing routines and to
perf_evlist__add_default(), not to perf_evlist__add_attrs, that is used so far
just by perf stat to add multiple events, according to the level of detail
specified.
Recently the tools were changed to reconstruct the event name from all the
details in perf_event_attr, not just from .type and .config, but taking into
account all the feature bits (.exclude_{guest,host,user,kernel,etc},
.precise_ip, etc).
That is when we noticed that the default for perf stat wasn't the one for the
rest of the tools, i.e. the .exclude_guest bit wasn't being set.
I.e. the default, that doesn't call event_attr_init was showing the :HG
modifier:
  $ perf stat usleep 1
   Performance counter stats for 'usleep 1':
            0.942119 task-clock                #    0.454 CPUs utilized
                   1 context-switches          #    0.001 M/sec
                   0 CPU-migrations            #    0.000 K/sec
                 126 page-faults               #    0.134 M/sec
             693,193 cycles:HG                 #    0.736 GHz                     [40.11%]
             407,461 stalled-cycles-frontend:HG #   58.78% frontend cycles idle    [72.29%]
             365,403 stalled-cycles-backend:HG #   52.71% backend  cycles idle
             465,982 instructions:HG           #    0.67  insns per cycle
                                               #    0.87  stalled cycles per insn
              89,760 branches:HG               #   95.275 M/sec
               6,178 branch-misses:HG          #    6.88% of all branches
         0.002077228 seconds time elapsed
While if one explicitely specifies the same events, which will make the parsing code
to be called and thus event_attr_init is called:
  $ perf stat -e task-clock,context-switches,migrations,page-faults,cycles,stalled-cycles-frontend,stalled-cycles-backend,instructions,branches,branch-misses usleep 1
   Performance counter stats for 'usleep 1':
            1.040349 task-clock                #    0.500 CPUs utilized
                   2 context-switches          #    0.002 M/sec
                   0 CPU-migrations            #    0.000 K/sec
                 127 page-faults               #    0.122 M/sec
             587,966 cycles                    #    0.565 GHz                     [13.18%]
             459,167 stalled-cycles-frontend   #   78.09% frontend cycles idle
             390,249 stalled-cycles-backend    #   66.37% backend  cycles idle
             504,006 instructions              #    0.86  insns per cycle
                                               #    0.91  stalled cycles per insn
              96,455 branches                  #   92.714 M/sec
               6,522 branch-misses             #    6.76% of all branches         [96.12%]
         0.002078681 seconds time elapsed
Fix it by introducing a perf_evlist__add_default_attrs method that will call
evlist_attr_init in all the perf_event_attr entries before adding the events.
Reported-by: Ingo Molnar <mingo@kernel.org>
Cc: David Ahern <dsahern@gmail.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Namhyung Kim <namhyung@gmail.com>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Stephane Eranian <eranian@google.com>
Link: http://lkml.kernel.org/n/tip-4eysr236r0pgiyum9epwxw7s@git.kernel.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2012-05-30 13:53:54 -03:00
										 |  |  | 		if (perf_evlist__add_default_attrs(evsel_list, default_attrs) < 0) | 
					
						
							| 
									
										
										
										
											2011-11-04 09:10:59 -02:00
										 |  |  | 			return -1; | 
					
						
							| 
									
										
											  
											
												perf stat: Add -d -d and -d -d -d options to show more CPU events
Print even more detailed statistics if requested via perf stat -d:
       -d:          detailed events, L1 and LLC data cache
    -d -d:     more detailed events, dTLB and iTLB events
 -d -d -d:     very detailed events, adding prefetch events
Full output looks like this now:
 Performance counter stats for '/home/mingo/hackbench 10' (5 runs):
       1703.674707 task-clock                #    8.709 CPUs utilized            ( +-  4.19% )
            49,068 context-switches          #    0.029 M/sec                    ( +- 16.66% )
             8,303 CPU-migrations            #    0.005 M/sec                    ( +- 24.90% )
            17,397 page-faults               #    0.010 M/sec                    ( +-  0.46% )
     2,345,389,239 cycles                    #    1.377 GHz                      ( +-  4.61% ) [55.90%]
     1,884,503,527 stalled-cycles-frontend   #   80.35% frontend cycles idle     ( +-  5.67% ) [50.39%]
       743,919,737 stalled-cycles-backend    #   31.72% backend  cycles idle     ( +-  8.75% ) [49.91%]
     1,314,416,379 instructions              #    0.56  insns per cycle
                                             #    1.43  stalled cycles per insn  ( +-  2.53% ) [60.87%]
       272,592,567 branches                  #  160.003 M/sec                    ( +-  1.74% ) [56.56%]
         3,794,846 branch-misses             #    1.39% of all branches          ( +-  6.59% ) [58.50%]
       449,982,778 L1-dcache-loads           #  264.125 M/sec                    ( +-  2.47% ) [49.88%]
        22,404,961 L1-dcache-load-misses     #    4.98% of all L1-dcache hits    ( +-  6.08% ) [55.05%]
         6,204,750 LLC-loads                 #    3.642 M/sec                    ( +-  8.91% ) [43.75%]
         1,837,411 LLC-load-misses           #    1.078 M/sec                    ( +-  7.27% ) [12.07%]
       411,440,421 L1-icache-loads           #  241.502 M/sec                    ( +-  5.60% ) [36.52%]
        27,556,832 L1-icache-load-misses     #   16.175 M/sec                    ( +-  7.46% ) [46.72%]
       464,067,627 dTLB-loads                #  272.392 M/sec                    ( +-  4.46% ) [54.17%]
        10,765,648 dTLB-load-misses          #    6.319 M/sec                    ( +-  3.18% ) [48.68%]
     1,273,080,386 iTLB-loads                #  747.256 M/sec                    ( +-  3.38% ) [47.53%]
           117,481 iTLB-load-misses          #    0.069 M/sec                    ( +- 14.99% ) [47.01%]
         4,590,653 L1-dcache-prefetches      #    2.695 M/sec                    ( +-  4.49% ) [46.19%]
         1,712,660 L1-dcache-prefetch-misses #    1.005 M/sec                    ( +-  3.75% ) [44.82%]
        0.195622057  seconds time elapsed  ( +-  6.84% )
Also clean up the attribute construction code to be appending, and factor
it out into add_default_attributes().
Tweak the coverage percentage printout a bit, so that it's easier to view it
alongside the +- sttddev colum.
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Steven Rostedt <rostedt@goodmis.org>
Link: http://lkml.kernel.org/n/tip-to3kgu04449s64062val8b62@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-05-19 13:30:56 +02:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Detailed events get appended to the event list: */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (detailed_run <  1) | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Append detailed run extra attributes: */ | 
					
						
							| 
									
										
											  
											
												perf stat: Initialize default events wrt exclude_{guest,host}
When no event is specified the tools use perf_evlist__add_default(), that will
call event_attr_init to initialize the KVM exclusion bits.
When the change was made to the tools so that by default guest samples would be
excluded, the changes were made just to the parsing routines and to
perf_evlist__add_default(), not to perf_evlist__add_attrs, that is used so far
just by perf stat to add multiple events, according to the level of detail
specified.
Recently the tools were changed to reconstruct the event name from all the
details in perf_event_attr, not just from .type and .config, but taking into
account all the feature bits (.exclude_{guest,host,user,kernel,etc},
.precise_ip, etc).
That is when we noticed that the default for perf stat wasn't the one for the
rest of the tools, i.e. the .exclude_guest bit wasn't being set.
I.e. the default, that doesn't call event_attr_init was showing the :HG
modifier:
  $ perf stat usleep 1
   Performance counter stats for 'usleep 1':
            0.942119 task-clock                #    0.454 CPUs utilized
                   1 context-switches          #    0.001 M/sec
                   0 CPU-migrations            #    0.000 K/sec
                 126 page-faults               #    0.134 M/sec
             693,193 cycles:HG                 #    0.736 GHz                     [40.11%]
             407,461 stalled-cycles-frontend:HG #   58.78% frontend cycles idle    [72.29%]
             365,403 stalled-cycles-backend:HG #   52.71% backend  cycles idle
             465,982 instructions:HG           #    0.67  insns per cycle
                                               #    0.87  stalled cycles per insn
              89,760 branches:HG               #   95.275 M/sec
               6,178 branch-misses:HG          #    6.88% of all branches
         0.002077228 seconds time elapsed
While if one explicitely specifies the same events, which will make the parsing code
to be called and thus event_attr_init is called:
  $ perf stat -e task-clock,context-switches,migrations,page-faults,cycles,stalled-cycles-frontend,stalled-cycles-backend,instructions,branches,branch-misses usleep 1
   Performance counter stats for 'usleep 1':
            1.040349 task-clock                #    0.500 CPUs utilized
                   2 context-switches          #    0.002 M/sec
                   0 CPU-migrations            #    0.000 K/sec
                 127 page-faults               #    0.122 M/sec
             587,966 cycles                    #    0.565 GHz                     [13.18%]
             459,167 stalled-cycles-frontend   #   78.09% frontend cycles idle
             390,249 stalled-cycles-backend    #   66.37% backend  cycles idle
             504,006 instructions              #    0.86  insns per cycle
                                               #    0.91  stalled cycles per insn
              96,455 branches                  #   92.714 M/sec
               6,522 branch-misses             #    6.76% of all branches         [96.12%]
         0.002078681 seconds time elapsed
Fix it by introducing a perf_evlist__add_default_attrs method that will call
evlist_attr_init in all the perf_event_attr entries before adding the events.
Reported-by: Ingo Molnar <mingo@kernel.org>
Cc: David Ahern <dsahern@gmail.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Namhyung Kim <namhyung@gmail.com>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Stephane Eranian <eranian@google.com>
Link: http://lkml.kernel.org/n/tip-4eysr236r0pgiyum9epwxw7s@git.kernel.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2012-05-30 13:53:54 -03:00
										 |  |  | 	if (perf_evlist__add_default_attrs(evsel_list, detailed_attrs) < 0) | 
					
						
							| 
									
										
										
										
											2011-11-04 09:10:59 -02:00
										 |  |  | 		return -1; | 
					
						
							| 
									
										
											  
											
												perf stat: Add -d -d and -d -d -d options to show more CPU events
Print even more detailed statistics if requested via perf stat -d:
       -d:          detailed events, L1 and LLC data cache
    -d -d:     more detailed events, dTLB and iTLB events
 -d -d -d:     very detailed events, adding prefetch events
Full output looks like this now:
 Performance counter stats for '/home/mingo/hackbench 10' (5 runs):
       1703.674707 task-clock                #    8.709 CPUs utilized            ( +-  4.19% )
            49,068 context-switches          #    0.029 M/sec                    ( +- 16.66% )
             8,303 CPU-migrations            #    0.005 M/sec                    ( +- 24.90% )
            17,397 page-faults               #    0.010 M/sec                    ( +-  0.46% )
     2,345,389,239 cycles                    #    1.377 GHz                      ( +-  4.61% ) [55.90%]
     1,884,503,527 stalled-cycles-frontend   #   80.35% frontend cycles idle     ( +-  5.67% ) [50.39%]
       743,919,737 stalled-cycles-backend    #   31.72% backend  cycles idle     ( +-  8.75% ) [49.91%]
     1,314,416,379 instructions              #    0.56  insns per cycle
                                             #    1.43  stalled cycles per insn  ( +-  2.53% ) [60.87%]
       272,592,567 branches                  #  160.003 M/sec                    ( +-  1.74% ) [56.56%]
         3,794,846 branch-misses             #    1.39% of all branches          ( +-  6.59% ) [58.50%]
       449,982,778 L1-dcache-loads           #  264.125 M/sec                    ( +-  2.47% ) [49.88%]
        22,404,961 L1-dcache-load-misses     #    4.98% of all L1-dcache hits    ( +-  6.08% ) [55.05%]
         6,204,750 LLC-loads                 #    3.642 M/sec                    ( +-  8.91% ) [43.75%]
         1,837,411 LLC-load-misses           #    1.078 M/sec                    ( +-  7.27% ) [12.07%]
       411,440,421 L1-icache-loads           #  241.502 M/sec                    ( +-  5.60% ) [36.52%]
        27,556,832 L1-icache-load-misses     #   16.175 M/sec                    ( +-  7.46% ) [46.72%]
       464,067,627 dTLB-loads                #  272.392 M/sec                    ( +-  4.46% ) [54.17%]
        10,765,648 dTLB-load-misses          #    6.319 M/sec                    ( +-  3.18% ) [48.68%]
     1,273,080,386 iTLB-loads                #  747.256 M/sec                    ( +-  3.38% ) [47.53%]
           117,481 iTLB-load-misses          #    0.069 M/sec                    ( +- 14.99% ) [47.01%]
         4,590,653 L1-dcache-prefetches      #    2.695 M/sec                    ( +-  4.49% ) [46.19%]
         1,712,660 L1-dcache-prefetch-misses #    1.005 M/sec                    ( +-  3.75% ) [44.82%]
        0.195622057  seconds time elapsed  ( +-  6.84% )
Also clean up the attribute construction code to be appending, and factor
it out into add_default_attributes().
Tweak the coverage percentage printout a bit, so that it's easier to view it
alongside the +- sttddev colum.
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Steven Rostedt <rostedt@goodmis.org>
Link: http://lkml.kernel.org/n/tip-to3kgu04449s64062val8b62@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-05-19 13:30:56 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (detailed_run < 2) | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Append very detailed run extra attributes: */ | 
					
						
							| 
									
										
											  
											
												perf stat: Initialize default events wrt exclude_{guest,host}
When no event is specified the tools use perf_evlist__add_default(), that will
call event_attr_init to initialize the KVM exclusion bits.
When the change was made to the tools so that by default guest samples would be
excluded, the changes were made just to the parsing routines and to
perf_evlist__add_default(), not to perf_evlist__add_attrs, that is used so far
just by perf stat to add multiple events, according to the level of detail
specified.
Recently the tools were changed to reconstruct the event name from all the
details in perf_event_attr, not just from .type and .config, but taking into
account all the feature bits (.exclude_{guest,host,user,kernel,etc},
.precise_ip, etc).
That is when we noticed that the default for perf stat wasn't the one for the
rest of the tools, i.e. the .exclude_guest bit wasn't being set.
I.e. the default, that doesn't call event_attr_init was showing the :HG
modifier:
  $ perf stat usleep 1
   Performance counter stats for 'usleep 1':
            0.942119 task-clock                #    0.454 CPUs utilized
                   1 context-switches          #    0.001 M/sec
                   0 CPU-migrations            #    0.000 K/sec
                 126 page-faults               #    0.134 M/sec
             693,193 cycles:HG                 #    0.736 GHz                     [40.11%]
             407,461 stalled-cycles-frontend:HG #   58.78% frontend cycles idle    [72.29%]
             365,403 stalled-cycles-backend:HG #   52.71% backend  cycles idle
             465,982 instructions:HG           #    0.67  insns per cycle
                                               #    0.87  stalled cycles per insn
              89,760 branches:HG               #   95.275 M/sec
               6,178 branch-misses:HG          #    6.88% of all branches
         0.002077228 seconds time elapsed
While if one explicitely specifies the same events, which will make the parsing code
to be called and thus event_attr_init is called:
  $ perf stat -e task-clock,context-switches,migrations,page-faults,cycles,stalled-cycles-frontend,stalled-cycles-backend,instructions,branches,branch-misses usleep 1
   Performance counter stats for 'usleep 1':
            1.040349 task-clock                #    0.500 CPUs utilized
                   2 context-switches          #    0.002 M/sec
                   0 CPU-migrations            #    0.000 K/sec
                 127 page-faults               #    0.122 M/sec
             587,966 cycles                    #    0.565 GHz                     [13.18%]
             459,167 stalled-cycles-frontend   #   78.09% frontend cycles idle
             390,249 stalled-cycles-backend    #   66.37% backend  cycles idle
             504,006 instructions              #    0.86  insns per cycle
                                               #    0.91  stalled cycles per insn
              96,455 branches                  #   92.714 M/sec
               6,522 branch-misses             #    6.76% of all branches         [96.12%]
         0.002078681 seconds time elapsed
Fix it by introducing a perf_evlist__add_default_attrs method that will call
evlist_attr_init in all the perf_event_attr entries before adding the events.
Reported-by: Ingo Molnar <mingo@kernel.org>
Cc: David Ahern <dsahern@gmail.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Namhyung Kim <namhyung@gmail.com>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Stephane Eranian <eranian@google.com>
Link: http://lkml.kernel.org/n/tip-4eysr236r0pgiyum9epwxw7s@git.kernel.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2012-05-30 13:53:54 -03:00
										 |  |  | 	if (perf_evlist__add_default_attrs(evsel_list, very_detailed_attrs) < 0) | 
					
						
							| 
									
										
										
										
											2011-11-04 09:10:59 -02:00
										 |  |  | 		return -1; | 
					
						
							| 
									
										
											  
											
												perf stat: Add -d -d and -d -d -d options to show more CPU events
Print even more detailed statistics if requested via perf stat -d:
       -d:          detailed events, L1 and LLC data cache
    -d -d:     more detailed events, dTLB and iTLB events
 -d -d -d:     very detailed events, adding prefetch events
Full output looks like this now:
 Performance counter stats for '/home/mingo/hackbench 10' (5 runs):
       1703.674707 task-clock                #    8.709 CPUs utilized            ( +-  4.19% )
            49,068 context-switches          #    0.029 M/sec                    ( +- 16.66% )
             8,303 CPU-migrations            #    0.005 M/sec                    ( +- 24.90% )
            17,397 page-faults               #    0.010 M/sec                    ( +-  0.46% )
     2,345,389,239 cycles                    #    1.377 GHz                      ( +-  4.61% ) [55.90%]
     1,884,503,527 stalled-cycles-frontend   #   80.35% frontend cycles idle     ( +-  5.67% ) [50.39%]
       743,919,737 stalled-cycles-backend    #   31.72% backend  cycles idle     ( +-  8.75% ) [49.91%]
     1,314,416,379 instructions              #    0.56  insns per cycle
                                             #    1.43  stalled cycles per insn  ( +-  2.53% ) [60.87%]
       272,592,567 branches                  #  160.003 M/sec                    ( +-  1.74% ) [56.56%]
         3,794,846 branch-misses             #    1.39% of all branches          ( +-  6.59% ) [58.50%]
       449,982,778 L1-dcache-loads           #  264.125 M/sec                    ( +-  2.47% ) [49.88%]
        22,404,961 L1-dcache-load-misses     #    4.98% of all L1-dcache hits    ( +-  6.08% ) [55.05%]
         6,204,750 LLC-loads                 #    3.642 M/sec                    ( +-  8.91% ) [43.75%]
         1,837,411 LLC-load-misses           #    1.078 M/sec                    ( +-  7.27% ) [12.07%]
       411,440,421 L1-icache-loads           #  241.502 M/sec                    ( +-  5.60% ) [36.52%]
        27,556,832 L1-icache-load-misses     #   16.175 M/sec                    ( +-  7.46% ) [46.72%]
       464,067,627 dTLB-loads                #  272.392 M/sec                    ( +-  4.46% ) [54.17%]
        10,765,648 dTLB-load-misses          #    6.319 M/sec                    ( +-  3.18% ) [48.68%]
     1,273,080,386 iTLB-loads                #  747.256 M/sec                    ( +-  3.38% ) [47.53%]
           117,481 iTLB-load-misses          #    0.069 M/sec                    ( +- 14.99% ) [47.01%]
         4,590,653 L1-dcache-prefetches      #    2.695 M/sec                    ( +-  4.49% ) [46.19%]
         1,712,660 L1-dcache-prefetch-misses #    1.005 M/sec                    ( +-  3.75% ) [44.82%]
        0.195622057  seconds time elapsed  ( +-  6.84% )
Also clean up the attribute construction code to be appending, and factor
it out into add_default_attributes().
Tweak the coverage percentage printout a bit, so that it's easier to view it
alongside the +- sttddev colum.
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Steven Rostedt <rostedt@goodmis.org>
Link: http://lkml.kernel.org/n/tip-to3kgu04449s64062val8b62@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-05-19 13:30:56 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (detailed_run < 3) | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Append very, very detailed run extra attributes: */ | 
					
						
							| 
									
										
											  
											
												perf stat: Initialize default events wrt exclude_{guest,host}
When no event is specified the tools use perf_evlist__add_default(), that will
call event_attr_init to initialize the KVM exclusion bits.
When the change was made to the tools so that by default guest samples would be
excluded, the changes were made just to the parsing routines and to
perf_evlist__add_default(), not to perf_evlist__add_attrs, that is used so far
just by perf stat to add multiple events, according to the level of detail
specified.
Recently the tools were changed to reconstruct the event name from all the
details in perf_event_attr, not just from .type and .config, but taking into
account all the feature bits (.exclude_{guest,host,user,kernel,etc},
.precise_ip, etc).
That is when we noticed that the default for perf stat wasn't the one for the
rest of the tools, i.e. the .exclude_guest bit wasn't being set.
I.e. the default, that doesn't call event_attr_init was showing the :HG
modifier:
  $ perf stat usleep 1
   Performance counter stats for 'usleep 1':
            0.942119 task-clock                #    0.454 CPUs utilized
                   1 context-switches          #    0.001 M/sec
                   0 CPU-migrations            #    0.000 K/sec
                 126 page-faults               #    0.134 M/sec
             693,193 cycles:HG                 #    0.736 GHz                     [40.11%]
             407,461 stalled-cycles-frontend:HG #   58.78% frontend cycles idle    [72.29%]
             365,403 stalled-cycles-backend:HG #   52.71% backend  cycles idle
             465,982 instructions:HG           #    0.67  insns per cycle
                                               #    0.87  stalled cycles per insn
              89,760 branches:HG               #   95.275 M/sec
               6,178 branch-misses:HG          #    6.88% of all branches
         0.002077228 seconds time elapsed
While if one explicitely specifies the same events, which will make the parsing code
to be called and thus event_attr_init is called:
  $ perf stat -e task-clock,context-switches,migrations,page-faults,cycles,stalled-cycles-frontend,stalled-cycles-backend,instructions,branches,branch-misses usleep 1
   Performance counter stats for 'usleep 1':
            1.040349 task-clock                #    0.500 CPUs utilized
                   2 context-switches          #    0.002 M/sec
                   0 CPU-migrations            #    0.000 K/sec
                 127 page-faults               #    0.122 M/sec
             587,966 cycles                    #    0.565 GHz                     [13.18%]
             459,167 stalled-cycles-frontend   #   78.09% frontend cycles idle
             390,249 stalled-cycles-backend    #   66.37% backend  cycles idle
             504,006 instructions              #    0.86  insns per cycle
                                               #    0.91  stalled cycles per insn
              96,455 branches                  #   92.714 M/sec
               6,522 branch-misses             #    6.76% of all branches         [96.12%]
         0.002078681 seconds time elapsed
Fix it by introducing a perf_evlist__add_default_attrs method that will call
evlist_attr_init in all the perf_event_attr entries before adding the events.
Reported-by: Ingo Molnar <mingo@kernel.org>
Cc: David Ahern <dsahern@gmail.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Namhyung Kim <namhyung@gmail.com>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Stephane Eranian <eranian@google.com>
Link: http://lkml.kernel.org/n/tip-4eysr236r0pgiyum9epwxw7s@git.kernel.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2012-05-30 13:53:54 -03:00
										 |  |  | 	return perf_evlist__add_default_attrs(evsel_list, very_very_detailed_attrs); | 
					
						
							| 
									
										
											  
											
												perf stat: Add -d -d and -d -d -d options to show more CPU events
Print even more detailed statistics if requested via perf stat -d:
       -d:          detailed events, L1 and LLC data cache
    -d -d:     more detailed events, dTLB and iTLB events
 -d -d -d:     very detailed events, adding prefetch events
Full output looks like this now:
 Performance counter stats for '/home/mingo/hackbench 10' (5 runs):
       1703.674707 task-clock                #    8.709 CPUs utilized            ( +-  4.19% )
            49,068 context-switches          #    0.029 M/sec                    ( +- 16.66% )
             8,303 CPU-migrations            #    0.005 M/sec                    ( +- 24.90% )
            17,397 page-faults               #    0.010 M/sec                    ( +-  0.46% )
     2,345,389,239 cycles                    #    1.377 GHz                      ( +-  4.61% ) [55.90%]
     1,884,503,527 stalled-cycles-frontend   #   80.35% frontend cycles idle     ( +-  5.67% ) [50.39%]
       743,919,737 stalled-cycles-backend    #   31.72% backend  cycles idle     ( +-  8.75% ) [49.91%]
     1,314,416,379 instructions              #    0.56  insns per cycle
                                             #    1.43  stalled cycles per insn  ( +-  2.53% ) [60.87%]
       272,592,567 branches                  #  160.003 M/sec                    ( +-  1.74% ) [56.56%]
         3,794,846 branch-misses             #    1.39% of all branches          ( +-  6.59% ) [58.50%]
       449,982,778 L1-dcache-loads           #  264.125 M/sec                    ( +-  2.47% ) [49.88%]
        22,404,961 L1-dcache-load-misses     #    4.98% of all L1-dcache hits    ( +-  6.08% ) [55.05%]
         6,204,750 LLC-loads                 #    3.642 M/sec                    ( +-  8.91% ) [43.75%]
         1,837,411 LLC-load-misses           #    1.078 M/sec                    ( +-  7.27% ) [12.07%]
       411,440,421 L1-icache-loads           #  241.502 M/sec                    ( +-  5.60% ) [36.52%]
        27,556,832 L1-icache-load-misses     #   16.175 M/sec                    ( +-  7.46% ) [46.72%]
       464,067,627 dTLB-loads                #  272.392 M/sec                    ( +-  4.46% ) [54.17%]
        10,765,648 dTLB-load-misses          #    6.319 M/sec                    ( +-  3.18% ) [48.68%]
     1,273,080,386 iTLB-loads                #  747.256 M/sec                    ( +-  3.38% ) [47.53%]
           117,481 iTLB-load-misses          #    0.069 M/sec                    ( +- 14.99% ) [47.01%]
         4,590,653 L1-dcache-prefetches      #    2.695 M/sec                    ( +-  4.49% ) [46.19%]
         1,712,660 L1-dcache-prefetch-misses #    1.005 M/sec                    ( +-  3.75% ) [44.82%]
        0.195622057  seconds time elapsed  ( +-  6.84% )
Also clean up the attribute construction code to be appending, and factor
it out into add_default_attributes().
Tweak the coverage percentage printout a bit, so that it's easier to view it
alongside the +- sttddev colum.
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Steven Rostedt <rostedt@goodmis.org>
Link: http://lkml.kernel.org/n/tip-to3kgu04449s64062val8b62@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-05-19 13:30:56 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-11 01:15:03 +03:00
										 |  |  | int cmd_stat(int argc, const char **argv, const char *prefix __maybe_unused) | 
					
						
							| 
									
										
										
										
											2009-05-26 09:17:18 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-10-23 13:40:14 +02:00
										 |  |  | 	bool append_file = false; | 
					
						
							| 
									
										
										
										
											2012-10-01 15:20:58 -03:00
										 |  |  | 	int output_fd = 0; | 
					
						
							|  |  |  | 	const char *output_name	= NULL; | 
					
						
							|  |  |  | 	const struct option options[] = { | 
					
						
							| 
									
										
										
										
											2013-08-21 16:47:26 -07:00
										 |  |  | 	OPT_BOOLEAN('T', "transaction", &transaction_run, | 
					
						
							|  |  |  | 		    "hardware transaction statistics"), | 
					
						
							| 
									
										
										
										
											2012-10-01 15:20:58 -03:00
										 |  |  | 	OPT_CALLBACK('e', "event", &evsel_list, "event", | 
					
						
							|  |  |  | 		     "event selector. use 'perf list' to list available events", | 
					
						
							|  |  |  | 		     parse_events_option), | 
					
						
							|  |  |  | 	OPT_CALLBACK(0, "filter", &evsel_list, "filter", | 
					
						
							|  |  |  | 		     "event filter", parse_filter), | 
					
						
							|  |  |  | 	OPT_BOOLEAN('i', "no-inherit", &no_inherit, | 
					
						
							|  |  |  | 		    "child tasks do not inherit counters"), | 
					
						
							|  |  |  | 	OPT_STRING('p', "pid", &target.pid, "pid", | 
					
						
							|  |  |  | 		   "stat events on existing process id"), | 
					
						
							|  |  |  | 	OPT_STRING('t', "tid", &target.tid, "tid", | 
					
						
							|  |  |  | 		   "stat events on existing thread id"), | 
					
						
							|  |  |  | 	OPT_BOOLEAN('a', "all-cpus", &target.system_wide, | 
					
						
							|  |  |  | 		    "system-wide collection from all CPUs"), | 
					
						
							|  |  |  | 	OPT_BOOLEAN('g', "group", &group, | 
					
						
							|  |  |  | 		    "put the counters into a counter group"), | 
					
						
							|  |  |  | 	OPT_BOOLEAN('c', "scale", &scale, "scale/normalize counters"), | 
					
						
							|  |  |  | 	OPT_INCR('v', "verbose", &verbose, | 
					
						
							|  |  |  | 		    "be more verbose (show counter open errors, etc)"), | 
					
						
							|  |  |  | 	OPT_INTEGER('r', "repeat", &run_count, | 
					
						
							| 
									
										
										
										
											2013-03-01 13:02:27 -05:00
										 |  |  | 		    "repeat command and print average + stddev (max: 100, forever: 0)"), | 
					
						
							| 
									
										
										
										
											2012-10-01 15:20:58 -03:00
										 |  |  | 	OPT_BOOLEAN('n', "null", &null_run, | 
					
						
							|  |  |  | 		    "null run - dont start any counters"), | 
					
						
							|  |  |  | 	OPT_INCR('d', "detailed", &detailed_run, | 
					
						
							|  |  |  | 		    "detailed run - start a lot of events"), | 
					
						
							|  |  |  | 	OPT_BOOLEAN('S', "sync", &sync_run, | 
					
						
							|  |  |  | 		    "call sync() before starting a run"), | 
					
						
							|  |  |  | 	OPT_CALLBACK_NOOPT('B', "big-num", NULL, NULL,  | 
					
						
							|  |  |  | 			   "print large numbers with thousands\' separators", | 
					
						
							|  |  |  | 			   stat__set_big_num), | 
					
						
							|  |  |  | 	OPT_STRING('C', "cpu", &target.cpu_list, "cpu", | 
					
						
							|  |  |  | 		    "list of cpus to monitor in system-wide"), | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 	OPT_SET_UINT('A', "no-aggr", &aggr_mode, | 
					
						
							|  |  |  | 		    "disable CPU count aggregation", AGGR_NONE), | 
					
						
							| 
									
										
										
										
											2012-10-01 15:20:58 -03:00
										 |  |  | 	OPT_STRING('x', "field-separator", &csv_sep, "separator", | 
					
						
							|  |  |  | 		   "print counts with custom separator"), | 
					
						
							|  |  |  | 	OPT_CALLBACK('G', "cgroup", &evsel_list, "name", | 
					
						
							|  |  |  | 		     "monitor event in cgroup name only", parse_cgroups), | 
					
						
							|  |  |  | 	OPT_STRING('o', "output", &output_name, "file", "output file name"), | 
					
						
							|  |  |  | 	OPT_BOOLEAN(0, "append", &append_file, "append to the output file"), | 
					
						
							|  |  |  | 	OPT_INTEGER(0, "log-fd", &output_fd, | 
					
						
							|  |  |  | 		    "log output to fd, instead of stderr"), | 
					
						
							| 
									
										
										
										
											2012-10-23 13:40:14 +02:00
										 |  |  | 	OPT_STRING(0, "pre", &pre_cmd, "command", | 
					
						
							|  |  |  | 			"command to run prior to the measured command"), | 
					
						
							|  |  |  | 	OPT_STRING(0, "post", &post_cmd, "command", | 
					
						
							|  |  |  | 			"command to run after to the measured command"), | 
					
						
							| 
									
										
											  
											
												perf stat: Add interval printing
This patch adds a new printing mode for perf stat.  It allows interval
printing. That means perf stat can now print event deltas at regular
time interval.  This is useful to detect phases in programs.
The -I option enables interval printing. It expects an interval duration
in milliseconds. Minimum is 100ms. Once, activated perf stat prints
events deltas since last printout. All modes are supported.
$ perf stat -I 1000 -e cycles noploop 10
noploop for 10 seconds
 #           time             counts events
      1.000109853      2,388,560,546 cycles
      2.000262846      2,393,332,358 cycles
      3.000354131      2,393,176,537 cycles
      4.000439503      2,393,203,790 cycles
      5.000527075      2,393,167,675 cycles
      6.000609052      2,393,203,670 cycles
      7.000691082      2,393,175,678 cycles
The output format makes it easy to feed into a plotting program such as
gnuplot when the -I option is used in combination with the -x option:
$ perf stat -x, -I 1000 -e cycles noploop 10
noploop for 10 seconds
1.000084113,2378775498,cycles
2.000245798,2391056897,cycles
3.000354445,2392089414,cycles
4.000459115,2390936603,cycles
5.000565341,2392108173,cycles
Signed-off-by: Stephane Eranian <eranian@google.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1359460064-3060-3-git-send-email-eranian@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2013-01-29 12:47:44 +01:00
										 |  |  | 	OPT_UINTEGER('I', "interval-print", &interval, | 
					
						
							|  |  |  | 		    "print counts at regular interval in ms (>= 100)"), | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:28 +01:00
										 |  |  | 	OPT_SET_UINT(0, "per-socket", &aggr_mode, | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 		     "aggregate counts per processor socket", AGGR_SOCKET), | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:29 +01:00
										 |  |  | 	OPT_SET_UINT(0, "per-core", &aggr_mode, | 
					
						
							|  |  |  | 		     "aggregate counts per physical processor core", AGGR_CORE), | 
					
						
							| 
									
										
										
										
											2013-08-02 17:41:11 -07:00
										 |  |  | 	OPT_UINTEGER('D', "delay", &initial_delay, | 
					
						
							|  |  |  | 		     "ms to wait before starting measurement after program start"), | 
					
						
							| 
									
										
										
										
											2012-10-01 15:20:58 -03:00
										 |  |  | 	OPT_END() | 
					
						
							|  |  |  | 	}; | 
					
						
							|  |  |  | 	const char * const stat_usage[] = { | 
					
						
							|  |  |  | 		"perf stat [<options>] [<command>]", | 
					
						
							|  |  |  | 		NULL | 
					
						
							|  |  |  | 	}; | 
					
						
							| 
									
										
										
										
											2013-11-01 16:33:15 +09:00
										 |  |  | 	int status = -EINVAL, run_idx; | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 	const char *mode; | 
					
						
							| 
									
										
										
										
											2009-06-13 14:57:28 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												perf stat: add perf stat -B to pretty print large numbers
It is hard to read very large numbers so provide an option to perf stat
to separate thousands using a separator. The patch leverages the locale
support of stdio. You need to set your LC_NUMERIC appropriately, for
instance LC_NUMERIC=en_US.UTF8. You need to pass -B to activate this
feature. This way existing scripts parsing the output do not need to be
changed. Here is an example.
$ perf stat noploop 2
noploop for 2 seconds
 Performance counter stats for 'noploop 2':
        1998.347031  task-clock-msecs         #      0.998 CPUs
                 61  context-switches         #      0.000 M/sec
                  0  CPU-migrations           #      0.000 M/sec
                118  page-faults              #      0.000 M/sec
      4,138,410,900  cycles                   #   2070.917 M/sec  (scaled from 70.01%)
      2,062,650,268  instructions             #      0.498 IPC    (scaled from 70.01%)
      2,057,653,466  branches                 #   1029.678 M/sec  (scaled from 70.01%)
             40,267  branch-misses            #      0.002 %      (scaled from 30.04%)
      2,055,961,348  cache-references         #   1028.831 M/sec  (scaled from 30.03%)
             53,725  cache-misses             #      0.027 M/sec  (scaled from 30.02%)
        2.001393933  seconds time elapsed
$ perf stat -B  noploop 2
noploop for 2 seconds
 Performance counter stats for 'noploop 2':
        1998.297883  task-clock-msecs         #      0.998 CPUs
                 59  context-switches         #      0.000 M/sec
                  0  CPU-migrations           #      0.000 M/sec
                119  page-faults              #      0.000 M/sec
      4,131,380,160  cycles                   #   2067.450 M/sec  (scaled from 70.01%)
      2,059,096,507  instructions             #      0.498 IPC    (scaled from 70.01%)
      2,054,681,303  branches                 #   1028.216 M/sec  (scaled from 70.01%)
             25,650  branch-misses            #      0.001 %      (scaled from 30.05%)
      2,056,283,014  cache-references         #   1029.017 M/sec  (scaled from 30.03%)
             47,097  cache-misses             #      0.024 M/sec  (scaled from 30.02%)
        2.001391016  seconds time elapsed
Cc: David S. Miller <davem@davemloft.net>
Cc: Frédéric Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Tom Zanussi <tzanussi@gmail.com>
LKML-Reference: <4bf28fe8.914ed80a.01ca.fffff5f5@mx.google.com>
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2010-05-18 15:00:01 +02:00
										 |  |  | 	setlocale(LC_ALL, ""); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-11 16:43:12 +09:00
										 |  |  | 	evsel_list = perf_evlist__new(); | 
					
						
							| 
									
										
										
										
											2011-01-11 20:56:53 -02:00
										 |  |  | 	if (evsel_list == NULL) | 
					
						
							|  |  |  | 		return -ENOMEM; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-22 23:04:12 +10:00
										 |  |  | 	argc = parse_options(argc, argv, options, stat_usage, | 
					
						
							|  |  |  | 		PARSE_OPT_STOP_AT_NON_OPTION); | 
					
						
							| 
									
										
											  
											
												perf stat: Add csv-style output
This patch adds an option (-x/--field-separator) to print counts using a
CSV-style output. The user can pass a custom separator. This makes it very easy
to import counts directly into your favorite spreadsheet without having to
write scripts.
Example:
$ perf stat --field-separator=,  -a -- sleep 1
4009.961740,task-clock-msecs
13,context-switches
2,CPU-migrations
189,page-faults
9596385684,cycles
3493659441,instructions
872897069,branches
41562,branch-misses
22424,cache-references
1289,cache-misses
Works also in non-aggregated mode:
$ perf stat -x ,  -a -A -- sleep 1
CPU0,1002.526168,task-clock-msecs
CPU1,1002.528365,task-clock-msecs
CPU2,1002.523360,task-clock-msecs
CPU3,1002.519878,task-clock-msecs
CPU0,1,context-switches
CPU1,5,context-switches
CPU2,5,context-switches
CPU3,6,context-switches
CPU0,0,CPU-migrations
CPU1,1,CPU-migrations
CPU2,0,CPU-migrations
CPU3,1,CPU-migrations
CPU0,2,page-faults
CPU1,6,page-faults
CPU2,9,page-faults
CPU3,174,page-faults
CPU0,2399439771,cycles
CPU1,2380369063,cycles
CPU2,2399142710,cycles
CPU3,2373161192,cycles
CPU0,872900618,instructions
CPU1,873030960,instructions
CPU2,872714525,instructions
CPU3,874460580,instructions
CPU0,221556839,branches
CPU1,218134342,branches
CPU2,218161730,branches
CPU3,218284093,branches
CPU0,18556,branch-misses
CPU1,1449,branch-misses
CPU2,3447,branch-misses
CPU3,12714,branch-misses
CPU0,8330,cache-references
CPU1,313844,cache-references
CPU2,47993728,cache-references
CPU3,826481,cache-references
CPU0,272,cache-misses
CPU1,5360,cache-misses
CPU2,1342193,cache-misses
CPU3,13992,cache-misses
This second version adds the ability to name a separator and uses
field-separator as the long option to be consistent with perf report.
Commiter note: Since we enabled --big-num by default in 201e0b0 and -x can't be
used with it, we need to notice if the user explicitely enabled or disabled -B,
add code to disable big_num if the user didn't explicitely set --big_num when
-x is used.
Cc: David S. Miller <davem@davemloft.net>
Cc: Frederik Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: paulus@samba.org
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Robert Richter <robert.richter@amd.com>
LKML-Reference: <4cf68aa7.0fedd80a.5294.1203@mx.google.com>
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2010-12-01 18:49:05 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 	output = stderr; | 
					
						
							|  |  |  | 	if (output_name && strcmp(output_name, "-")) | 
					
						
							|  |  |  | 		output = NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-07 17:14:00 -06:00
										 |  |  | 	if (output_name && output_fd) { | 
					
						
							|  |  |  | 		fprintf(stderr, "cannot use both --output and --log-fd\n"); | 
					
						
							| 
									
										
										
										
											2013-11-01 16:33:15 +09:00
										 |  |  | 		parse_options_usage(stat_usage, options, "o", 1); | 
					
						
							|  |  |  | 		parse_options_usage(NULL, options, "log-fd", 0); | 
					
						
							|  |  |  | 		goto out; | 
					
						
							| 
									
										
										
										
											2011-09-07 17:14:00 -06:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-05-15 13:11:11 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (output_fd < 0) { | 
					
						
							|  |  |  | 		fprintf(stderr, "argument to --log-fd must be a > 0\n"); | 
					
						
							| 
									
										
										
										
											2013-11-01 16:33:15 +09:00
										 |  |  | 		parse_options_usage(stat_usage, options, "log-fd", 0); | 
					
						
							|  |  |  | 		goto out; | 
					
						
							| 
									
										
										
										
											2012-05-15 13:11:11 +02:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 	if (!output) { | 
					
						
							|  |  |  | 		struct timespec tm; | 
					
						
							|  |  |  | 		mode = append_file ? "a" : "w"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		output = fopen(output_name, mode); | 
					
						
							|  |  |  | 		if (!output) { | 
					
						
							|  |  |  | 			perror("failed to create output file"); | 
					
						
							| 
									
										
										
										
											2012-08-26 12:24:44 -06:00
										 |  |  | 			return -1; | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		clock_gettime(CLOCK_REALTIME, &tm); | 
					
						
							|  |  |  | 		fprintf(output, "# started on %s\n", ctime(&tm.tv_sec)); | 
					
						
							| 
									
										
										
										
											2012-05-15 13:11:11 +02:00
										 |  |  | 	} else if (output_fd > 0) { | 
					
						
							| 
									
										
										
										
											2011-09-07 17:14:00 -06:00
										 |  |  | 		mode = append_file ? "a" : "w"; | 
					
						
							|  |  |  | 		output = fdopen(output_fd, mode); | 
					
						
							|  |  |  | 		if (!output) { | 
					
						
							|  |  |  | 			perror("Failed opening logfd"); | 
					
						
							|  |  |  | 			return -errno; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-07 17:14:03 -06:00
										 |  |  | 	if (csv_sep) { | 
					
						
							| 
									
										
											  
											
												perf stat: Add csv-style output
This patch adds an option (-x/--field-separator) to print counts using a
CSV-style output. The user can pass a custom separator. This makes it very easy
to import counts directly into your favorite spreadsheet without having to
write scripts.
Example:
$ perf stat --field-separator=,  -a -- sleep 1
4009.961740,task-clock-msecs
13,context-switches
2,CPU-migrations
189,page-faults
9596385684,cycles
3493659441,instructions
872897069,branches
41562,branch-misses
22424,cache-references
1289,cache-misses
Works also in non-aggregated mode:
$ perf stat -x ,  -a -A -- sleep 1
CPU0,1002.526168,task-clock-msecs
CPU1,1002.528365,task-clock-msecs
CPU2,1002.523360,task-clock-msecs
CPU3,1002.519878,task-clock-msecs
CPU0,1,context-switches
CPU1,5,context-switches
CPU2,5,context-switches
CPU3,6,context-switches
CPU0,0,CPU-migrations
CPU1,1,CPU-migrations
CPU2,0,CPU-migrations
CPU3,1,CPU-migrations
CPU0,2,page-faults
CPU1,6,page-faults
CPU2,9,page-faults
CPU3,174,page-faults
CPU0,2399439771,cycles
CPU1,2380369063,cycles
CPU2,2399142710,cycles
CPU3,2373161192,cycles
CPU0,872900618,instructions
CPU1,873030960,instructions
CPU2,872714525,instructions
CPU3,874460580,instructions
CPU0,221556839,branches
CPU1,218134342,branches
CPU2,218161730,branches
CPU3,218284093,branches
CPU0,18556,branch-misses
CPU1,1449,branch-misses
CPU2,3447,branch-misses
CPU3,12714,branch-misses
CPU0,8330,cache-references
CPU1,313844,cache-references
CPU2,47993728,cache-references
CPU3,826481,cache-references
CPU0,272,cache-misses
CPU1,5360,cache-misses
CPU2,1342193,cache-misses
CPU3,13992,cache-misses
This second version adds the ability to name a separator and uses
field-separator as the long option to be consistent with perf report.
Commiter note: Since we enabled --big-num by default in 201e0b0 and -x can't be
used with it, we need to notice if the user explicitely enabled or disabled -B,
add code to disable big_num if the user didn't explicitely set --big_num when
-x is used.
Cc: David S. Miller <davem@davemloft.net>
Cc: Frederik Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: paulus@samba.org
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Robert Richter <robert.richter@amd.com>
LKML-Reference: <4cf68aa7.0fedd80a.5294.1203@mx.google.com>
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2010-12-01 18:49:05 +02:00
										 |  |  | 		csv_output = true; | 
					
						
							| 
									
										
										
										
											2011-09-07 17:14:03 -06:00
										 |  |  | 		if (!strcmp(csv_sep, "\\t")) | 
					
						
							|  |  |  | 			csv_sep = "\t"; | 
					
						
							|  |  |  | 	} else | 
					
						
							| 
									
										
											  
											
												perf stat: Add csv-style output
This patch adds an option (-x/--field-separator) to print counts using a
CSV-style output. The user can pass a custom separator. This makes it very easy
to import counts directly into your favorite spreadsheet without having to
write scripts.
Example:
$ perf stat --field-separator=,  -a -- sleep 1
4009.961740,task-clock-msecs
13,context-switches
2,CPU-migrations
189,page-faults
9596385684,cycles
3493659441,instructions
872897069,branches
41562,branch-misses
22424,cache-references
1289,cache-misses
Works also in non-aggregated mode:
$ perf stat -x ,  -a -A -- sleep 1
CPU0,1002.526168,task-clock-msecs
CPU1,1002.528365,task-clock-msecs
CPU2,1002.523360,task-clock-msecs
CPU3,1002.519878,task-clock-msecs
CPU0,1,context-switches
CPU1,5,context-switches
CPU2,5,context-switches
CPU3,6,context-switches
CPU0,0,CPU-migrations
CPU1,1,CPU-migrations
CPU2,0,CPU-migrations
CPU3,1,CPU-migrations
CPU0,2,page-faults
CPU1,6,page-faults
CPU2,9,page-faults
CPU3,174,page-faults
CPU0,2399439771,cycles
CPU1,2380369063,cycles
CPU2,2399142710,cycles
CPU3,2373161192,cycles
CPU0,872900618,instructions
CPU1,873030960,instructions
CPU2,872714525,instructions
CPU3,874460580,instructions
CPU0,221556839,branches
CPU1,218134342,branches
CPU2,218161730,branches
CPU3,218284093,branches
CPU0,18556,branch-misses
CPU1,1449,branch-misses
CPU2,3447,branch-misses
CPU3,12714,branch-misses
CPU0,8330,cache-references
CPU1,313844,cache-references
CPU2,47993728,cache-references
CPU3,826481,cache-references
CPU0,272,cache-misses
CPU1,5360,cache-misses
CPU2,1342193,cache-misses
CPU3,13992,cache-misses
This second version adds the ability to name a separator and uses
field-separator as the long option to be consistent with perf report.
Commiter note: Since we enabled --big-num by default in 201e0b0 and -x can't be
used with it, we need to notice if the user explicitely enabled or disabled -B,
add code to disable big_num if the user didn't explicitely set --big_num when
-x is used.
Cc: David S. Miller <davem@davemloft.net>
Cc: Frederik Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: paulus@samba.org
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Robert Richter <robert.richter@amd.com>
LKML-Reference: <4cf68aa7.0fedd80a.5294.1203@mx.google.com>
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2010-12-01 18:49:05 +02:00
										 |  |  | 		csv_sep = DEFAULT_SEPARATOR; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/*
 | 
					
						
							|  |  |  | 	 * let the spreadsheet do the pretty-printing | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	if (csv_output) { | 
					
						
							| 
									
										
										
										
											2011-09-07 17:14:04 -06:00
										 |  |  | 		/* User explicitly passed -B? */ | 
					
						
							| 
									
										
											  
											
												perf stat: Add csv-style output
This patch adds an option (-x/--field-separator) to print counts using a
CSV-style output. The user can pass a custom separator. This makes it very easy
to import counts directly into your favorite spreadsheet without having to
write scripts.
Example:
$ perf stat --field-separator=,  -a -- sleep 1
4009.961740,task-clock-msecs
13,context-switches
2,CPU-migrations
189,page-faults
9596385684,cycles
3493659441,instructions
872897069,branches
41562,branch-misses
22424,cache-references
1289,cache-misses
Works also in non-aggregated mode:
$ perf stat -x ,  -a -A -- sleep 1
CPU0,1002.526168,task-clock-msecs
CPU1,1002.528365,task-clock-msecs
CPU2,1002.523360,task-clock-msecs
CPU3,1002.519878,task-clock-msecs
CPU0,1,context-switches
CPU1,5,context-switches
CPU2,5,context-switches
CPU3,6,context-switches
CPU0,0,CPU-migrations
CPU1,1,CPU-migrations
CPU2,0,CPU-migrations
CPU3,1,CPU-migrations
CPU0,2,page-faults
CPU1,6,page-faults
CPU2,9,page-faults
CPU3,174,page-faults
CPU0,2399439771,cycles
CPU1,2380369063,cycles
CPU2,2399142710,cycles
CPU3,2373161192,cycles
CPU0,872900618,instructions
CPU1,873030960,instructions
CPU2,872714525,instructions
CPU3,874460580,instructions
CPU0,221556839,branches
CPU1,218134342,branches
CPU2,218161730,branches
CPU3,218284093,branches
CPU0,18556,branch-misses
CPU1,1449,branch-misses
CPU2,3447,branch-misses
CPU3,12714,branch-misses
CPU0,8330,cache-references
CPU1,313844,cache-references
CPU2,47993728,cache-references
CPU3,826481,cache-references
CPU0,272,cache-misses
CPU1,5360,cache-misses
CPU2,1342193,cache-misses
CPU3,13992,cache-misses
This second version adds the ability to name a separator and uses
field-separator as the long option to be consistent with perf report.
Commiter note: Since we enabled --big-num by default in 201e0b0 and -x can't be
used with it, we need to notice if the user explicitely enabled or disabled -B,
add code to disable big_num if the user didn't explicitely set --big_num when
-x is used.
Cc: David S. Miller <davem@davemloft.net>
Cc: Frederik Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: paulus@samba.org
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Robert Richter <robert.richter@amd.com>
LKML-Reference: <4cf68aa7.0fedd80a.5294.1203@mx.google.com>
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2010-12-01 18:49:05 +02:00
										 |  |  | 		if (big_num_opt == 1) { | 
					
						
							|  |  |  | 			fprintf(stderr, "-B option not supported with -x\n"); | 
					
						
							| 
									
										
										
										
											2013-11-01 16:33:15 +09:00
										 |  |  | 			parse_options_usage(stat_usage, options, "B", 1); | 
					
						
							|  |  |  | 			parse_options_usage(NULL, options, "x", 1); | 
					
						
							|  |  |  | 			goto out; | 
					
						
							| 
									
										
											  
											
												perf stat: Add csv-style output
This patch adds an option (-x/--field-separator) to print counts using a
CSV-style output. The user can pass a custom separator. This makes it very easy
to import counts directly into your favorite spreadsheet without having to
write scripts.
Example:
$ perf stat --field-separator=,  -a -- sleep 1
4009.961740,task-clock-msecs
13,context-switches
2,CPU-migrations
189,page-faults
9596385684,cycles
3493659441,instructions
872897069,branches
41562,branch-misses
22424,cache-references
1289,cache-misses
Works also in non-aggregated mode:
$ perf stat -x ,  -a -A -- sleep 1
CPU0,1002.526168,task-clock-msecs
CPU1,1002.528365,task-clock-msecs
CPU2,1002.523360,task-clock-msecs
CPU3,1002.519878,task-clock-msecs
CPU0,1,context-switches
CPU1,5,context-switches
CPU2,5,context-switches
CPU3,6,context-switches
CPU0,0,CPU-migrations
CPU1,1,CPU-migrations
CPU2,0,CPU-migrations
CPU3,1,CPU-migrations
CPU0,2,page-faults
CPU1,6,page-faults
CPU2,9,page-faults
CPU3,174,page-faults
CPU0,2399439771,cycles
CPU1,2380369063,cycles
CPU2,2399142710,cycles
CPU3,2373161192,cycles
CPU0,872900618,instructions
CPU1,873030960,instructions
CPU2,872714525,instructions
CPU3,874460580,instructions
CPU0,221556839,branches
CPU1,218134342,branches
CPU2,218161730,branches
CPU3,218284093,branches
CPU0,18556,branch-misses
CPU1,1449,branch-misses
CPU2,3447,branch-misses
CPU3,12714,branch-misses
CPU0,8330,cache-references
CPU1,313844,cache-references
CPU2,47993728,cache-references
CPU3,826481,cache-references
CPU0,272,cache-misses
CPU1,5360,cache-misses
CPU2,1342193,cache-misses
CPU3,13992,cache-misses
This second version adds the ability to name a separator and uses
field-separator as the long option to be consistent with perf report.
Commiter note: Since we enabled --big-num by default in 201e0b0 and -x can't be
used with it, we need to notice if the user explicitely enabled or disabled -B,
add code to disable big_num if the user didn't explicitely set --big_num when
-x is used.
Cc: David S. Miller <davem@davemloft.net>
Cc: Frederik Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: paulus@samba.org
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Robert Richter <robert.richter@amd.com>
LKML-Reference: <4cf68aa7.0fedd80a.5294.1203@mx.google.com>
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2010-12-01 18:49:05 +02:00
										 |  |  | 		} else /* Nope, so disable big number formatting */ | 
					
						
							|  |  |  | 			big_num = false; | 
					
						
							|  |  |  | 	} else if (big_num_opt == 0) /* User passed --no-big-num */ | 
					
						
							|  |  |  | 		big_num = false; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-12 16:46:16 -03:00
										 |  |  | 	if (!argc && target__none(&target)) | 
					
						
							| 
									
										
										
										
											2009-05-26 09:17:18 +02:00
										 |  |  | 		usage_with_options(stat_usage, options); | 
					
						
							| 
									
										
										
										
											2013-09-30 07:37:37 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-01 13:02:27 -05:00
										 |  |  | 	if (run_count < 0) { | 
					
						
							| 
									
										
										
										
											2013-11-01 16:33:15 +09:00
										 |  |  | 		pr_err("Run count must be a positive number\n"); | 
					
						
							|  |  |  | 		parse_options_usage(stat_usage, options, "r", 1); | 
					
						
							|  |  |  | 		goto out; | 
					
						
							| 
									
										
										
										
											2013-03-01 13:02:27 -05:00
										 |  |  | 	} else if (run_count == 0) { | 
					
						
							|  |  |  | 		forever = true; | 
					
						
							|  |  |  | 		run_count = 1; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-04-20 15:37:32 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
											
												perf tool: Add cgroup support
This patch adds the ability to filter monitoring based on container groups
(cgroups) for both perf stat and perf record. It is possible to monitor
multiple cgroup in parallel. There is one cgroup per event. The cgroups to
monitor are passed via a new -G option followed by a comma separated list of
cgroup names.
The cgroup filesystem has to be mounted. Given a cgroup name, the perf tool
finds the corresponding directory in the cgroup filesystem and opens it. It
then passes that file descriptor to the kernel.
Example:
$ perf stat -B -a -e cycles:u,cycles:u,cycles:u -G test1,,test2 -- sleep 1
 Performance counter stats for 'sleep 1':
      2,368,667,414  cycles                   test1
      2,369,661,459  cycles
      <not counted>  cycles                   test2
        1.001856890  seconds time elapsed
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
LKML-Reference: <4d590290.825bdf0a.7d0a.4890@mx.google.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-02-14 11:20:01 +02:00
										 |  |  | 	/* no_aggr, cgroup are for system-wide only */ | 
					
						
							| 
									
										
										
										
											2013-11-12 16:46:16 -03:00
										 |  |  | 	if ((aggr_mode != AGGR_GLOBAL || nr_cgroups) && | 
					
						
							|  |  |  | 	    !target__has_cpu(&target)) { | 
					
						
							| 
									
										
										
											
												perf tool: Add cgroup support
This patch adds the ability to filter monitoring based on container groups
(cgroups) for both perf stat and perf record. It is possible to monitor
multiple cgroup in parallel. There is one cgroup per event. The cgroups to
monitor are passed via a new -G option followed by a comma separated list of
cgroup names.
The cgroup filesystem has to be mounted. Given a cgroup name, the perf tool
finds the corresponding directory in the cgroup filesystem and opens it. It
then passes that file descriptor to the kernel.
Example:
$ perf stat -B -a -e cycles:u,cycles:u,cycles:u -G test1,,test2 -- sleep 1
 Performance counter stats for 'sleep 1':
      2,368,667,414  cycles                   test1
      2,369,661,459  cycles
      <not counted>  cycles                   test2
        1.001856890  seconds time elapsed
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
LKML-Reference: <4d590290.825bdf0a.7d0a.4890@mx.google.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-02-14 11:20:01 +02:00
										 |  |  | 		fprintf(stderr, "both cgroup and no-aggregation " | 
					
						
							|  |  |  | 			"modes only available in system-wide mode\n"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-01 16:33:15 +09:00
										 |  |  | 		parse_options_usage(stat_usage, options, "G", 1); | 
					
						
							|  |  |  | 		parse_options_usage(NULL, options, "A", 1); | 
					
						
							|  |  |  | 		parse_options_usage(NULL, options, "a", 1); | 
					
						
							|  |  |  | 		goto out; | 
					
						
							| 
									
										
										
										
											2013-02-06 15:46:02 +01:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												perf stat: Add -d -d and -d -d -d options to show more CPU events
Print even more detailed statistics if requested via perf stat -d:
       -d:          detailed events, L1 and LLC data cache
    -d -d:     more detailed events, dTLB and iTLB events
 -d -d -d:     very detailed events, adding prefetch events
Full output looks like this now:
 Performance counter stats for '/home/mingo/hackbench 10' (5 runs):
       1703.674707 task-clock                #    8.709 CPUs utilized            ( +-  4.19% )
            49,068 context-switches          #    0.029 M/sec                    ( +- 16.66% )
             8,303 CPU-migrations            #    0.005 M/sec                    ( +- 24.90% )
            17,397 page-faults               #    0.010 M/sec                    ( +-  0.46% )
     2,345,389,239 cycles                    #    1.377 GHz                      ( +-  4.61% ) [55.90%]
     1,884,503,527 stalled-cycles-frontend   #   80.35% frontend cycles idle     ( +-  5.67% ) [50.39%]
       743,919,737 stalled-cycles-backend    #   31.72% backend  cycles idle     ( +-  8.75% ) [49.91%]
     1,314,416,379 instructions              #    0.56  insns per cycle
                                             #    1.43  stalled cycles per insn  ( +-  2.53% ) [60.87%]
       272,592,567 branches                  #  160.003 M/sec                    ( +-  1.74% ) [56.56%]
         3,794,846 branch-misses             #    1.39% of all branches          ( +-  6.59% ) [58.50%]
       449,982,778 L1-dcache-loads           #  264.125 M/sec                    ( +-  2.47% ) [49.88%]
        22,404,961 L1-dcache-load-misses     #    4.98% of all L1-dcache hits    ( +-  6.08% ) [55.05%]
         6,204,750 LLC-loads                 #    3.642 M/sec                    ( +-  8.91% ) [43.75%]
         1,837,411 LLC-load-misses           #    1.078 M/sec                    ( +-  7.27% ) [12.07%]
       411,440,421 L1-icache-loads           #  241.502 M/sec                    ( +-  5.60% ) [36.52%]
        27,556,832 L1-icache-load-misses     #   16.175 M/sec                    ( +-  7.46% ) [46.72%]
       464,067,627 dTLB-loads                #  272.392 M/sec                    ( +-  4.46% ) [54.17%]
        10,765,648 dTLB-load-misses          #    6.319 M/sec                    ( +-  3.18% ) [48.68%]
     1,273,080,386 iTLB-loads                #  747.256 M/sec                    ( +-  3.38% ) [47.53%]
           117,481 iTLB-load-misses          #    0.069 M/sec                    ( +- 14.99% ) [47.01%]
         4,590,653 L1-dcache-prefetches      #    2.695 M/sec                    ( +-  4.49% ) [46.19%]
         1,712,660 L1-dcache-prefetch-misses #    1.005 M/sec                    ( +-  3.75% ) [44.82%]
        0.195622057  seconds time elapsed  ( +-  6.84% )
Also clean up the attribute construction code to be appending, and factor
it out into add_default_attributes().
Tweak the coverage percentage printout a bit, so that it's easier to view it
alongside the +- sttddev colum.
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Steven Rostedt <rostedt@goodmis.org>
Link: http://lkml.kernel.org/n/tip-to3kgu04449s64062val8b62@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@elte.hu>
											
										 
											2011-05-19 13:30:56 +02:00
										 |  |  | 	if (add_default_attributes()) | 
					
						
							|  |  |  | 		goto out; | 
					
						
							| 
									
										
										
										
											2009-04-20 15:37:32 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-12 16:46:16 -03:00
										 |  |  | 	target__validate(&target); | 
					
						
							| 
									
										
										
										
											2011-01-03 17:53:33 -02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-07 14:09:04 +09:00
										 |  |  | 	if (perf_evlist__create_maps(evsel_list, &target) < 0) { | 
					
						
							| 
									
										
										
										
											2013-11-12 16:46:16 -03:00
										 |  |  | 		if (target__has_task(&target)) { | 
					
						
							| 
									
										
										
										
											2012-05-07 14:09:04 +09:00
										 |  |  | 			pr_err("Problems finding threads of monitor\n"); | 
					
						
							| 
									
										
										
										
											2013-11-01 16:33:15 +09:00
										 |  |  | 			parse_options_usage(stat_usage, options, "p", 1); | 
					
						
							|  |  |  | 			parse_options_usage(NULL, options, "t", 1); | 
					
						
							| 
									
										
										
										
											2013-11-12 16:46:16 -03:00
										 |  |  | 		} else if (target__has_cpu(&target)) { | 
					
						
							| 
									
										
										
										
											2012-05-07 14:09:04 +09:00
										 |  |  | 			perror("failed to parse CPUs map"); | 
					
						
							| 
									
										
										
										
											2013-11-01 16:33:15 +09:00
										 |  |  | 			parse_options_usage(stat_usage, options, "C", 1); | 
					
						
							|  |  |  | 			parse_options_usage(NULL, options, "a", 1); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		goto out; | 
					
						
							| 
									
										
										
										
											2011-01-03 17:49:48 -02:00
										 |  |  | 	} | 
					
						
							| 
									
										
											  
											
												perf stat: Add interval printing
This patch adds a new printing mode for perf stat.  It allows interval
printing. That means perf stat can now print event deltas at regular
time interval.  This is useful to detect phases in programs.
The -I option enables interval printing. It expects an interval duration
in milliseconds. Minimum is 100ms. Once, activated perf stat prints
events deltas since last printout. All modes are supported.
$ perf stat -I 1000 -e cycles noploop 10
noploop for 10 seconds
 #           time             counts events
      1.000109853      2,388,560,546 cycles
      2.000262846      2,393,332,358 cycles
      3.000354131      2,393,176,537 cycles
      4.000439503      2,393,203,790 cycles
      5.000527075      2,393,167,675 cycles
      6.000609052      2,393,203,670 cycles
      7.000691082      2,393,175,678 cycles
The output format makes it easy to feed into a plotting program such as
gnuplot when the -I option is used in combination with the -x option:
$ perf stat -x, -I 1000 -e cycles noploop 10
noploop for 10 seconds
1.000084113,2378775498,cycles
2.000245798,2391056897,cycles
3.000354445,2392089414,cycles
4.000459115,2390936603,cycles
5.000565341,2392108173,cycles
Signed-off-by: Stephane Eranian <eranian@google.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1359460064-3060-3-git-send-email-eranian@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2013-01-29 12:47:44 +01:00
										 |  |  | 	if (interval && interval < 100) { | 
					
						
							|  |  |  | 		pr_err("print interval must be >= 100ms\n"); | 
					
						
							| 
									
										
										
										
											2013-11-01 16:33:15 +09:00
										 |  |  | 		parse_options_usage(stat_usage, options, "I", 1); | 
					
						
							| 
									
										
										
										
											2014-01-03 15:56:06 -03:00
										 |  |  | 		goto out; | 
					
						
							| 
									
										
											  
											
												perf stat: Add interval printing
This patch adds a new printing mode for perf stat.  It allows interval
printing. That means perf stat can now print event deltas at regular
time interval.  This is useful to detect phases in programs.
The -I option enables interval printing. It expects an interval duration
in milliseconds. Minimum is 100ms. Once, activated perf stat prints
events deltas since last printout. All modes are supported.
$ perf stat -I 1000 -e cycles noploop 10
noploop for 10 seconds
 #           time             counts events
      1.000109853      2,388,560,546 cycles
      2.000262846      2,393,332,358 cycles
      3.000354131      2,393,176,537 cycles
      4.000439503      2,393,203,790 cycles
      5.000527075      2,393,167,675 cycles
      6.000609052      2,393,203,670 cycles
      7.000691082      2,393,175,678 cycles
The output format makes it easy to feed into a plotting program such as
gnuplot when the -I option is used in combination with the -x option:
$ perf stat -x, -I 1000 -e cycles noploop 10
noploop for 10 seconds
1.000084113,2378775498,cycles
2.000245798,2391056897,cycles
3.000354445,2392089414,cycles
4.000459115,2390936603,cycles
5.000565341,2392108173,cycles
Signed-off-by: Stephane Eranian <eranian@google.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1359460064-3060-3-git-send-email-eranian@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2013-01-29 12:47:44 +01:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-05-28 12:00:01 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-18 11:24:21 -03:00
										 |  |  | 	if (perf_evlist__alloc_stats(evsel_list, interval)) | 
					
						
							| 
									
										
										
										
											2014-01-03 15:56:06 -03:00
										 |  |  | 		goto out; | 
					
						
							| 
									
										
										
										
											2010-03-18 11:36:05 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 	if (perf_stat_init_aggr_mode()) | 
					
						
							| 
									
										
										
										
											2014-01-03 15:56:06 -03:00
										 |  |  | 		goto out; | 
					
						
							| 
									
										
										
										
											2013-02-14 13:57:27 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-15 11:03:23 +02:00
										 |  |  | 	/*
 | 
					
						
							|  |  |  | 	 * We dont want to block the signals - that would cause | 
					
						
							|  |  |  | 	 * child tasks to inherit that and Ctrl-C would not work. | 
					
						
							|  |  |  | 	 * What we want is for Ctrl-C to work in the exec()-ed | 
					
						
							|  |  |  | 	 * task, but being ignored by perf stat itself: | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2009-06-10 15:55:59 +02:00
										 |  |  | 	atexit(sig_atexit); | 
					
						
							| 
									
										
										
										
											2013-03-01 13:02:27 -05:00
										 |  |  | 	if (!forever) | 
					
						
							|  |  |  | 		signal(SIGINT,  skip_signal); | 
					
						
							| 
									
										
											  
											
												perf stat: Add interval printing
This patch adds a new printing mode for perf stat.  It allows interval
printing. That means perf stat can now print event deltas at regular
time interval.  This is useful to detect phases in programs.
The -I option enables interval printing. It expects an interval duration
in milliseconds. Minimum is 100ms. Once, activated perf stat prints
events deltas since last printout. All modes are supported.
$ perf stat -I 1000 -e cycles noploop 10
noploop for 10 seconds
 #           time             counts events
      1.000109853      2,388,560,546 cycles
      2.000262846      2,393,332,358 cycles
      3.000354131      2,393,176,537 cycles
      4.000439503      2,393,203,790 cycles
      5.000527075      2,393,167,675 cycles
      6.000609052      2,393,203,670 cycles
      7.000691082      2,393,175,678 cycles
The output format makes it easy to feed into a plotting program such as
gnuplot when the -I option is used in combination with the -x option:
$ perf stat -x, -I 1000 -e cycles noploop 10
noploop for 10 seconds
1.000084113,2378775498,cycles
2.000245798,2391056897,cycles
3.000354445,2392089414,cycles
4.000459115,2390936603,cycles
5.000565341,2392108173,cycles
Signed-off-by: Stephane Eranian <eranian@google.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1359460064-3060-3-git-send-email-eranian@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
											
										 
											2013-01-29 12:47:44 +01:00
										 |  |  | 	signal(SIGCHLD, skip_signal); | 
					
						
							| 
									
										
										
										
											2009-05-15 11:03:23 +02:00
										 |  |  | 	signal(SIGALRM, skip_signal); | 
					
						
							|  |  |  | 	signal(SIGABRT, skip_signal); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-13 14:57:28 +02:00
										 |  |  | 	status = 0; | 
					
						
							| 
									
										
										
										
											2013-03-01 13:02:27 -05:00
										 |  |  | 	for (run_idx = 0; forever || run_idx < run_count; run_idx++) { | 
					
						
							| 
									
										
										
										
											2009-06-13 14:57:28 +02:00
										 |  |  | 		if (run_count != 1 && verbose) | 
					
						
							| 
									
										
										
										
											2011-08-15 22:22:33 +02:00
										 |  |  | 			fprintf(output, "[ perf stat: executing run #%d ... ]\n", | 
					
						
							|  |  |  | 				run_idx + 1); | 
					
						
							| 
									
										
										
										
											2011-04-28 18:17:11 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-13 14:57:28 +02:00
										 |  |  | 		status = run_perf_stat(argc, argv); | 
					
						
							| 
									
										
										
										
											2013-03-01 13:02:27 -05:00
										 |  |  | 		if (forever && status != -1) { | 
					
						
							|  |  |  | 			print_stat(argc, argv); | 
					
						
							| 
									
										
										
										
											2013-03-18 11:24:21 -03:00
										 |  |  | 			perf_stat__reset_stats(evsel_list); | 
					
						
							| 
									
										
										
										
											2013-03-01 13:02:27 -05:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-06-13 14:57:28 +02:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-01 13:02:27 -05:00
										 |  |  | 	if (!forever && status != -1 && !interval) | 
					
						
							| 
									
										
										
										
											2010-03-22 13:10:28 -03:00
										 |  |  | 		print_stat(argc, argv); | 
					
						
							| 
									
										
										
										
											2013-03-18 11:24:21 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	perf_evlist__free_stats(evsel_list); | 
					
						
							| 
									
										
										
										
											2011-02-01 16:18:10 -02:00
										 |  |  | out: | 
					
						
							|  |  |  | 	perf_evlist__delete(evsel_list); | 
					
						
							| 
									
										
										
										
											2009-06-13 14:57:28 +02:00
										 |  |  | 	return status; | 
					
						
							| 
									
										
										
										
											2009-04-20 15:37:32 +02:00
										 |  |  | } |