diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2019-03-11 01:22:03 +0300 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2019-03-11 01:22:03 +0300 | 
| commit | 12ad143e1b803e541e48b8ba40f550250259ecdd (patch) | |
| tree | 5202b407df21e5abaeb294d1ecddcf0a2eca7f8b /tools/perf/scripts/python/export-to-sqlite.py | |
| parent | 262d6a9a63a387c8dfa9eb4f7713e159c941e52c (diff) | |
| parent | b339da480315505aa28a723a983217ebcff95c86 (diff) | |
| download | linux-12ad143e1b803e541e48b8ba40f550250259ecdd.tar.xz | |
Merge branch 'perf-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip
Pull perf updates from Thomas Gleixner:
 "Perf updates and fixes:
  Kernel:
   - Handle events which have the bpf_event attribute set as side band
     events as they carry information about BPF programs.
   - Add missing switch-case fall-through comments
  Libraries:
   - Fix leaks and double frees in error code paths.
   - Prevent buffer overflows in libtraceevent
  Tools:
   - Improvements in handling Intel BT/PTS
   - Add BTF ELF markers to perf trace BPF programs to improve output
   - Support --time, --cpu, --pid and --tid filters for perf diff
   - Calculate the column width in perf annotate as the hardcoded 6
     characters for the instruction are not sufficient
   - Small fixes all over the place"
* 'perf-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: (38 commits)
  perf/core: Mark expected switch fall-through
  perf/x86/intel/uncore: Fix client IMC events return huge result
  perf/ring_buffer: Use high order allocations for AUX buffers optimistically
  perf data: Force perf_data__open|close zero data->file.path
  perf session: Fix double free in perf_data__close
  perf evsel: Probe for precise_ip with simple attr
  perf tools: Read and store caps/max_precise in perf_pmu
  perf hist: Fix memory leak of srcline
  perf hist: Add error path into hist_entry__init
  perf c2c: Fix c2c report for empty numa node
  perf script python: Add Python3 support to intel-pt-events.py
  perf script python: Add Python3 support to event_analyzing_sample.py
  perf script python: add Python3 support to check-perf-trace.py
  perf script python: Add Python3 support to futex-contention.py
  perf script python: Remove mixed indentation
  perf diff: Support --pid/--tid filter options
  perf diff: Support --cpu filter option
  perf diff: Support --time filter option
  perf thread: Generalize function to copy from thread addr space from intel-bts code
  perf annotate: Calculate the max instruction name, align column to that
  ...
Diffstat (limited to 'tools/perf/scripts/python/export-to-sqlite.py')
| -rw-r--r-- | tools/perf/scripts/python/export-to-sqlite.py | 12 | 
1 files changed, 8 insertions, 4 deletions
diff --git a/tools/perf/scripts/python/export-to-sqlite.py b/tools/perf/scripts/python/export-to-sqlite.py index ed237f2ed03f..eb63e6c7107f 100644 --- a/tools/perf/scripts/python/export-to-sqlite.py +++ b/tools/perf/scripts/python/export-to-sqlite.py @@ -222,7 +222,8 @@ if perf_db_export_calls:  		'call_id	bigint,'  		'return_id	bigint,'  		'parent_call_path_id	bigint,' -		'flags		integer)') +		'flags		integer,' +		'parent_id	bigint)')  # printf was added to sqlite in version 3.8.3  sqlite_has_printf = False @@ -321,7 +322,8 @@ if perf_db_export_calls:  			'call_id,'  			'return_id,'  			'CASE WHEN flags=0 THEN \'\' WHEN flags=1 THEN \'no call\' WHEN flags=2 THEN \'no return\' WHEN flags=3 THEN \'no call/return\' WHEN flags=6 THEN \'jump\' ELSE flags END AS flags,' -			'parent_call_path_id' +			'parent_call_path_id,' +			'parent_id'  		' FROM calls INNER JOIN call_paths ON call_paths.id = call_path_id')  do_query(query, 'CREATE VIEW samples_view AS ' @@ -373,7 +375,7 @@ if perf_db_export_calls or perf_db_export_callchains:  	call_path_query.prepare("INSERT INTO call_paths VALUES (?, ?, ?, ?)")  if perf_db_export_calls:  	call_query = QSqlQuery(db) -	call_query.prepare("INSERT INTO calls VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)") +	call_query.prepare("INSERT INTO calls VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)")  def trace_begin():  	print datetime.datetime.today(), "Writing records..." @@ -388,6 +390,7 @@ def trace_begin():  	sample_table(0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0)  	if perf_db_export_calls or perf_db_export_callchains:  		call_path_table(0, 0, 0, 0) +		call_return_table(0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0)  unhandled_count = 0 @@ -397,6 +400,7 @@ def trace_end():  	print datetime.datetime.today(), "Adding indexes"  	if perf_db_export_calls:  		do_query(query, 'CREATE INDEX pcpid_idx ON calls (parent_call_path_id)') +		do_query(query, 'CREATE INDEX pid_idx ON calls (parent_id)')  	if (unhandled_count):  		print datetime.datetime.today(), "Warning: ", unhandled_count, " unhandled events" @@ -452,4 +456,4 @@ def call_path_table(*x):  	bind_exec(call_path_query, 4, x)  def call_return_table(*x): -	bind_exec(call_query, 11, x) +	bind_exec(call_query, 12, x)  | 
