diff options
author | Adrian Hunter <adrian.hunter@intel.com> | 2019-02-28 08:00:27 -0500 |
---|---|---|
committer | Arnaldo Carvalho de Melo <acme@redhat.com> | 2019-03-01 12:53:33 -0500 |
commit | febce6dc1f5167e683d6e3c3d0f6ab7f98201ea8 (patch) | |
tree | ffc36c46b80a5f738cb3891e3558dae53cf635ac /tools/perf/scripts/python/export-to-postgresql.py | |
parent | 07c5ebead85f507271fb8e2a8b5814e486702518 (diff) |
perf scripts python: export-to-postgresql.py: Export calls parent_id
Export to the 'calls' table the newly created 'parent_id' and create an
index for it.
Signed-off-by: Adrian Hunter <adrian.hunter@intel.com>
Cc: Jiri Olsa <jolsa@redhat.com>
Link: https://lkml.kernel.org/n/tip-eybd6fnk6j9r7g643lsideoo@git.kernel.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Diffstat (limited to 'tools/perf/scripts/python/export-to-postgresql.py')
-rw-r--r-- | tools/perf/scripts/python/export-to-postgresql.py | 14 |
1 files changed, 9 insertions, 5 deletions
diff --git a/tools/perf/scripts/python/export-to-postgresql.py b/tools/perf/scripts/python/export-to-postgresql.py index 6358522a69f6..390a351d15ea 100644 --- a/tools/perf/scripts/python/export-to-postgresql.py +++ b/tools/perf/scripts/python/export-to-postgresql.py | |||
@@ -394,7 +394,8 @@ if perf_db_export_calls: | |||
394 | 'call_id bigint,' | 394 | 'call_id bigint,' |
395 | 'return_id bigint,' | 395 | 'return_id bigint,' |
396 | 'parent_call_path_id bigint,' | 396 | 'parent_call_path_id bigint,' |
397 | 'flags integer)') | 397 | 'flags integer,' |
398 | 'parent_id bigint)') | ||
398 | 399 | ||
399 | do_query(query, 'CREATE VIEW machines_view AS ' | 400 | do_query(query, 'CREATE VIEW machines_view AS ' |
400 | 'SELECT ' | 401 | 'SELECT ' |
@@ -479,7 +480,8 @@ if perf_db_export_calls: | |||
479 | 'call_id,' | 480 | 'call_id,' |
480 | 'return_id,' | 481 | 'return_id,' |
481 | '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 CAST ( flags AS VARCHAR(6) ) END AS flags,' | 482 | '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 CAST ( flags AS VARCHAR(6) ) END AS flags,' |
482 | 'parent_call_path_id' | 483 | 'parent_call_path_id,' |
484 | 'calls.parent_id' | ||
483 | ' FROM calls INNER JOIN call_paths ON call_paths.id = call_path_id') | 485 | ' FROM calls INNER JOIN call_paths ON call_paths.id = call_path_id') |
484 | 486 | ||
485 | do_query(query, 'CREATE VIEW samples_view AS ' | 487 | do_query(query, 'CREATE VIEW samples_view AS ' |
@@ -575,6 +577,7 @@ def trace_begin(): | |||
575 | sample_table(0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0) | 577 | sample_table(0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0) |
576 | if perf_db_export_calls or perf_db_export_callchains: | 578 | if perf_db_export_calls or perf_db_export_callchains: |
577 | call_path_table(0, 0, 0, 0) | 579 | call_path_table(0, 0, 0, 0) |
580 | call_return_table(0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0) | ||
578 | 581 | ||
579 | unhandled_count = 0 | 582 | unhandled_count = 0 |
580 | 583 | ||
@@ -657,6 +660,7 @@ def trace_end(): | |||
657 | 'ADD CONSTRAINT returnfk FOREIGN KEY (return_id) REFERENCES samples (id),' | 660 | 'ADD CONSTRAINT returnfk FOREIGN KEY (return_id) REFERENCES samples (id),' |
658 | 'ADD CONSTRAINT parent_call_pathfk FOREIGN KEY (parent_call_path_id) REFERENCES call_paths (id)') | 661 | 'ADD CONSTRAINT parent_call_pathfk FOREIGN KEY (parent_call_path_id) REFERENCES call_paths (id)') |
659 | do_query(query, 'CREATE INDEX pcpid_idx ON calls (parent_call_path_id)') | 662 | do_query(query, 'CREATE INDEX pcpid_idx ON calls (parent_call_path_id)') |
663 | do_query(query, 'CREATE INDEX pid_idx ON calls (parent_id)') | ||
660 | 664 | ||
661 | if (unhandled_count): | 665 | if (unhandled_count): |
662 | print datetime.datetime.today(), "Warning: ", unhandled_count, " unhandled events" | 666 | print datetime.datetime.today(), "Warning: ", unhandled_count, " unhandled events" |
@@ -728,7 +732,7 @@ def call_path_table(cp_id, parent_id, symbol_id, ip, *x): | |||
728 | value = struct.pack(fmt, 4, 8, cp_id, 8, parent_id, 8, symbol_id, 8, ip) | 732 | value = struct.pack(fmt, 4, 8, cp_id, 8, parent_id, 8, symbol_id, 8, ip) |
729 | call_path_file.write(value) | 733 | call_path_file.write(value) |
730 | 734 | ||
731 | def call_return_table(cr_id, thread_id, comm_id, call_path_id, call_time, return_time, branch_count, call_id, return_id, parent_call_path_id, flags, *x): | 735 | def call_return_table(cr_id, thread_id, comm_id, call_path_id, call_time, return_time, branch_count, call_id, return_id, parent_call_path_id, flags, parent_id, *x): |
732 | fmt = "!hiqiqiqiqiqiqiqiqiqiqii" | 736 | fmt = "!hiqiqiqiqiqiqiqiqiqiqiiiq" |
733 | value = struct.pack(fmt, 11, 8, cr_id, 8, thread_id, 8, comm_id, 8, call_path_id, 8, call_time, 8, return_time, 8, branch_count, 8, call_id, 8, return_id, 8, parent_call_path_id, 4, flags) | 737 | value = struct.pack(fmt, 12, 8, cr_id, 8, thread_id, 8, comm_id, 8, call_path_id, 8, call_time, 8, return_time, 8, branch_count, 8, call_id, 8, return_id, 8, parent_call_path_id, 4, flags, 8, parent_id) |
734 | call_file.write(value) | 738 | call_file.write(value) |