diff options
author | Adrian Hunter <adrian.hunter@intel.com> | 2019-02-28 08:00:25 -0500 |
---|---|---|
committer | Arnaldo Carvalho de Melo <acme@redhat.com> | 2019-03-01 12:52:29 -0500 |
commit | 8ce9a7251d110c7bbb43e30dd42f81d8e6286516 (patch) | |
tree | b4f8dd643a24da5b7f38b90bf242e82d264d1f25 /tools/perf/scripts/python/export-to-sqlite.py | |
parent | f435887ec0c941b97301bd6ed1f3e4b5200df409 (diff) |
perf scripts python: export-to-sqlite.py: Export calls parent_id
Export to the 'calls' table the newly created 'parent_id'.
Signed-off-by: Adrian Hunter <adrian.hunter@intel.com>
Cc: Jiri Olsa <jolsa@redhat.com>
Link: https://lkml.kernel.org/n/tip-b09oukl48rsl9azkp2wmh0bl@git.kernel.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
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) |