diff options
| author | Ingo Molnar <mingo@kernel.org> | 2019-03-09 11:00:17 -0500 |
|---|---|---|
| committer | Ingo Molnar <mingo@kernel.org> | 2019-03-09 11:00:17 -0500 |
| commit | b339da480315505aa28a723a983217ebcff95c86 (patch) | |
| tree | 4194e7a3b4aa986335eeaf697652a4ac163c45ef /tools/perf/scripts/python/export-to-sqlite.py | |
| parent | 43aa378b41700650e4ddbd068650f9fe4ab496df (diff) | |
| parent | b8f7d86b5849ea7bb84bddc0345a3799049764d4 (diff) | |
Merge tag 'perf-core-for-mingo-5.1-20190307' of git://git.kernel.org/pub/scm/linux/kernel/git/acme/linux into perf/urgent
Pull perf/core changes from Arnaldo Carvalho de Melo:
perf bpf:
Arnaldo Carvalho de Melo:
- Automatically add BTF ELF markers to 'perf trace' BPF programs, so that
tools such as 'bpftool map dump' can pretty print map keys and values.
perf c2c:
Jiri Olsa:
- Fix report for empty NUMA node.
perf diff:
Jin Yao:
- Support --time, --cpu, --pid and --tid filter options.
perf probe:
Arnaldo Carvalho de Melo:
- Clarify error message about not finding kernel modules debuginfo.
perf record:
Jiri Olsa:
- Fixup probing for max attr.precise_ip.
perf trace:
Arnaldo Carvalho de Melo:
- Add missing %s lost in the 'msg_flags' recvmmsg arg when adding prefix suppression logic.
perf annotate:
Arnaldo Carvalho de Melo:
- Calculate the max instruction name, align column to that, removing the
hardcoded max 6 chars and cope with instructions with names longer than that,
such as vpmovmskb, vpcmpeqb, etc.
kernel:
Song Liu:
- Consider events with attr.bpf_event set as side-band.
Gustavo A. R. Silva:
- Mark expected switch fall-through in perf_event_parse_addr_filter().
Libraries:
Jiri Olsa:
- Fix leaks and double frees on error paths.
libtraceevent:
Tony Jones:
- Fix buffer overflow in arg_eval().
python scripting:
Tony Jones:
- More python3 fixes.
Trivial:
Yang Wei:
- Remove needless extra semicolon in clang C++ glue code.
Intel PT/BTS:
Adrian Hunter:
- Improve auxtrace address filter error message when there is no DSO.
- Fix divide by zero when TSC is not available.
- Further improvements to the export to sqlite/posgresql python scripts
and to the GUI sqlviewer, exporting 'parent_id' so that we have enable
the creation of call trees.
Andi Kleen:
- Generalize function to copy from thread addr space from intel-bts code.
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Signed-off-by: Ingo Molnar <mingo@kernel.org>
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: | |||
| 222 | 'call_id bigint,' | 222 | 'call_id bigint,' |
| 223 | 'return_id bigint,' | 223 | 'return_id bigint,' |
| 224 | 'parent_call_path_id bigint,' | 224 | 'parent_call_path_id bigint,' |
| 225 | 'flags integer)') | 225 | 'flags integer,' |
| 226 | 'parent_id bigint)') | ||
| 226 | 227 | ||
| 227 | # printf was added to sqlite in version 3.8.3 | 228 | # printf was added to sqlite in version 3.8.3 |
| 228 | sqlite_has_printf = False | 229 | sqlite_has_printf = False |
| @@ -321,7 +322,8 @@ if perf_db_export_calls: | |||
| 321 | 'call_id,' | 322 | 'call_id,' |
| 322 | 'return_id,' | 323 | 'return_id,' |
| 323 | '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,' | 324 | '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,' |
| 324 | 'parent_call_path_id' | 325 | 'parent_call_path_id,' |
| 326 | 'parent_id' | ||
| 325 | ' FROM calls INNER JOIN call_paths ON call_paths.id = call_path_id') | 327 | ' FROM calls INNER JOIN call_paths ON call_paths.id = call_path_id') |
| 326 | 328 | ||
| 327 | do_query(query, 'CREATE VIEW samples_view AS ' | 329 | do_query(query, 'CREATE VIEW samples_view AS ' |
| @@ -373,7 +375,7 @@ if perf_db_export_calls or perf_db_export_callchains: | |||
| 373 | call_path_query.prepare("INSERT INTO call_paths VALUES (?, ?, ?, ?)") | 375 | call_path_query.prepare("INSERT INTO call_paths VALUES (?, ?, ?, ?)") |
| 374 | if perf_db_export_calls: | 376 | if perf_db_export_calls: |
| 375 | call_query = QSqlQuery(db) | 377 | call_query = QSqlQuery(db) |
| 376 | call_query.prepare("INSERT INTO calls VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)") | 378 | call_query.prepare("INSERT INTO calls VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)") |
| 377 | 379 | ||
| 378 | def trace_begin(): | 380 | def trace_begin(): |
| 379 | print datetime.datetime.today(), "Writing records..." | 381 | print datetime.datetime.today(), "Writing records..." |
| @@ -388,6 +390,7 @@ def trace_begin(): | |||
| 388 | sample_table(0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0) | 390 | sample_table(0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0) |
| 389 | if perf_db_export_calls or perf_db_export_callchains: | 391 | if perf_db_export_calls or perf_db_export_callchains: |
| 390 | call_path_table(0, 0, 0, 0) | 392 | call_path_table(0, 0, 0, 0) |
| 393 | call_return_table(0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0) | ||
| 391 | 394 | ||
| 392 | unhandled_count = 0 | 395 | unhandled_count = 0 |
| 393 | 396 | ||
| @@ -397,6 +400,7 @@ def trace_end(): | |||
| 397 | print datetime.datetime.today(), "Adding indexes" | 400 | print datetime.datetime.today(), "Adding indexes" |
| 398 | if perf_db_export_calls: | 401 | if perf_db_export_calls: |
| 399 | do_query(query, 'CREATE INDEX pcpid_idx ON calls (parent_call_path_id)') | 402 | do_query(query, 'CREATE INDEX pcpid_idx ON calls (parent_call_path_id)') |
| 403 | do_query(query, 'CREATE INDEX pid_idx ON calls (parent_id)') | ||
| 400 | 404 | ||
| 401 | if (unhandled_count): | 405 | if (unhandled_count): |
| 402 | print datetime.datetime.today(), "Warning: ", unhandled_count, " unhandled events" | 406 | print datetime.datetime.today(), "Warning: ", unhandled_count, " unhandled events" |
| @@ -452,4 +456,4 @@ def call_path_table(*x): | |||
| 452 | bind_exec(call_path_query, 4, x) | 456 | bind_exec(call_path_query, 4, x) |
| 453 | 457 | ||
| 454 | def call_return_table(*x): | 458 | def call_return_table(*x): |
| 455 | bind_exec(call_query, 11, x) | 459 | bind_exec(call_query, 12, x) |
