1*564b9527SAdrian Hunter# export-to-sqlite.py: export perf data to a sqlite3 database 2*564b9527SAdrian Hunter# Copyright (c) 2017, Intel Corporation. 3*564b9527SAdrian Hunter# 4*564b9527SAdrian Hunter# This program is free software; you can redistribute it and/or modify it 5*564b9527SAdrian Hunter# under the terms and conditions of the GNU General Public License, 6*564b9527SAdrian Hunter# version 2, as published by the Free Software Foundation. 7*564b9527SAdrian Hunter# 8*564b9527SAdrian Hunter# This program is distributed in the hope it will be useful, but WITHOUT 9*564b9527SAdrian Hunter# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 10*564b9527SAdrian Hunter# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for 11*564b9527SAdrian Hunter# more details. 12*564b9527SAdrian Hunter 13*564b9527SAdrian Hunterimport os 14*564b9527SAdrian Hunterimport sys 15*564b9527SAdrian Hunterimport struct 16*564b9527SAdrian Hunterimport datetime 17*564b9527SAdrian Hunter 18*564b9527SAdrian Hunter# To use this script you will need to have installed package python-pyside which 19*564b9527SAdrian Hunter# provides LGPL-licensed Python bindings for Qt. You will also need the package 20*564b9527SAdrian Hunter# libqt4-sql-sqlite for Qt sqlite3 support. 21*564b9527SAdrian Hunter# 22*564b9527SAdrian Hunter# An example of using this script with Intel PT: 23*564b9527SAdrian Hunter# 24*564b9527SAdrian Hunter# $ perf record -e intel_pt//u ls 25*564b9527SAdrian Hunter# $ perf script -s ~/libexec/perf-core/scripts/python/export-to-sqlite.py pt_example branches calls 26*564b9527SAdrian Hunter# 2017-07-31 14:26:07.326913 Creating database... 27*564b9527SAdrian Hunter# 2017-07-31 14:26:07.538097 Writing records... 28*564b9527SAdrian Hunter# 2017-07-31 14:26:09.889292 Adding indexes 29*564b9527SAdrian Hunter# 2017-07-31 14:26:09.958746 Done 30*564b9527SAdrian Hunter# 31*564b9527SAdrian Hunter# To browse the database, sqlite3 can be used e.g. 32*564b9527SAdrian Hunter# 33*564b9527SAdrian Hunter# $ sqlite3 pt_example 34*564b9527SAdrian Hunter# sqlite> .header on 35*564b9527SAdrian Hunter# sqlite> select * from samples_view where id < 10; 36*564b9527SAdrian Hunter# sqlite> .mode column 37*564b9527SAdrian Hunter# sqlite> select * from samples_view where id < 10; 38*564b9527SAdrian Hunter# sqlite> .tables 39*564b9527SAdrian Hunter# sqlite> .schema samples_view 40*564b9527SAdrian Hunter# sqlite> .quit 41*564b9527SAdrian Hunter# 42*564b9527SAdrian Hunter# An example of using the database is provided by the script 43*564b9527SAdrian Hunter# call-graph-from-sql.py. Refer to that script for details. 44*564b9527SAdrian Hunter# 45*564b9527SAdrian Hunter# The database structure is practically the same as created by the script 46*564b9527SAdrian Hunter# export-to-postgresql.py. Refer to that script for details. A notable 47*564b9527SAdrian Hunter# difference is the 'transaction' column of the 'samples' table which is 48*564b9527SAdrian Hunter# renamed 'transaction_' in sqlite because 'transaction' is a reserved word. 49*564b9527SAdrian Hunter 50*564b9527SAdrian Hunterfrom PySide.QtSql import * 51*564b9527SAdrian Hunter 52*564b9527SAdrian Huntersys.path.append(os.environ['PERF_EXEC_PATH'] + \ 53*564b9527SAdrian Hunter '/scripts/python/Perf-Trace-Util/lib/Perf/Trace') 54*564b9527SAdrian Hunter 55*564b9527SAdrian Hunter# These perf imports are not used at present 56*564b9527SAdrian Hunter#from perf_trace_context import * 57*564b9527SAdrian Hunter#from Core import * 58*564b9527SAdrian Hunter 59*564b9527SAdrian Hunterperf_db_export_mode = True 60*564b9527SAdrian Hunterperf_db_export_calls = False 61*564b9527SAdrian Hunterperf_db_export_callchains = False 62*564b9527SAdrian Hunter 63*564b9527SAdrian Hunterdef usage(): 64*564b9527SAdrian Hunter print >> sys.stderr, "Usage is: export-to-sqlite.py <database name> [<columns>] [<calls>] [<callchains>]" 65*564b9527SAdrian Hunter print >> sys.stderr, "where: columns 'all' or 'branches'" 66*564b9527SAdrian Hunter print >> sys.stderr, " calls 'calls' => create calls and call_paths table" 67*564b9527SAdrian Hunter print >> sys.stderr, " callchains 'callchains' => create call_paths table" 68*564b9527SAdrian Hunter raise Exception("Too few arguments") 69*564b9527SAdrian Hunter 70*564b9527SAdrian Hunterif (len(sys.argv) < 2): 71*564b9527SAdrian Hunter usage() 72*564b9527SAdrian Hunter 73*564b9527SAdrian Hunterdbname = sys.argv[1] 74*564b9527SAdrian Hunter 75*564b9527SAdrian Hunterif (len(sys.argv) >= 3): 76*564b9527SAdrian Hunter columns = sys.argv[2] 77*564b9527SAdrian Hunterelse: 78*564b9527SAdrian Hunter columns = "all" 79*564b9527SAdrian Hunter 80*564b9527SAdrian Hunterif columns not in ("all", "branches"): 81*564b9527SAdrian Hunter usage() 82*564b9527SAdrian Hunter 83*564b9527SAdrian Hunterbranches = (columns == "branches") 84*564b9527SAdrian Hunter 85*564b9527SAdrian Hunterfor i in range(3,len(sys.argv)): 86*564b9527SAdrian Hunter if (sys.argv[i] == "calls"): 87*564b9527SAdrian Hunter perf_db_export_calls = True 88*564b9527SAdrian Hunter elif (sys.argv[i] == "callchains"): 89*564b9527SAdrian Hunter perf_db_export_callchains = True 90*564b9527SAdrian Hunter else: 91*564b9527SAdrian Hunter usage() 92*564b9527SAdrian Hunter 93*564b9527SAdrian Hunterdef do_query(q, s): 94*564b9527SAdrian Hunter if (q.exec_(s)): 95*564b9527SAdrian Hunter return 96*564b9527SAdrian Hunter raise Exception("Query failed: " + q.lastError().text()) 97*564b9527SAdrian Hunter 98*564b9527SAdrian Hunterdef do_query_(q): 99*564b9527SAdrian Hunter if (q.exec_()): 100*564b9527SAdrian Hunter return 101*564b9527SAdrian Hunter raise Exception("Query failed: " + q.lastError().text()) 102*564b9527SAdrian Hunter 103*564b9527SAdrian Hunterprint datetime.datetime.today(), "Creating database..." 104*564b9527SAdrian Hunter 105*564b9527SAdrian Hunterdb_exists = False 106*564b9527SAdrian Huntertry: 107*564b9527SAdrian Hunter f = open(dbname) 108*564b9527SAdrian Hunter f.close() 109*564b9527SAdrian Hunter db_exists = True 110*564b9527SAdrian Hunterexcept: 111*564b9527SAdrian Hunter pass 112*564b9527SAdrian Hunter 113*564b9527SAdrian Hunterif db_exists: 114*564b9527SAdrian Hunter raise Exception(dbname + " already exists") 115*564b9527SAdrian Hunter 116*564b9527SAdrian Hunterdb = QSqlDatabase.addDatabase('QSQLITE') 117*564b9527SAdrian Hunterdb.setDatabaseName(dbname) 118*564b9527SAdrian Hunterdb.open() 119*564b9527SAdrian Hunter 120*564b9527SAdrian Hunterquery = QSqlQuery(db) 121*564b9527SAdrian Hunter 122*564b9527SAdrian Hunterdo_query(query, 'PRAGMA journal_mode = OFF') 123*564b9527SAdrian Hunterdo_query(query, 'BEGIN TRANSACTION') 124*564b9527SAdrian Hunter 125*564b9527SAdrian Hunterdo_query(query, 'CREATE TABLE selected_events (' 126*564b9527SAdrian Hunter 'id integer NOT NULL PRIMARY KEY,' 127*564b9527SAdrian Hunter 'name varchar(80))') 128*564b9527SAdrian Hunterdo_query(query, 'CREATE TABLE machines (' 129*564b9527SAdrian Hunter 'id integer NOT NULL PRIMARY KEY,' 130*564b9527SAdrian Hunter 'pid integer,' 131*564b9527SAdrian Hunter 'root_dir varchar(4096))') 132*564b9527SAdrian Hunterdo_query(query, 'CREATE TABLE threads (' 133*564b9527SAdrian Hunter 'id integer NOT NULL PRIMARY KEY,' 134*564b9527SAdrian Hunter 'machine_id bigint,' 135*564b9527SAdrian Hunter 'process_id bigint,' 136*564b9527SAdrian Hunter 'pid integer,' 137*564b9527SAdrian Hunter 'tid integer)') 138*564b9527SAdrian Hunterdo_query(query, 'CREATE TABLE comms (' 139*564b9527SAdrian Hunter 'id integer NOT NULL PRIMARY KEY,' 140*564b9527SAdrian Hunter 'comm varchar(16))') 141*564b9527SAdrian Hunterdo_query(query, 'CREATE TABLE comm_threads (' 142*564b9527SAdrian Hunter 'id integer NOT NULL PRIMARY KEY,' 143*564b9527SAdrian Hunter 'comm_id bigint,' 144*564b9527SAdrian Hunter 'thread_id bigint)') 145*564b9527SAdrian Hunterdo_query(query, 'CREATE TABLE dsos (' 146*564b9527SAdrian Hunter 'id integer NOT NULL PRIMARY KEY,' 147*564b9527SAdrian Hunter 'machine_id bigint,' 148*564b9527SAdrian Hunter 'short_name varchar(256),' 149*564b9527SAdrian Hunter 'long_name varchar(4096),' 150*564b9527SAdrian Hunter 'build_id varchar(64))') 151*564b9527SAdrian Hunterdo_query(query, 'CREATE TABLE symbols (' 152*564b9527SAdrian Hunter 'id integer NOT NULL PRIMARY KEY,' 153*564b9527SAdrian Hunter 'dso_id bigint,' 154*564b9527SAdrian Hunter 'sym_start bigint,' 155*564b9527SAdrian Hunter 'sym_end bigint,' 156*564b9527SAdrian Hunter 'binding integer,' 157*564b9527SAdrian Hunter 'name varchar(2048))') 158*564b9527SAdrian Hunterdo_query(query, 'CREATE TABLE branch_types (' 159*564b9527SAdrian Hunter 'id integer NOT NULL PRIMARY KEY,' 160*564b9527SAdrian Hunter 'name varchar(80))') 161*564b9527SAdrian Hunter 162*564b9527SAdrian Hunterif branches: 163*564b9527SAdrian Hunter do_query(query, 'CREATE TABLE samples (' 164*564b9527SAdrian Hunter 'id integer NOT NULL PRIMARY KEY,' 165*564b9527SAdrian Hunter 'evsel_id bigint,' 166*564b9527SAdrian Hunter 'machine_id bigint,' 167*564b9527SAdrian Hunter 'thread_id bigint,' 168*564b9527SAdrian Hunter 'comm_id bigint,' 169*564b9527SAdrian Hunter 'dso_id bigint,' 170*564b9527SAdrian Hunter 'symbol_id bigint,' 171*564b9527SAdrian Hunter 'sym_offset bigint,' 172*564b9527SAdrian Hunter 'ip bigint,' 173*564b9527SAdrian Hunter 'time bigint,' 174*564b9527SAdrian Hunter 'cpu integer,' 175*564b9527SAdrian Hunter 'to_dso_id bigint,' 176*564b9527SAdrian Hunter 'to_symbol_id bigint,' 177*564b9527SAdrian Hunter 'to_sym_offset bigint,' 178*564b9527SAdrian Hunter 'to_ip bigint,' 179*564b9527SAdrian Hunter 'branch_type integer,' 180*564b9527SAdrian Hunter 'in_tx boolean,' 181*564b9527SAdrian Hunter 'call_path_id bigint)') 182*564b9527SAdrian Hunterelse: 183*564b9527SAdrian Hunter do_query(query, 'CREATE TABLE samples (' 184*564b9527SAdrian Hunter 'id integer NOT NULL PRIMARY KEY,' 185*564b9527SAdrian Hunter 'evsel_id bigint,' 186*564b9527SAdrian Hunter 'machine_id bigint,' 187*564b9527SAdrian Hunter 'thread_id bigint,' 188*564b9527SAdrian Hunter 'comm_id bigint,' 189*564b9527SAdrian Hunter 'dso_id bigint,' 190*564b9527SAdrian Hunter 'symbol_id bigint,' 191*564b9527SAdrian Hunter 'sym_offset bigint,' 192*564b9527SAdrian Hunter 'ip bigint,' 193*564b9527SAdrian Hunter 'time bigint,' 194*564b9527SAdrian Hunter 'cpu integer,' 195*564b9527SAdrian Hunter 'to_dso_id bigint,' 196*564b9527SAdrian Hunter 'to_symbol_id bigint,' 197*564b9527SAdrian Hunter 'to_sym_offset bigint,' 198*564b9527SAdrian Hunter 'to_ip bigint,' 199*564b9527SAdrian Hunter 'period bigint,' 200*564b9527SAdrian Hunter 'weight bigint,' 201*564b9527SAdrian Hunter 'transaction_ bigint,' 202*564b9527SAdrian Hunter 'data_src bigint,' 203*564b9527SAdrian Hunter 'branch_type integer,' 204*564b9527SAdrian Hunter 'in_tx boolean,' 205*564b9527SAdrian Hunter 'call_path_id bigint)') 206*564b9527SAdrian Hunter 207*564b9527SAdrian Hunterif perf_db_export_calls or perf_db_export_callchains: 208*564b9527SAdrian Hunter do_query(query, 'CREATE TABLE call_paths (' 209*564b9527SAdrian Hunter 'id integer NOT NULL PRIMARY KEY,' 210*564b9527SAdrian Hunter 'parent_id bigint,' 211*564b9527SAdrian Hunter 'symbol_id bigint,' 212*564b9527SAdrian Hunter 'ip bigint)') 213*564b9527SAdrian Hunterif perf_db_export_calls: 214*564b9527SAdrian Hunter do_query(query, 'CREATE TABLE calls (' 215*564b9527SAdrian Hunter 'id integer NOT NULL PRIMARY KEY,' 216*564b9527SAdrian Hunter 'thread_id bigint,' 217*564b9527SAdrian Hunter 'comm_id bigint,' 218*564b9527SAdrian Hunter 'call_path_id bigint,' 219*564b9527SAdrian Hunter 'call_time bigint,' 220*564b9527SAdrian Hunter 'return_time bigint,' 221*564b9527SAdrian Hunter 'branch_count bigint,' 222*564b9527SAdrian Hunter 'call_id bigint,' 223*564b9527SAdrian Hunter 'return_id bigint,' 224*564b9527SAdrian Hunter 'parent_call_path_id bigint,' 225*564b9527SAdrian Hunter 'flags integer)') 226*564b9527SAdrian Hunter 227*564b9527SAdrian Hunter# printf was added to sqlite in version 3.8.3 228*564b9527SAdrian Huntersqlite_has_printf = False 229*564b9527SAdrian Huntertry: 230*564b9527SAdrian Hunter do_query(query, 'SELECT printf("") FROM machines') 231*564b9527SAdrian Hunter sqlite_has_printf = True 232*564b9527SAdrian Hunterexcept: 233*564b9527SAdrian Hunter pass 234*564b9527SAdrian Hunter 235*564b9527SAdrian Hunterdef emit_to_hex(x): 236*564b9527SAdrian Hunter if sqlite_has_printf: 237*564b9527SAdrian Hunter return 'printf("%x", ' + x + ')' 238*564b9527SAdrian Hunter else: 239*564b9527SAdrian Hunter return x 240*564b9527SAdrian Hunter 241*564b9527SAdrian Hunterdo_query(query, 'CREATE VIEW machines_view AS ' 242*564b9527SAdrian Hunter 'SELECT ' 243*564b9527SAdrian Hunter 'id,' 244*564b9527SAdrian Hunter 'pid,' 245*564b9527SAdrian Hunter 'root_dir,' 246*564b9527SAdrian Hunter 'CASE WHEN id=0 THEN \'unknown\' WHEN pid=-1 THEN \'host\' ELSE \'guest\' END AS host_or_guest' 247*564b9527SAdrian Hunter ' FROM machines') 248*564b9527SAdrian Hunter 249*564b9527SAdrian Hunterdo_query(query, 'CREATE VIEW dsos_view AS ' 250*564b9527SAdrian Hunter 'SELECT ' 251*564b9527SAdrian Hunter 'id,' 252*564b9527SAdrian Hunter 'machine_id,' 253*564b9527SAdrian Hunter '(SELECT host_or_guest FROM machines_view WHERE id = machine_id) AS host_or_guest,' 254*564b9527SAdrian Hunter 'short_name,' 255*564b9527SAdrian Hunter 'long_name,' 256*564b9527SAdrian Hunter 'build_id' 257*564b9527SAdrian Hunter ' FROM dsos') 258*564b9527SAdrian Hunter 259*564b9527SAdrian Hunterdo_query(query, 'CREATE VIEW symbols_view AS ' 260*564b9527SAdrian Hunter 'SELECT ' 261*564b9527SAdrian Hunter 'id,' 262*564b9527SAdrian Hunter 'name,' 263*564b9527SAdrian Hunter '(SELECT short_name FROM dsos WHERE id=dso_id) AS dso,' 264*564b9527SAdrian Hunter 'dso_id,' 265*564b9527SAdrian Hunter 'sym_start,' 266*564b9527SAdrian Hunter 'sym_end,' 267*564b9527SAdrian Hunter 'CASE WHEN binding=0 THEN \'local\' WHEN binding=1 THEN \'global\' ELSE \'weak\' END AS binding' 268*564b9527SAdrian Hunter ' FROM symbols') 269*564b9527SAdrian Hunter 270*564b9527SAdrian Hunterdo_query(query, 'CREATE VIEW threads_view AS ' 271*564b9527SAdrian Hunter 'SELECT ' 272*564b9527SAdrian Hunter 'id,' 273*564b9527SAdrian Hunter 'machine_id,' 274*564b9527SAdrian Hunter '(SELECT host_or_guest FROM machines_view WHERE id = machine_id) AS host_or_guest,' 275*564b9527SAdrian Hunter 'process_id,' 276*564b9527SAdrian Hunter 'pid,' 277*564b9527SAdrian Hunter 'tid' 278*564b9527SAdrian Hunter ' FROM threads') 279*564b9527SAdrian Hunter 280*564b9527SAdrian Hunterdo_query(query, 'CREATE VIEW comm_threads_view AS ' 281*564b9527SAdrian Hunter 'SELECT ' 282*564b9527SAdrian Hunter 'comm_id,' 283*564b9527SAdrian Hunter '(SELECT comm FROM comms WHERE id = comm_id) AS command,' 284*564b9527SAdrian Hunter 'thread_id,' 285*564b9527SAdrian Hunter '(SELECT pid FROM threads WHERE id = thread_id) AS pid,' 286*564b9527SAdrian Hunter '(SELECT tid FROM threads WHERE id = thread_id) AS tid' 287*564b9527SAdrian Hunter ' FROM comm_threads') 288*564b9527SAdrian Hunter 289*564b9527SAdrian Hunterif perf_db_export_calls or perf_db_export_callchains: 290*564b9527SAdrian Hunter do_query(query, 'CREATE VIEW call_paths_view AS ' 291*564b9527SAdrian Hunter 'SELECT ' 292*564b9527SAdrian Hunter 'c.id,' 293*564b9527SAdrian Hunter + emit_to_hex('c.ip') + ' AS ip,' 294*564b9527SAdrian Hunter 'c.symbol_id,' 295*564b9527SAdrian Hunter '(SELECT name FROM symbols WHERE id = c.symbol_id) AS symbol,' 296*564b9527SAdrian Hunter '(SELECT dso_id FROM symbols WHERE id = c.symbol_id) AS dso_id,' 297*564b9527SAdrian Hunter '(SELECT dso FROM symbols_view WHERE id = c.symbol_id) AS dso_short_name,' 298*564b9527SAdrian Hunter 'c.parent_id,' 299*564b9527SAdrian Hunter + emit_to_hex('p.ip') + ' AS parent_ip,' 300*564b9527SAdrian Hunter 'p.symbol_id AS parent_symbol_id,' 301*564b9527SAdrian Hunter '(SELECT name FROM symbols WHERE id = p.symbol_id) AS parent_symbol,' 302*564b9527SAdrian Hunter '(SELECT dso_id FROM symbols WHERE id = p.symbol_id) AS parent_dso_id,' 303*564b9527SAdrian Hunter '(SELECT dso FROM symbols_view WHERE id = p.symbol_id) AS parent_dso_short_name' 304*564b9527SAdrian Hunter ' FROM call_paths c INNER JOIN call_paths p ON p.id = c.parent_id') 305*564b9527SAdrian Hunterif perf_db_export_calls: 306*564b9527SAdrian Hunter do_query(query, 'CREATE VIEW calls_view AS ' 307*564b9527SAdrian Hunter 'SELECT ' 308*564b9527SAdrian Hunter 'calls.id,' 309*564b9527SAdrian Hunter 'thread_id,' 310*564b9527SAdrian Hunter '(SELECT pid FROM threads WHERE id = thread_id) AS pid,' 311*564b9527SAdrian Hunter '(SELECT tid FROM threads WHERE id = thread_id) AS tid,' 312*564b9527SAdrian Hunter '(SELECT comm FROM comms WHERE id = comm_id) AS command,' 313*564b9527SAdrian Hunter 'call_path_id,' 314*564b9527SAdrian Hunter + emit_to_hex('ip') + ' AS ip,' 315*564b9527SAdrian Hunter 'symbol_id,' 316*564b9527SAdrian Hunter '(SELECT name FROM symbols WHERE id = symbol_id) AS symbol,' 317*564b9527SAdrian Hunter 'call_time,' 318*564b9527SAdrian Hunter 'return_time,' 319*564b9527SAdrian Hunter 'return_time - call_time AS elapsed_time,' 320*564b9527SAdrian Hunter 'branch_count,' 321*564b9527SAdrian Hunter 'call_id,' 322*564b9527SAdrian Hunter 'return_id,' 323*564b9527SAdrian Hunter 'CASE WHEN flags=1 THEN \'no call\' WHEN flags=2 THEN \'no return\' WHEN flags=3 THEN \'no call/return\' ELSE \'\' END AS flags,' 324*564b9527SAdrian Hunter 'parent_call_path_id' 325*564b9527SAdrian Hunter ' FROM calls INNER JOIN call_paths ON call_paths.id = call_path_id') 326*564b9527SAdrian Hunter 327*564b9527SAdrian Hunterdo_query(query, 'CREATE VIEW samples_view AS ' 328*564b9527SAdrian Hunter 'SELECT ' 329*564b9527SAdrian Hunter 'id,' 330*564b9527SAdrian Hunter 'time,' 331*564b9527SAdrian Hunter 'cpu,' 332*564b9527SAdrian Hunter '(SELECT pid FROM threads WHERE id = thread_id) AS pid,' 333*564b9527SAdrian Hunter '(SELECT tid FROM threads WHERE id = thread_id) AS tid,' 334*564b9527SAdrian Hunter '(SELECT comm FROM comms WHERE id = comm_id) AS command,' 335*564b9527SAdrian Hunter '(SELECT name FROM selected_events WHERE id = evsel_id) AS event,' 336*564b9527SAdrian Hunter + emit_to_hex('ip') + ' AS ip_hex,' 337*564b9527SAdrian Hunter '(SELECT name FROM symbols WHERE id = symbol_id) AS symbol,' 338*564b9527SAdrian Hunter 'sym_offset,' 339*564b9527SAdrian Hunter '(SELECT short_name FROM dsos WHERE id = dso_id) AS dso_short_name,' 340*564b9527SAdrian Hunter + emit_to_hex('to_ip') + ' AS to_ip_hex,' 341*564b9527SAdrian Hunter '(SELECT name FROM symbols WHERE id = to_symbol_id) AS to_symbol,' 342*564b9527SAdrian Hunter 'to_sym_offset,' 343*564b9527SAdrian Hunter '(SELECT short_name FROM dsos WHERE id = to_dso_id) AS to_dso_short_name,' 344*564b9527SAdrian Hunter '(SELECT name FROM branch_types WHERE id = branch_type) AS branch_type_name,' 345*564b9527SAdrian Hunter 'in_tx' 346*564b9527SAdrian Hunter ' FROM samples') 347*564b9527SAdrian Hunter 348*564b9527SAdrian Hunterdo_query(query, 'END TRANSACTION') 349*564b9527SAdrian Hunter 350*564b9527SAdrian Hunterevsel_query = QSqlQuery(db) 351*564b9527SAdrian Hunterevsel_query.prepare("INSERT INTO selected_events VALUES (?, ?)") 352*564b9527SAdrian Huntermachine_query = QSqlQuery(db) 353*564b9527SAdrian Huntermachine_query.prepare("INSERT INTO machines VALUES (?, ?, ?)") 354*564b9527SAdrian Hunterthread_query = QSqlQuery(db) 355*564b9527SAdrian Hunterthread_query.prepare("INSERT INTO threads VALUES (?, ?, ?, ?, ?)") 356*564b9527SAdrian Huntercomm_query = QSqlQuery(db) 357*564b9527SAdrian Huntercomm_query.prepare("INSERT INTO comms VALUES (?, ?)") 358*564b9527SAdrian Huntercomm_thread_query = QSqlQuery(db) 359*564b9527SAdrian Huntercomm_thread_query.prepare("INSERT INTO comm_threads VALUES (?, ?, ?)") 360*564b9527SAdrian Hunterdso_query = QSqlQuery(db) 361*564b9527SAdrian Hunterdso_query.prepare("INSERT INTO dsos VALUES (?, ?, ?, ?, ?)") 362*564b9527SAdrian Huntersymbol_query = QSqlQuery(db) 363*564b9527SAdrian Huntersymbol_query.prepare("INSERT INTO symbols VALUES (?, ?, ?, ?, ?, ?)") 364*564b9527SAdrian Hunterbranch_type_query = QSqlQuery(db) 365*564b9527SAdrian Hunterbranch_type_query.prepare("INSERT INTO branch_types VALUES (?, ?)") 366*564b9527SAdrian Huntersample_query = QSqlQuery(db) 367*564b9527SAdrian Hunterif branches: 368*564b9527SAdrian Hunter sample_query.prepare("INSERT INTO samples VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)") 369*564b9527SAdrian Hunterelse: 370*564b9527SAdrian Hunter sample_query.prepare("INSERT INTO samples VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)") 371*564b9527SAdrian Hunterif perf_db_export_calls or perf_db_export_callchains: 372*564b9527SAdrian Hunter call_path_query = QSqlQuery(db) 373*564b9527SAdrian Hunter call_path_query.prepare("INSERT INTO call_paths VALUES (?, ?, ?, ?)") 374*564b9527SAdrian Hunterif perf_db_export_calls: 375*564b9527SAdrian Hunter call_query = QSqlQuery(db) 376*564b9527SAdrian Hunter call_query.prepare("INSERT INTO calls VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)") 377*564b9527SAdrian Hunter 378*564b9527SAdrian Hunterdef trace_begin(): 379*564b9527SAdrian Hunter print datetime.datetime.today(), "Writing records..." 380*564b9527SAdrian Hunter do_query(query, 'BEGIN TRANSACTION') 381*564b9527SAdrian Hunter # id == 0 means unknown. It is easier to create records for them than replace the zeroes with NULLs 382*564b9527SAdrian Hunter evsel_table(0, "unknown") 383*564b9527SAdrian Hunter machine_table(0, 0, "unknown") 384*564b9527SAdrian Hunter thread_table(0, 0, 0, -1, -1) 385*564b9527SAdrian Hunter comm_table(0, "unknown") 386*564b9527SAdrian Hunter dso_table(0, 0, "unknown", "unknown", "") 387*564b9527SAdrian Hunter symbol_table(0, 0, 0, 0, 0, "unknown") 388*564b9527SAdrian Hunter 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*564b9527SAdrian Hunter if perf_db_export_calls or perf_db_export_callchains: 390*564b9527SAdrian Hunter call_path_table(0, 0, 0, 0) 391*564b9527SAdrian Hunter 392*564b9527SAdrian Hunterunhandled_count = 0 393*564b9527SAdrian Hunter 394*564b9527SAdrian Hunterdef trace_end(): 395*564b9527SAdrian Hunter do_query(query, 'END TRANSACTION') 396*564b9527SAdrian Hunter 397*564b9527SAdrian Hunter print datetime.datetime.today(), "Adding indexes" 398*564b9527SAdrian Hunter if perf_db_export_calls: 399*564b9527SAdrian Hunter do_query(query, 'CREATE INDEX pcpid_idx ON calls (parent_call_path_id)') 400*564b9527SAdrian Hunter 401*564b9527SAdrian Hunter if (unhandled_count): 402*564b9527SAdrian Hunter print datetime.datetime.today(), "Warning: ", unhandled_count, " unhandled events" 403*564b9527SAdrian Hunter print datetime.datetime.today(), "Done" 404*564b9527SAdrian Hunter 405*564b9527SAdrian Hunterdef trace_unhandled(event_name, context, event_fields_dict): 406*564b9527SAdrian Hunter global unhandled_count 407*564b9527SAdrian Hunter unhandled_count += 1 408*564b9527SAdrian Hunter 409*564b9527SAdrian Hunterdef sched__sched_switch(*x): 410*564b9527SAdrian Hunter pass 411*564b9527SAdrian Hunter 412*564b9527SAdrian Hunterdef bind_exec(q, n, x): 413*564b9527SAdrian Hunter for xx in x[0:n]: 414*564b9527SAdrian Hunter q.addBindValue(str(xx)) 415*564b9527SAdrian Hunter do_query_(q) 416*564b9527SAdrian Hunter 417*564b9527SAdrian Hunterdef evsel_table(*x): 418*564b9527SAdrian Hunter bind_exec(evsel_query, 2, x) 419*564b9527SAdrian Hunter 420*564b9527SAdrian Hunterdef machine_table(*x): 421*564b9527SAdrian Hunter bind_exec(machine_query, 3, x) 422*564b9527SAdrian Hunter 423*564b9527SAdrian Hunterdef thread_table(*x): 424*564b9527SAdrian Hunter bind_exec(thread_query, 5, x) 425*564b9527SAdrian Hunter 426*564b9527SAdrian Hunterdef comm_table(*x): 427*564b9527SAdrian Hunter bind_exec(comm_query, 2, x) 428*564b9527SAdrian Hunter 429*564b9527SAdrian Hunterdef comm_thread_table(*x): 430*564b9527SAdrian Hunter bind_exec(comm_thread_query, 3, x) 431*564b9527SAdrian Hunter 432*564b9527SAdrian Hunterdef dso_table(*x): 433*564b9527SAdrian Hunter bind_exec(dso_query, 5, x) 434*564b9527SAdrian Hunter 435*564b9527SAdrian Hunterdef symbol_table(*x): 436*564b9527SAdrian Hunter bind_exec(symbol_query, 6, x) 437*564b9527SAdrian Hunter 438*564b9527SAdrian Hunterdef branch_type_table(*x): 439*564b9527SAdrian Hunter bind_exec(branch_type_query, 2, x) 440*564b9527SAdrian Hunter 441*564b9527SAdrian Hunterdef sample_table(*x): 442*564b9527SAdrian Hunter if branches: 443*564b9527SAdrian Hunter bind_exec(sample_query, 18, x) 444*564b9527SAdrian Hunter else: 445*564b9527SAdrian Hunter bind_exec(sample_query, 22, x) 446*564b9527SAdrian Hunter 447*564b9527SAdrian Hunterdef call_path_table(*x): 448*564b9527SAdrian Hunter bind_exec(call_path_query, 4, x) 449*564b9527SAdrian Hunter 450*564b9527SAdrian Hunterdef call_return_table(*x): 451*564b9527SAdrian Hunter bind_exec(call_query, 11, x) 452