Arnaldo Carvalho de Melo 
							
						 
					 
					
						
						
							
						
						d704ebdae4 
					 
					
						
						
							
							perf tools: tool->finished_round() doesn't need perf_session  
						
						... 
						
						
						
						It is all about flushing the ordered queue or piping it thru, no need
for a perf_session pointer.
Cc: Adrian Hunter <adrian.hunter@intel.com >
Cc: Borislav Petkov <bp@suse.de >
Cc: David Ahern <dsahern@gmail.com >
Cc: Don Zickus <dzickus@redhat.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Jiri Olsa <jolsa@redhat.com >
Cc: Namhyung Kim <namhyung@kernel.org >
Cc: Stephane Eranian <eranian@google.com >
Link: http://lkml.kernel.org/n/tip-g47fx3ys0t9271cp0dcabjc7@git.kernel.org 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2015-03-12 12:39:49 -03:00 
						 
				 
			
				
					
						
							
							
								Arnaldo Carvalho de Melo 
							
						 
					 
					
						
						
							
						
						d10eb1eb76 
					 
					
						
						
							
							perf ordered_events: Allow tools to specify a deliver method  
						
						... 
						
						
						
						So that we can simplify the deliver method to pass just:
 (ordered_events, ordered_event, sample);
Cc: Adrian Hunter <adrian.hunter@intel.com >
Cc: Borislav Petkov <bp@suse.de >
Cc: David Ahern <dsahern@gmail.com >
Cc: Don Zickus <dzickus@redhat.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Jiri Olsa <jolsa@redhat.com >
Cc: Namhyung Kim <namhyung@kernel.org >
Cc: Stephane Eranian <eranian@google.com >
Link: http://lkml.kernel.org/n/tip-j0s4bpxs5qza5tnkvjwom9rw@git.kernel.org 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2015-03-12 12:39:46 -03:00 
						 
				 
			
				
					
						
							
							
								Arnaldo Carvalho de Melo 
							
						 
					 
					
						
						
							
						
						b7b61cbebd 
					 
					
						
						
							
							perf ordered_events: Shorten function signatures  
						
						... 
						
						
						
						By keeping pointers to machines, evlist and tool in ordered_events.
Cc: Adrian Hunter <adrian.hunter@intel.com >
Cc: Borislav Petkov <bp@suse.de >
Cc: David Ahern <dsahern@gmail.com >
Cc: Don Zickus <dzickus@redhat.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Jiri Olsa <jolsa@redhat.com >
Cc: Namhyung Kim <namhyung@kernel.org >
Cc: Stephane Eranian <eranian@google.com >
Link: http://lkml.kernel.org/n/tip-0c6huyaf59mqtm2ek9pmposl@git.kernel.org 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2015-03-11 10:17:09 -03:00 
						 
				 
			
				
					
						
							
							
								Arnaldo Carvalho de Melo 
							
						 
					 
					
						
						
							
						
						fa713a4eb9 
					 
					
						
						
							
							perf ordered_events: Untangle from perf_session  
						
						... 
						
						
						
						For use by tools that are not perf.data based, as maybe 'perf trace' in
live mode.
Cc: Adrian Hunter <adrian.hunter@intel.com >
Cc: Borislav Petkov <bp@suse.de >
Cc: David Ahern <dsahern@gmail.com >
Cc: Don Zickus <dzickus@redhat.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Jiri Olsa <jolsa@redhat.com >
Cc: Namhyung Kim <namhyung@kernel.org >
Cc: Stephane Eranian <eranian@google.com >
Link: http://lkml.kernel.org/n/tip-nedqe7cmii5w82etfi36urfz@git.kernel.org 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2015-03-11 10:16:50 -03:00 
						 
				 
			
				
					
						
							
							
								Arnaldo Carvalho de Melo 
							
						 
					 
					
						
						
							
						
						f3b623b849 
					 
					
						
						
							
							perf tools: Reference count struct thread  
						
						... 
						
						
						
						We need to do that to stop accumulating entries in the dead_threads
linked list, i.e. we were keeping references to threads in struct hists
that continue to exist even after a thread exited and was removed from
the machine threads rbtree.
We still keep the dead_threads list, but just for debugging, allowing us
to iterate at any given point over the threads that still are referenced
by things like struct hist_entry.
Cc: Adrian Hunter <adrian.hunter@intel.com >
Cc: Borislav Petkov <bp@suse.de >
Cc: David Ahern <dsahern@gmail.com >
Cc: Don Zickus <dzickus@redhat.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Jiri Olsa <jolsa@redhat.com >
Cc: Namhyung Kim <namhyung@kernel.org >
Cc: Stephane Eranian <eranian@google.com >
Link: http://lkml.kernel.org/n/tip-3ejvfyed0r7ue61dkurzjux4@git.kernel.org 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2015-03-03 00:17:08 -03:00 
						 
				 
			
				
					
						
							
							
								Arnaldo Carvalho de Melo 
							
						 
					 
					
						
						
							
						
						9fa8727aa4 
					 
					
						
						
							
							perf session: Remove perf_session from dump_event  
						
						... 
						
						
						
						All it wants is session->evlist.
Cc: Adrian Hunter <adrian.hunter@intel.com >
Cc: Borislav Petkov <bp@suse.de >
Cc: David Ahern <dsahern@gmail.com >
Cc: Don Zickus <dzickus@redhat.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Jiri Olsa <jolsa@redhat.com >
Cc: Mike Galbraith <efault@gmx.de >
Cc: Namhyung Kim <namhyung@kernel.org >
Cc: Peter Zijlstra <peterz@infradead.org >
Cc: Stephane Eranian <eranian@google.com >
Link: http://lkml.kernel.org/n/tip-6w9663gka3jb1j1rfxxd5jcq@git.kernel.org 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2015-02-22 22:23:46 -03:00 
						 
				 
			
				
					
						
							
							
								Arnaldo Carvalho de Melo 
							
						 
					 
					
						
						
							
						
						313e53b08e 
					 
					
						
						
							
							perf session: Remove perf_session from some deliver event routines  
						
						... 
						
						
						
						Further untangling perf_session from plain event delivery routines.
Cc: Adrian Hunter <adrian.hunter@intel.com >
Cc: Borislav Petkov <bp@suse.de >
Cc: David Ahern <dsahern@gmail.com >
Cc: Don Zickus <dzickus@redhat.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Jiri Olsa <jolsa@redhat.com >
Cc: Mike Galbraith <efault@gmx.de >
Cc: Namhyung Kim <namhyung@kernel.org >
Cc: Peter Zijlstra <peterz@infradead.org >
Cc: Stephane Eranian <eranian@google.com >
Link: http://lkml.kernel.org/n/tip-cvz8e6pwyogs4w14582iis9w@git.kernel.org 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2015-02-22 22:23:40 -03:00 
						 
				 
			
				
					
						
							
							
								Arnaldo Carvalho de Melo 
							
						 
					 
					
						
						
							
						
						ccda068f96 
					 
					
						
						
							
							perf session: Remove perf_session from warn_errors signature  
						
						... 
						
						
						
						Cc: Adrian Hunter <adrian.hunter@intel.com >
Cc: Borislav Petkov <bp@suse.de >
Cc: David Ahern <dsahern@gmail.com >
Cc: Don Zickus <dzickus@redhat.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Jiri Olsa <jolsa@redhat.com >
Cc: Mike Galbraith <efault@gmx.de >
Cc: Namhyung Kim <namhyung@kernel.org >
Cc: Peter Zijlstra <peterz@infradead.org >
Cc: Stephane Eranian <eranian@google.com >
Link: http://lkml.kernel.org/n/tip-pxxm1liohog3d6i826x8sud8@git.kernel.org 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2015-02-22 22:23:23 -03:00 
						 
				 
			
				
					
						
							
							
								Arnaldo Carvalho de Melo 
							
						 
					 
					
						
						
							
						
						75be989a7a 
					 
					
						
						
							
							perf evlist: Adopt events_stats from perf_session  
						
						... 
						
						
						
						For tools that don't deal with perf.data files, thus do not need to
use perf_session.
Cc: Adrian Hunter <adrian.hunter@intel.com >
Cc: Borislav Petkov <bp@suse.de >
Cc: David Ahern <dsahern@gmail.com >
Cc: Don Zickus <dzickus@redhat.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Jiri Olsa <jolsa@redhat.com >
Cc: Mike Galbraith <efault@gmx.de >
Cc: Namhyung Kim <namhyung@kernel.org >
Cc: Peter Zijlstra <peterz@infradead.org >
Cc: Stephane Eranian <eranian@google.com >
Link: http://lkml.kernel.org/n/tip-kglq67gvauq9tak02a4se00r@git.kernel.org 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2015-02-22 22:22:57 -03:00 
						 
				 
			
				
					
						
							
							
								Arnaldo Carvalho de Melo 
							
						 
					 
					
						
						
							
						
						54245fdc35 
					 
					
						
						
							
							perf session: Remove wrappers to machines__find  
						
						... 
						
						
						
						Start to untangle session from delivering samples, as there are
tools that want to use ordered_events and don't use perf_session at all.
Cc: Adrian Hunter <adrian.hunter@intel.com >
Cc: Borislav Petkov <bp@suse.de >
Cc: David Ahern <dsahern@gmail.com >
Cc: Don Zickus <dzickus@redhat.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Jiri Olsa <jolsa@redhat.com >
Cc: Mike Galbraith <efault@gmx.de >
Cc: Namhyung Kim <namhyung@kernel.org >
Cc: Peter Zijlstra <peterz@infradead.org >
Cc: Stephane Eranian <eranian@google.com >
Link: http://lkml.kernel.org/n/tip-rn4pk3pjxd78sgzrkn19tktp@git.kernel.org 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2015-02-22 22:22:41 -03:00 
						 
				 
			
				
					
						
							
							
								Kan Liang 
							
						 
					 
					
						
						
							
						
						384b60557b 
					 
					
						
						
							
							perf tools: Construct LBR call chain  
						
						... 
						
						
						
						LBR call stack only has user-space callchains. It is output in the
PERF_SAMPLE_BRANCH_STACK data format. For kernel callchains, it's
still in the form of PERF_SAMPLE_CALLCHAIN.
The perf tool has to handle both data sources to construct a
complete callstack.
For the "perf report -D" option, both lbr and fp information will be
displayed.
A new call chain recording option "lbr" is introduced into the perf
tool for LBR call stack. The user can use --call-graph lbr to get
the call stack information from hardware.
Here are some examples.
When profiling bc(1) on Fedora 19:
  echo 'scale=2000; 4*a(1)' > cmd; perf record --call-graph lbr bc -l < cmd
If enabling LBR, perf report output looks like:
    50.36%       bc  bc                 [.] bc_divide
                 |
                 --- bc_divide
                     execute
                     run_code
                     yyparse
                     main
                     __libc_start_main
                     _start
    33.66%       bc  bc                 [.] _one_mult
                 |
                 --- _one_mult
                     bc_divide
                     execute
                     run_code
                     yyparse
                     main
                     __libc_start_main
                     _start
     7.62%       bc  bc                 [.] _bc_do_add
                 |
                 --- _bc_do_add
                    |
                    |--99.89%-- 0x2000186a8
                     --0.11%-- [...]
     6.83%       bc  bc                 [.] _bc_do_sub
                 |
                 --- _bc_do_sub
                    |
                    |--99.94%-- bc_add
                    |          execute
                    |          run_code
                    |          yyparse
                    |          main
                    |          __libc_start_main
                    |          _start
                     --0.06%-- [...]
     0.46%       bc  libc-2.17.so       [.] __memset_sse2
                 |
                 --- __memset_sse2
                    |
                    |--54.13%-- bc_new_num
                    |          |
                    |          |--51.00%-- bc_divide
                    |          |          execute
                    |          |          run_code
                    |          |          yyparse
                    |          |          main
                    |          |          __libc_start_main
                    |          |          _start
                    |          |
                    |          |--30.46%-- _bc_do_sub
                    |          |          bc_add
                    |          |          execute
                    |          |          run_code
                    |          |          yyparse
                    |          |          main
                    |          |          __libc_start_main
                    |          |          _start
                    |          |
                    |           --18.55%-- _bc_do_add
                    |                     bc_add
                    |                     execute
                    |                     run_code
                    |                     yyparse
                    |                     main
                    |                     __libc_start_main
                    |                     _start
                    |
                     --45.87%-- bc_divide
                               execute
                               run_code
                               yyparse
                               main
                               __libc_start_main
                               _start
If using FP, perf report output looks like:
  echo 'scale=2000; 4*a(1)' > cmd; perf record --call-graph fp bc -l < cmd
    50.49%       bc  bc                 [.] bc_divide
                 |
                 --- bc_divide
    33.57%       bc  bc                 [.] _one_mult
                 |
                 --- _one_mult
     7.61%       bc  bc                 [.] _bc_do_add
                 |
                 --- _bc_do_add
                     0x2000186a8
     6.88%       bc  bc                 [.] _bc_do_sub
                 |
                 --- _bc_do_sub
     0.42%       bc  libc-2.17.so       [.] __memcpy_ssse3_back
                 |
                 --- __memcpy_ssse3_back
If using LBR, perf report -D output looks like:
3458145275743 0x2fd750 [0xd8]: PERF_RECORD_SAMPLE(IP, 0x2): 9748/9748: 0x408ea8 period: 609644 addr: 0
... LBR call chain: nr:8
.....  0: fffffffffffffe00
.....  1: 0000000000408e50
.....  2: 000000000040a458
.....  3: 000000000040562e
.....  4: 0000000000408590
.....  5: 00000000004022c0
.....  6: 00000000004015dd
.....  7: 0000003d1cc21b43
... FP chain: nr:2
.....  0: fffffffffffffe00
.....  1: 0000000000408ea8
 ... thread: bc:9748
 ...... dso: /usr/bin/bc
The LBR call stack has the following known limitations:
 - Zero length calls are not filtered out by the hardware
 - Exception handing such as setjmp/longjmp will have calls/returns not
   match
 - Pushing different return address onto the stack will have
   calls/returns not match
 - If callstack is deeper than the LBR, only the last entries are
   captured
Tested-by: Jiri Olsa <jolsa@kernel.org >
Signed-off-by: Kan Liang <kan.liang@intel.com >
Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org >
Cc: Adrian Hunter <adrian.hunter@intel.com >
Cc: Arnaldo Carvalho de Melo <acme@kernel.org >
Cc: Borislav Petkov <bp@suse.de >
Cc: David Ahern <dsahern@gmail.com >
Cc: Don Zickus <dzickus@redhat.com >
Cc: Linus Torvalds <torvalds@linux-foundation.org >
Cc: Namhyung Kim <namhyung@kernel.org >
Cc: Paul Mackerras <paulus@samba.org >
Cc: Simon Que <sque@chromium.org >
Cc: Stephane Eranian <eranian@google.com >
Link: http://lkml.kernel.org/r/1420482185-29830-3-git-send-email-kan.liang@intel.com 
Signed-off-by: Ingo Molnar <mingo@kernel.org > 
						
						
					 
					
						2015-02-18 17:16:18 +01:00 
						 
				 
			
				
					
						
							
							
								Namhyung Kim 
							
						 
					 
					
						
						
							
						
						4ac30cf74b 
					 
					
						
						
							
							perf tools: Do not use __perf_session__process_events() directly  
						
						... 
						
						
						
						It's only used for perf record to process build-id because its file size
it's not fixed at this time due to remaining header features.
However data offset and size is available so that we can use the
perf_session__process_events() once we set the file size as the current
offset like for now.
Signed-off-by: Namhyung Kim <namhyung@kernel.org >
Cc: Adrian Hunter <adrian.hunter@intel.com >
Cc: Andi Kleen <andi@firstfloor.org >
Cc: David Ahern <dsahern@gmail.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Jiri Olsa <jolsa@redhat.com >
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl >
Cc: Stephane Eranian <eranian@google.com >
Link: http://lkml.kernel.org/r/1422518843-25818-3-git-send-email-namhyung@kernel.org 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2015-01-29 16:36:32 -03:00 
						 
				 
			
				
					
						
							
							
								Arnaldo Carvalho de Melo 
							
						 
					 
					
						
						
							
						
						48000a1aed 
					 
					
						
						
							
							perf tools: Remove EOL whitespaces  
						
						... 
						
						
						
						Janitorial stuff: boredom moment.
Cc: Adrian Hunter <adrian.hunter@intel.com >
Cc: Borislav Petkov <bp@suse.de >
Cc: David Ahern <dsahern@gmail.com >
Cc: Don Zickus <dzickus@redhat.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Jiri Olsa <jolsa@redhat.com >
Cc: Mike Galbraith <efault@gmx.de >
Cc: Namhyung Kim <namhyung@kernel.org >
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-u70i7shys3kths4hzru72bha@git.kernel.org 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2015-01-21 13:24:31 -03:00 
						 
				 
			
				
					
						
							
							
								Linus Torvalds 
							
						 
					 
					
						
						
							
						
						bee2782f30 
					 
					
						
						
							
							Merge branch 'perf-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip  
						
						... 
						
						
						
						Pull leftover perf fixes from Ingo Molnar:
 "Two perf fixes left over from the previous cycle"
* 'perf-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
  perf session: Do not fail on processing out of order event
  x86/asm/traps: Disable tracing and kprobes in fixup_bad_iret and sync_regs 
						
						
					 
					
						2014-12-09 21:18:06 -08:00 
						 
				 
			
				
					
						
							
							
								Jiri Olsa 
							
						 
					 
					
						
						
							
						
						f61ff6c06d 
					 
					
						
						
							
							perf session: Do not fail on processing out of order event  
						
						... 
						
						
						
						Linus reported perf report command being interrupted due to processing
of 'out of order' event, with following error:
  Timestamp below last timeslice flush
  0x5733a8 [0x28]: failed to process type: 3
I could reproduce the issue and in my case it was caused by one CPU
(mmap) being behind during record and userspace mmap reader seeing the
data after other CPUs data were already stored.
This is expected under some circumstances because we need to limit the
number of events that we queue for reordering when we receive a
PERF_RECORD_FINISHED_ROUND or when we force flush due to memory
pressure.
Reported-by: Linus Torvalds <torvalds@linux-foundation.org >
Signed-off-by: Jiri Olsa <jolsa@kernel.org >
Acked-by: Ingo Molnar <mingo@kernel.org >
Cc: Andi Kleen <ak@linux.intel.com >
Cc: Corey Ashford <cjashfor@linux.vnet.ibm.com >
Cc: David Ahern <dsahern@gmail.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Ingo Molnar <mingo@kernel.org >
Cc: Linus Torvalds <torvalds@linux-foundation.org >
Cc: Matt Fleming <matt.fleming@intel.com >
Cc: Namhyung Kim <namhyung@kernel.org >
Cc: Paul Mackerras <paulus@samba.org >
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl >
Cc: Stephane Eranian <eranian@google.com >
Link: http://lkml.kernel.org/r/1417016371-30249-1-git-send-email-jolsa@kernel.org 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2014-11-28 18:19:37 -03:00 
						 
				 
			
				
					
						
							
							
								Stephane Eranian 
							
						 
					 
					
						
						
							
						
						6a21c0b5c2 
					 
					
						
						
							
							perf tools: Add core support for sampling intr machine state regs  
						
						... 
						
						
						
						Add the infrastructure to setup, collect and report the interrupt
machine state regs which can be captured by the kernel.
Signed-off-by: Stephane Eranian <eranian@google.com >
Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org >
Cc: cebbert.lkml@gmail.com 
Cc: Adrian Hunter <adrian.hunter@intel.com >
Cc: Andi Kleen <ak@linux.intel.com >
Cc: Arnaldo Carvalho de Melo <acme@kernel.org >
Cc: David Ahern <dsahern@gmail.com >
Cc: Don Zickus <dzickus@redhat.com >
Cc: Jean Pihet <jean.pihet@linaro.org >
Cc: Jiri Olsa <jolsa@kernel.org >
Cc: Jiri Olsa <jolsa@redhat.com >
Cc: Linus Torvalds <torvalds@linux-foundation.org >
Cc: Namhyung Kim <namhyung@kernel.org >
Cc: Paul Mackerras <paulus@samba.org >
Cc: Stephane Eranian <eranian@google.com >
Cc: Waiman Long <Waiman.Long@hp.com >
Cc: Wang Nan <wangnan0@huawei.com >
Link: http://lkml.kernel.org/r/1411559322-16548-4-git-send-email-eranian@google.com 
Signed-off-by: Ingo Molnar <mingo@kernel.org > 
						
						
					 
					
						2014-11-16 11:41:59 +01:00 
						 
				 
			
				
					
						
							
							
								Adrian Hunter 
							
						 
					 
					
						
						
							
						
						a293829df7 
					 
					
						
						
							
							perf session: Add perf_session__deliver_synth_event()  
						
						... 
						
						
						
						Add a function to deliver synthesized events from within a session.
Intel PT decoding works by synthesizing events (primarily branch events)
that can then be consumed by existing tools.  This function will be used
to deliver those events.
Signed-off-by: Adrian Hunter <adrian.hunter@intel.com >
Cc: David Ahern <dsahern@gmail.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Jiri Olsa <jolsa@redhat.com >
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/r/1414417770-18602-3-git-send-email-adrian.hunter@intel.com 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2014-10-29 11:36:15 -02:00 
						 
				 
			
				
					
						
							
							
								Arnaldo Carvalho de Melo 
							
						 
					 
					
						
						
							
						
						cba9b847f6 
					 
					
						
						
							
							perf tools: Use evlist__for_each in a few remaining places  
						
						... 
						
						
						
						Where direct use of the longer form using list_for_entry() was being
used.
Cc: Adrian Hunter <adrian.hunter@intel.com >
Cc: Borislav Petkov <bp@suse.de >
Cc: David Ahern <dsahern@gmail.com >
Cc: Don Zickus <dzickus@redhat.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Jiri Olsa <jolsa@redhat.com >
Cc: Mike Galbraith <efault@gmx.de >
Cc: Namhyung Kim <namhyung@kernel.org >
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-v4fw80flg25nkl8jgeod3ot9@git.kernel.org 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2014-10-29 11:31:54 -02:00 
						 
				 
			
				
					
						
							
							
								Adrian Hunter 
							
						 
					 
					
						
						
							
						
						3c659eedad 
					 
					
						
						
							
							perf tools: Add id index  
						
						... 
						
						
						
						Add an index of the event identifiers, in preparation for Intel PT.
The event id (also called the sample id) is a unique number
allocated by the kernel to the event created by perf_event_open().  Events
can include the event id by having a sample type including PERF_SAMPLE_ID or
PERF_SAMPLE_IDENTIFIER.
Currently the main use of the event id is to match an event back to the
evsel to which it belongs i.e. perf_evlist__id2evsel()
The purpose of this patch is to make it possible to match an event back to
the mmap from which it was read.  The reason that is useful is because the
mmap represents a time-ordered context (either for a cpu or for a thread).
Intel PT decodes trace information on that basis.  In full-trace mode, that
information can be recorded when the Intel PT trace is read, but in
sample-mode the Intel PT trace data is embedded in a sample and it is in
that case that the "id index" is needed.
So the mmaps are numbered (idx) and the cpu and tid recorded against the id
by perf_evlist__set_sid_idx() which is called by perf_evlist__mmap_per_evsel().
That information is recorded on the perf.data file in the new "id index".
idx, cpu and tid are added to struct perf_sample_id (which is the node of
evlist's hash table to match ids to evsels).  The information can be
retrieved using perf_evlist__id2sid().  Note however this all depends on
having a sample type including PERF_SAMPLE_ID or PERF_SAMPLE_IDENTIFIER,
otherwise ids are not recorded.
The "id index" is a synthesized event record which will be created when
Intel PT sampling is used by calling perf_event__synthesize_id_index().
Signed-off-by: Adrian Hunter <adrian.hunter@intel.com >
Acked-by: Jiri Olsa <jolsa@kernel.org >
Cc: David Ahern <dsahern@gmail.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Jiri Olsa <jolsa@redhat.com >
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/r/1414417770-18602-2-git-send-email-adrian.hunter@intel.com 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2014-10-29 11:24:47 -02:00 
						 
				 
			
				
					
						
							
							
								Arnaldo Carvalho de Melo 
							
						 
					 
					
						
						
							
						
						cc8b7c2bf5 
					 
					
						
						
							
							perf thread: Adopt resolve_callchain method from machine  
						
						... 
						
						
						
						Shortening function signature lenght too, since a thread's machine can be
obtained from thread->mg->machine, no need to pass thread, machine.
Cc: Adrian Hunter <adrian.hunter@intel.com >
Cc: Borislav Petkov <bp@suse.de >
Cc: David Ahern <dsahern@gmail.com >
Cc: Don Zickus <dzickus@redhat.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Jean Pihet <jean.pihet@linaro.org >
Cc: Jiri Olsa <jolsa@redhat.com >
Cc: Mike Galbraith <efault@gmx.de >
Cc: Namhyung Kim <namhyung@kernel.org >
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-5wb6css280ty0cel5p0zo2b1@git.kernel.org 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2014-10-29 10:32:46 -02:00 
						 
				 
			
				
					
						
							
							
								Alexander Yarygin 
							
						 
					 
					
						
						
							
						
						54bf53b1cb 
					 
					
						
						
							
							perf session: Add option to copy events when queueing  
						
						... 
						
						
						
						When processing events the session code has an ordered samples queue
which is used to time-sort events coming in across multiple mmaps. At a
later point in time samples on the queue are flushed up to some
timestamp at which point the event is actually processed.
When analyzing events live (ie., record/analysis path in the same
command) there is a race that leads to corrupted events and parse errors
which cause perf to terminate. The problem is that when the event is
placed in the ordered samples queue it is only a reference to the event
which is really sitting in the mmap buffer. Even though the event is
queued for later processing the mmap tail pointer is updated which
indicates to the kernel that the event has been processed. The race is
flushing the event from the queue before it gets overwritten by some
other event. For commands trying to process events live (versus just
writing to a file) and processing a high rate of events this leads to
parse failures and perf terminates.
Examples hitting this problem are 'perf kvm stat live', especially with
nested VMs which generate 100,000+ traces per second, and a command
processing scheduling events with a high rate of context switching --
e.g., running 'perf bench sched pipe'.
This patch offers live commands an option to copy the event when it is
placed in the ordered samples queue.
Based on a patch from David Ahern <dsahern@gmail.com >
Signed-off-by: Alexander Yarygin <yarygin@linux.vnet.ibm.com >
Acked-by: Jiri Olsa <jolsa@kernel.org >
Cc: Christian Borntraeger <borntraeger@de.ibm.com >
Cc: David Ahern <dsahern@gmail.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Ingo Molnar <mingo@kernel.org >
Cc: Jiri Olsa <jolsa@redhat.com >
Cc: Mike Galbraith <efault@gmx.de >
Cc: Namhyung Kim <namhyung.kim@lge.com >
Cc: Paul Mackerras <paulus@samba.org >
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl >
Cc: Stephane Eranian <eranian@google.com >
Link: http://lkml.kernel.org/r/1412347212-28237-2-git-send-email-yarygin@linux.vnet.ibm.com 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2014-10-15 17:39:03 -03:00 
						 
				 
			
				
					
						
							
							
								Arnaldo Carvalho de Melo 
							
						 
					 
					
						
						
							
						
						2a1731fb85 
					 
					
						
						
							
							perf session: Remove last reference to hists struct  
						
						... 
						
						
						
						Now perf_session doesn't require that the evsels in its evlist are hists
containing ones.
Tools that are hists based and want to do per evsel events_stats
updates, if at some point this turns into a necessity, should do it in
the tool specific code, keeping the session class hists agnostic.
Cc: Adrian Hunter <adrian.hunter@intel.com >
Cc: Borislav Petkov <bp@suse.de >
Cc: David Ahern <dsahern@gmail.com >
Cc: Don Zickus <dzickus@redhat.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Jean Pihet <jean.pihet@linaro.org >
Cc: Jiri Olsa <jolsa@redhat.com >
Cc: Mike Galbraith <efault@gmx.de >
Cc: Namhyung Kim <namhyung@kernel.org >
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-cli1bgwpo82mdikuhy3djsuy@git.kernel.org 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2014-10-14 11:41:25 -03:00 
						 
				 
			
				
					
						
							
							
								Arnaldo Carvalho de Melo 
							
						 
					 
					
						
						
							
						
						c2329ade22 
					 
					
						
						
							
							perf session: Don't count per evsel events  
						
						... 
						
						
						
						PERF_RECORD_SAMPLE was not being counted here and is the only per-evsel
thing anyway, the other events were not mapping to a evsel.
With this we don't require that evsels used with a perf_session need to
have space for hists, like the ones in annotate, report, top.
Cc: Adrian Hunter <adrian.hunter@intel.com >
Cc: Borislav Petkov <bp@suse.de >
Cc: David Ahern <dsahern@gmail.com >
Cc: Don Zickus <dzickus@redhat.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Jean Pihet <jean.pihet@linaro.org >
Cc: Jiri Olsa <jolsa@redhat.com >
Cc: Mike Galbraith <efault@gmx.de >
Cc: Namhyung Kim <namhyung@kernel.org >
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-kzchpz0l1mhrsfpkirz086m2@git.kernel.org 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2014-10-10 15:15:32 -03:00 
						 
				 
			
				
					
						
							
							
								Arnaldo Carvalho de Melo 
							
						 
					 
					
						
						
							
						
						4ea062ed43 
					 
					
						
						
							
							perf evsel: Add hists helper  
						
						... 
						
						
						
						Not all tools need a hists instance per perf_evsel, so lets pave the way
to remove evsel->hists while leaving a way to access the hists from a
specially allocated evsel, one that comes with space at the end where
lives the evsel.
Cc: Adrian Hunter <adrian.hunter@intel.com >
Cc: Borislav Petkov <bp@suse.de >
Cc: David Ahern <dsahern@gmail.com >
Cc: Don Zickus <dzickus@redhat.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Jean Pihet <jean.pihet@linaro.org >
Cc: Jiri Olsa <jolsa@redhat.com >
Cc: Mike Galbraith <efault@gmx.de >
Cc: Namhyung Kim <namhyung@kernel.org >
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-qlktkhe31w4mgtbd84035sr2@git.kernel.org 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2014-10-09 13:13:41 -03:00 
						 
				 
			
				
					
						
							
							
								Andi Kleen 
							
						 
					 
					
						
						
							
						
						a5c2a4c956 
					 
					
						
						
							
							perf tools: Fix perf record as non root with kptr_restrict == 1  
						
						... 
						
						
						
						Currently perf record always errors out when you run it as non-root with
kptr_restrict == 1, which is often the default.
Make it only warn instead and fix the kernel resolve code to not
segfault later. Profiling works still fine, except kernel symbols are
not resolved.
Signed-off-by: Andi Kleen <ak@linux.intel.com >
Cc: Ingo Molnar <mingo@kernel.org >
Cc: Jiri Olsa <jolsa@redhat.com >
Cc: Namhyung Kim <namhyung@kernel.org >
Cc: Peter Zijlstra <peterz@infradead.org >
Link: http://lkml.kernel.org/r/1411594794-7229-1-git-send-email-andi@firstfloor.org 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2014-09-26 10:51:41 -03:00 
						 
				 
			
				
					
						
							
							
								Adrian Hunter 
							
						 
					 
					
						
						
							
						
						cfe1c41405 
					 
					
						
						
							
							perf machine: Add machine__thread_exec_comm()  
						
						... 
						
						
						
						Add machine__thread_exec_comm() to return the comm that matches the last
exec, if the comm_exec flag is present, or the last comm otherwise.
Signed-off-by: Adrian Hunter <adrian.hunter@intel.com >
Cc: David Ahern <dsahern@gmail.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Jiri Olsa <jolsa@redhat.com >
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/r/1406786474-9306-3-git-send-email-adrian.hunter@intel.com 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2014-08-13 19:23:21 -03:00 
						 
				 
			
				
					
						
							
							
								Adrian Hunter 
							
						 
					 
					
						
						
							
						
						5a52f33adf 
					 
					
						
						
							
							perf session: Add perf_session__peek_event()  
						
						... 
						
						
						
						Add a function to peek at other events in the event stream.
Signed-off-by: Adrian Hunter <adrian.hunter@intel.com >
Cc: David Ahern <dsahern@gmail.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Jiri Olsa <jolsa@redhat.com >
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/r/1406786474-9306-15-git-send-email-adrian.hunter@intel.com 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2014-08-13 19:21:44 -03:00 
						 
				 
			
				
					
						
							
							
								Jiri Olsa 
							
						 
					 
					
						
						
							
						
						b0a45203a7 
					 
					
						
						
							
							perf tools: Allow out of order messages in forced flush  
						
						... 
						
						
						
						In forced flush (OE_FLUSH__HALF) we break the rules of the flush
timestamp via PERF_RECORD_FINISHED_ROUND event, so we could get out of
order event.
Do not force error in this case plus changing the output warning to use
WARN_ONCE.
Signed-off-by: Jiri Olsa <jolsa@kernel.org >
Acked-by: David Ahern <dsahern@gmail.com >
Cc: Corey Ashford <cjashfor@linux.vnet.ibm.com >
Cc: David Ahern <dsahern@gmail.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Ingo Molnar <mingo@kernel.org >
Cc: Jean Pihet <jean.pihet@linaro.org >
Cc: Namhyung Kim <namhyung@kernel.org >
Cc: Paul Mackerras <paulus@samba.org >
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl >
Link: http://lkml.kernel.org/n/tip-8q8794a8nlmpd1u8xrqmcyd2@git.kernel.org 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2014-08-12 12:03:02 -03:00 
						 
				 
			
				
					
						
							
							
								Jiri Olsa 
							
						 
					 
					
						
						
							
						
						cee3ab9caa 
					 
					
						
						
							
							perf tools: Add debug prints for ordered events queue  
						
						... 
						
						
						
						Adding some prints for ordered events queue, to help debug issues.
Adding debug_ordered_events debug variable to be able to enable ordered
events debug messages using:
  $ perf --debug ordered-events=2 report ...
Also using oe pointer in perf_session__queue_event instead of chained
session variable dereferencing.
Signed-off-by: Jiri Olsa <jolsa@kernel.org >
Acked-by: David Ahern <dsahern@gmail.com >
Cc: Corey Ashford <cjashfor@linux.vnet.ibm.com >
Cc: David Ahern <dsahern@gmail.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Ingo Molnar <mingo@kernel.org >
Cc: Jean Pihet <jean.pihet@linaro.org >
Cc: Namhyung Kim <namhyung@kernel.org >
Cc: Paul Mackerras <paulus@samba.org >
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl >
Link: http://lkml.kernel.org/n/tip-7p3mnnopjvsp9nmk9msqcfkm@git.kernel.org 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2014-08-12 12:03:01 -03:00 
						 
				 
			
				
					
						
							
							
								Jiri Olsa 
							
						 
					 
					
						
						
							
						
						adc56ed1e0 
					 
					
						
						
							
							perf tools: Add ordered_events__free function  
						
						... 
						
						
						
						Adding ordered_events__free function to release all the struct
ordered_events data. It's replacement for former
perf_session_free_sample_buffers function.
Signed-off-by: Jiri Olsa <jolsa@kernel.org >
Acked-by: David Ahern <dsahern@gmail.com >
Cc: Corey Ashford <cjashfor@linux.vnet.ibm.com >
Cc: David Ahern <dsahern@gmail.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Ingo Molnar <mingo@kernel.org >
Cc: Jean Pihet <jean.pihet@linaro.org >
Cc: Namhyung Kim <namhyung@kernel.org >
Cc: Paul Mackerras <paulus@samba.org >
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl >
Link: http://lkml.kernel.org/n/tip-urraa8ccay4o14wambjraws7@git.kernel.org 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2014-08-12 12:03:00 -03:00 
						 
				 
			
				
					
						
							
							
								Jiri Olsa 
							
						 
					 
					
						
						
							
						
						36522f5cf2 
					 
					
						
						
							
							perf tools: Add ordered_events__init function  
						
						... 
						
						
						
						Adding ordered_events__init function for struct ordered_events struct
initialization.
Signed-off-by: Jiri Olsa <jolsa@kernel.org >
Acked-by: David Ahern <dsahern@gmail.com >
Cc: Corey Ashford <cjashfor@linux.vnet.ibm.com >
Cc: David Ahern <dsahern@gmail.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Ingo Molnar <mingo@kernel.org >
Cc: Jean Pihet <jean.pihet@linaro.org >
Cc: Namhyung Kim <namhyung@kernel.org >
Cc: Paul Mackerras <paulus@samba.org >
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl >
Link: http://lkml.kernel.org/n/tip-g6dx35hed8g14eh1ygx4uzp6@git.kernel.org 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2014-08-12 12:02:59 -03:00 
						 
				 
			
				
					
						
							
							
								Jiri Olsa 
							
						 
					 
					
						
						
							
						
						5f86b80b85 
					 
					
						
						
							
							perf tools: Create ordered-events object  
						
						... 
						
						
						
						Move ordered events code into separated object ordered-events.[ch].
No functional change was intended.
Signed-off-by: Jiri Olsa <jolsa@kernel.org >
Acked-by: David Ahern <dsahern@gmail.com >
Cc: Corey Ashford <cjashfor@linux.vnet.ibm.com >
Cc: David Ahern <dsahern@gmail.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Ingo Molnar <mingo@kernel.org >
Cc: Jean Pihet <jean.pihet@linaro.org >
Cc: Namhyung Kim <namhyung@kernel.org >
Cc: Paul Mackerras <paulus@samba.org >
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl >
Link: http://lkml.kernel.org/n/tip-1ge3rilgudszbl87cejm1tfg@git.kernel.org 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2014-08-12 12:02:58 -03:00 
						 
				 
			
				
					
						
							
							
								Jiri Olsa 
							
						 
					 
					
						
						
							
						
						79a30fe4f3 
					 
					
						
						
							
							perf tools: Make perf_session__deliver_event global  
						
						... 
						
						
						
						Making perf_session__deliver_event global function, as it will be called
from another object in following patch.
Signed-off-by: Jiri Olsa <jolsa@kernel.org >
Acked-by: David Ahern <dsahern@gmail.com >
Cc: Corey Ashford <cjashfor@linux.vnet.ibm.com >
Cc: David Ahern <dsahern@gmail.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Ingo Molnar <mingo@kernel.org >
Cc: Jean Pihet <jean.pihet@linaro.org >
Cc: Namhyung Kim <namhyung@kernel.org >
Cc: Paul Mackerras <paulus@samba.org >
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl >
Link: http://lkml.kernel.org/n/tip-rz7s2b8uwv567bigckh75gvk@git.kernel.org 
[ Fixup naming to match class__method schema, as now is more widely exposed ]
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2014-08-12 12:02:58 -03:00 
						 
				 
			
				
					
						
							
							
								Jiri Olsa 
							
						 
					 
					
						
						
							
						
						d40b4a15ab 
					 
					
						
						
							
							perf tools: Flush ordered events in case of allocation failure  
						
						... 
						
						
						
						In previous patches we added a limit for ordered events queue allocation
size. If we reach this size we need to flush (part of) the queue to get
some free buffers.
The current functionality is not affected, because the limit is hard
coded to (u64) -1. The configuration code for size will come in
following patches.
Signed-off-by: Jiri Olsa <jolsa@kernel.org >
Acked-by: David Ahern <dsahern@gmail.com >
Cc: Corey Ashford <cjashfor@linux.vnet.ibm.com >
Cc: David Ahern <dsahern@gmail.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Ingo Molnar <mingo@kernel.org >
Cc: Jean Pihet <jean.pihet@linaro.org >
Cc: Namhyung Kim <namhyung@kernel.org >
Cc: Paul Mackerras <paulus@samba.org >
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl >
Link: http://lkml.kernel.org/n/tip-ggcas0xdq847fi85bz73do2e@git.kernel.org 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2014-08-12 12:02:57 -03:00 
						 
				 
			
				
					
						
							
							
								Jiri Olsa 
							
						 
					 
					
						
						
							
						
						8d99a6ceeb 
					 
					
						
						
							
							perf tools: Limit ordered events queue size  
						
						... 
						
						
						
						Add limit to the ordered events queue allocation. This way we will be
able to control the size of the queue buffers.
There's no limit at the moment (it's set to (u64) -1). The config code
will come in following patches.
Signed-off-by: Jiri Olsa <jolsa@kernel.org >
Acked-by: David Ahern <dsahern@gmail.com >
Cc: Corey Ashford <cjashfor@linux.vnet.ibm.com >
Cc: David Ahern <dsahern@gmail.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Ingo Molnar <mingo@kernel.org >
Cc: Jean Pihet <jean.pihet@linaro.org >
Cc: Namhyung Kim <namhyung@kernel.org >
Cc: Paul Mackerras <paulus@samba.org >
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl >
Link: http://lkml.kernel.org/n/tip-lw1ny3mk4ctb6su5ght5rsng@git.kernel.org 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2014-08-12 12:02:57 -03:00 
						 
				 
			
				
					
						
							
							
								Jiri Olsa 
							
						 
					 
					
						
						
							
						
						d8836b5d17 
					 
					
						
						
							
							perf tools: Factor ordered_events__flush to be more generic  
						
						... 
						
						
						
						Centralizing the next_flush calculation under the ordered_events__flush
function.
Signed-off-by: Jiri Olsa <jolsa@kernel.org >
Acked-by: David Ahern <dsahern@gmail.com >
Cc: Corey Ashford <cjashfor@linux.vnet.ibm.com >
Cc: David Ahern <dsahern@gmail.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Ingo Molnar <mingo@kernel.org >
Cc: Jean Pihet <jean.pihet@linaro.org >
Cc: Namhyung Kim <namhyung@kernel.org >
Cc: Paul Mackerras <paulus@samba.org >
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl >
Link: http://lkml.kernel.org/n/tip-srwunsy7o5wl17vpt4a10oxp@git.kernel.org 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2014-08-12 12:02:56 -03:00 
						 
				 
			
				
					
						
							
							
								Jiri Olsa 
							
						 
					 
					
						
						
							
						
						c64c7e1a5a 
					 
					
						
						
							
							perf tools: Add ordered_events__(new|delete) interface  
						
						... 
						
						
						
						Adding new ordered events interface to new|delete event buffer:
  ordered_events__new    - allocate event buffer from the cache
  ordered_events__delete - return event buffer to the cache
Signed-off-by: Jiri Olsa <jolsa@kernel.org >
Acked-by: David Ahern <dsahern@gmail.com >
Cc: Corey Ashford <cjashfor@linux.vnet.ibm.com >
Cc: David Ahern <dsahern@gmail.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Ingo Molnar <mingo@kernel.org >
Cc: Jean Pihet <jean.pihet@linaro.org >
Cc: Namhyung Kim <namhyung@kernel.org >
Cc: Paul Mackerras <paulus@samba.org >
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl >
Link: http://lkml.kernel.org/n/tip-srwunsy7o5wl17vpt4a10oxp@git.kernel.org 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2014-08-12 12:02:56 -03:00 
						 
				 
			
				
					
						
							
							
								Jiri Olsa 
							
						 
					 
					
						
						
							
						
						fc12482f4f 
					 
					
						
						
							
							perf tools: Rename ordered_events members  
						
						... 
						
						
						
						Rename 'struct ordered_events' members to fit better the ordered events
style.
No functional change was intended.
Signed-off-by: Jiri Olsa <jolsa@kernel.org >
Acked-by: David Ahern <dsahern@gmail.com >
Cc: Corey Ashford <cjashfor@linux.vnet.ibm.com >
Cc: David Ahern <dsahern@gmail.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Ingo Molnar <mingo@kernel.org >
Cc: Jean Pihet <jean.pihet@linaro.org >
Cc: Namhyung Kim <namhyung@kernel.org >
Cc: Paul Mackerras <paulus@samba.org >
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl >
Link: http://lkml.kernel.org/n/tip-v0eb2hsmrxbolnoawu5fn92z@git.kernel.org 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2014-08-12 12:02:55 -03:00 
						 
				 
			
				
					
						
							
							
								Jiri Olsa 
							
						 
					 
					
						
						
							
						
						37e39aa8a8 
					 
					
						
						
							
							perf tools: Rename ordered_samples struct to ordered_events  
						
						... 
						
						
						
						Following up with ordered_samples rename for ordered_samples and
sample_queue structs to ordered_events and ordered_event structs
respectively.
Also changing flush_sample_queue function name to ordered_events_flush.
No functional change was intended.
Signed-off-by: Jiri Olsa <jolsa@kernel.org >
Acked-by: David Ahern <dsahern@gmail.com >
Cc: Corey Ashford <cjashfor@linux.vnet.ibm.com >
Cc: David Ahern <dsahern@gmail.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Ingo Molnar <mingo@kernel.org >
Cc: Jean Pihet <jean.pihet@linaro.org >
Cc: Namhyung Kim <namhyung@kernel.org >
Cc: Paul Mackerras <paulus@samba.org >
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl >
Link: http://lkml.kernel.org/n/tip-2dkrdvh0bbmzxdse437fcgls@git.kernel.org 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2014-08-12 12:02:55 -03:00 
						 
				 
			
				
					
						
							
							
								Jiri Olsa 
							
						 
					 
					
						
						
							
						
						0a8cb85c20 
					 
					
						
						
							
							perf tools: Rename ordered_samples bool to ordered_events  
						
						... 
						
						
						
						The time ordering is generic for all kinds of events, so using generic
name 'ordered_events' for ordered_samples bool in perf_tool struct.
No functional change was intended.
Signed-off-by: Jiri Olsa <jolsa@kernel.org >
Acked-by: David Ahern <dsahern@gmail.com >
Cc: Corey Ashford <cjashfor@linux.vnet.ibm.com >
Cc: David Ahern <dsahern@gmail.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Ingo Molnar <mingo@kernel.org >
Cc: Jean Pihet <jean.pihet@linaro.org >
Cc: Namhyung Kim <namhyung@kernel.org >
Cc: Paul Mackerras <paulus@samba.org >
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl >
Link: http://lkml.kernel.org/n/tip-07mrqzcuhsks9wfmxrzsvemz@git.kernel.org 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2014-08-12 12:02:54 -03:00 
						 
				 
			
				
					
						
							
							
								Jiri Olsa 
							
						 
					 
					
						
						
							
						
						f1dd1460a4 
					 
					
						
						
							
							perf session: Fix accounting of ordered samples queue  
						
						... 
						
						
						
						Properly account flushed samples within the ordered samples queue.
Signed-off-by: Jiri Olsa <jolsa@kernel.org >
Acked-by: Adrian Hunter <adrian.hunter@intel.com >
Acked-by: David Ahern <dsahern@gmail.com >
Cc: Corey Ashford <cjashfor@linux.vnet.ibm.com >
Cc: David Ahern <dsahern@gmail.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Ingo Molnar <mingo@kernel.org >
Cc: Jean Pihet <jean.pihet@linaro.org >
Cc: Namhyung Kim <namhyung@kernel.org >
Cc: Paul Mackerras <paulus@samba.org >
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl >
Link: http://lkml.kernel.org/r/1405893363-21967-2-git-send-email-jolsa@kernel.org 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2014-07-24 16:40:47 -03:00 
						 
				 
			
				
					
						
							
							
								Adrian Hunter 
							
						 
					 
					
						
						
							
						
						d027b64001 
					 
					
						
						
							
							perf machine: Fix the lifetime of the VDSO temporary file  
						
						... 
						
						
						
						The VDSO temporary file is unlinked when a session is deleted.  That
precludes the possibilities that there is no session or there is more
than one session.
Correctly the vdso belongs to the machine so put the information on
'struct machine' and get rid of the global variables.
Reviewed-by: Jiri Olsa <jolsa@redhat.com >
Signed-off-by: Adrian Hunter <adrian.hunter@intel.com >
Cc: David Ahern <dsahern@gmail.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Jiri Olsa <jolsa@redhat.com >
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/r/53CF9B14.7040408@intel.com 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2014-07-23 17:14:39 -03:00 
						 
				 
			
				
					
						
							
							
								Adrian Hunter 
							
						 
					 
					
						
						
							
						
						d5652d865e 
					 
					
						
						
							
							perf session: Add ability to skip 4GiB or more  
						
						... 
						
						
						
						A session can be made to skip portions of the input file.  Do not limit
that size to 32-bits.
Signed-off-by: Adrian Hunter <adrian.hunter@intel.com >
Cc: David Ahern <dsahern@gmail.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Jiri Olsa <jolsa@redhat.com >
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/r/1406143198-20732-2-git-send-email-adrian.hunter@intel.com 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2014-07-23 17:07:14 -03:00 
						 
				 
			
				
					
						
							
							
								Adrian Hunter 
							
						 
					 
					
						
						
							
						
						6f917c7099 
					 
					
						
						
							
							perf session: Add ability to 'skip' a non-piped event stream  
						
						... 
						
						
						
						A piped event stream may contain arbitary sized tracepoint information
following a PERF_RECORD_HEADER_TRACING_DATA event.  The position in the
stream has to be 'skipped' to match the start of the next event.
Provide the same ability to a non-piped event stream to allow for
Instruction Trace data that may also be in a non-piped event stream.
Signed-off-by: Adrian Hunter <adrian.hunter@intel.com >
Cc: David Ahern <dsahern@gmail.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Jiri Olsa <jolsa@redhat.com >
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/r/1406143198-20732-1-git-send-email-adrian.hunter@intel.com 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2014-07-23 17:00:46 -03:00 
						 
				 
			
				
					
						
							
							
								Adrian Hunter 
							
						 
					 
					
						
						
							
						
						919d86d3a3 
					 
					
						
						
							
							perf session: Flag if the event stream is entirely in memory  
						
						... 
						
						
						
						Flag if the event stream is a file that has been mmapped in one go.
This is useful, for example, if a tool needs to keep an event for later
reference.  If the new flag is set, a pointer to the event can be
retained, otherwise the event must be copied.
Signed-off-by: Adrian Hunter <adrian.hunter@intel.com >
Cc: David Ahern <dsahern@gmail.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Jiri Olsa <jolsa@redhat.com >
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/r/1405332185-4050-28-git-send-email-adrian.hunter@intel.com 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2014-07-16 17:57:36 -03:00 
						 
				 
			
				
					
						
							
							
								Adrian Hunter 
							
						 
					 
					
						
						
							
						
						1fcb876863 
					 
					
						
						
							
							perf machine: Fix the value used for unknown pids  
						
						... 
						
						
						
						The value used for unknown pids cannot be zero because that is used by
the "idle" task.
Use -1 instead.  Also handle the unknown pid case when creating map
groups.
Note that, threads with an unknown pid should not occur because fork (or
synthesized) events precede the thread's existence.
Signed-off-by: Adrian Hunter <adrian.hunter@intel.com >
Cc: David Ahern <dsahern@gmail.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Jiri Olsa <jolsa@redhat.com >
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/r/1405332185-4050-2-git-send-email-adrian.hunter@intel.com 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2014-07-16 17:57:33 -03:00 
						 
				 
			
				
					
						
							
							
								Masanari Iida 
							
						 
					 
					
						
						
							
						
						c5765ece8a 
					 
					
						
						
							
							perf session: Fix possible null pointer dereference in session.c  
						
						... 
						
						
						
						cppcheck detected following warning:
[tools/perf/util/session.c:1628] -> [tools/perf/util/session.c:1632]:
 (warning) Possible null pointer dereference: session - otherwise it
 is redundant to check it against null.
In order to avoide null pointer, check the pointer before use.
Signed-off-by: Masanari Iida <standby24x7@gmail.com >
Link: http://lkml.kernel.org/r/1400087618-13628-1-git-send-email-standby24x7@gmail.com 
Signed-off-by: Jiri Olsa <jolsa@kernel.org > 
						
						
					 
					
						2014-05-16 09:18:51 +02:00 
						 
				 
			
				
					
						
							
							
								Don Zickus 
							
						 
					 
					
						
						
							
						
						0ea590ae81 
					 
					
						
						
							
							perf session: Change header.misc dump from decimal to hex  
						
						... 
						
						
						
						When printing the raw dump of a data file, the header.misc is
printed as a decimal.  Unfortunately, that field is a bit mask, so
it is hard to interpret as a decimal.
Print in hex, so the user can easily see what bits are set and more
importantly what type of info it is conveying.
V2: add 0x in front per Jiri Olsa
Signed-off-by: Don Zickus <dzickus@redhat.com >
Cc: Jiri Olsa <jolsa@redhat.com >
Cc: Stephane Eranian <eranian@google.com >
Link: http://lkml.kernel.org/r/1393386227-149412-3-git-send-email-dzickus@redhat.com 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2014-03-14 18:08:39 -03:00 
						 
				 
			
				
					
						
							
							
								Jiri Olsa 
							
						 
					 
					
						
						
							
						
						352ea45a72 
					 
					
						
						
							
							perf callchain: Add mask into struct regs_dump  
						
						... 
						
						
						
						Adding mask info into struct regs_dump to make the registers information
compact.
The mask was always passed along, so logically the mask info fits more
into the struct regs_dump.
Signed-off-by: Jiri Olsa <jolsa@redhat.com >
Acked-by: Jean Pihet <jean.pihet@linaro.org >
Cc: Adrian Hunter <adrian.hunter@intel.com >
Cc: Corey Ashford <cjashfor@linux.vnet.ibm.com >
Cc: David Ahern <dsahern@gmail.com >
Cc: Frederic Weisbecker <fweisbec@gmail.com >
Cc: Ingo Molnar <mingo@kernel.org >
Cc: Jean Pihet <jean.pihet@linaro.org >
Cc: Namhyung Kim <namhyung@kernel.org >
Cc: Paul Mackerras <paulus@samba.org >
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl >
Link: http://lkml.kernel.org/r/1389098853-14466-9-git-send-email-jolsa@redhat.com 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2014-02-18 09:34:48 -03:00 
						 
				 
			
				
					
						
							
							
								Jiri Olsa 
							
						 
					 
					
						
						
							
						
						f67697bd07 
					 
					
						
						
							
							perf tools: Handle PERF_RECORD_HEADER_EVENT_TYPE properly  
						
						... 
						
						
						
						We removed event types from data file in following commits:
  606521044b3c57eranian@google.com >
Signed-off-by: Jiri Olsa <jolsa@redhat.com >
Cc: Corey Ashford <cjashfor@linux.vnet.ibm.com >
Cc: David Ahern <dsahern@gmail.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 >
Link: http://lkml.kernel.org/r/1391524668-12546-1-git-send-email-jolsa@redhat.com 
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com > 
						
						
					 
					
						2014-02-10 11:34:31 -03:00