7afedc63be
* [rocprofv3] rocpd SQLite3 database output support
* Move counters xml and yaml to source/share/rocprofiler-sdk
- more representative of install hierarchy
* Add share/rocprofiler-sdk/rocpd SQL files
* Experimental rocprofiler-sdk SQL API
* rocprofv3 default output format is rocpd
* Fix rocpd event ids for counter collection w/o kernel dispatch
* Remove fktable entries from rocpd_tables.sql
* Fix rocpd schema path
* Fix install component for roctx python bindings
* rocprofiler-sdk-rocpd
- create include/rocprofiler-sdk-rocpd
- create rocprofiler-sdk-rocpd library, package, etc.
- default all "guid" fields to "{{guid}}" in tables
- remove "{{view_uuid}}" support (always unused)
* Migrate rocprofv3 to use rocprofiler-sdk-rocpd
* Fix missing foreign key reference
* Revert change
* Fix cmake comment
* Fix maybe-uninitialized compiler warning
* Fix maybe-uninitialized compiler warning
* Add logging to rocpd_sql_load_schema
* Improve string sanitization when inserting json strings
* Initialize rocpd logging on rocprofiler-sdk-rocpd library load
* Revert lib/output/generatePerfetto.cpp changes
* [temporary] Tweak rocprofv3-test-list-avail-trace-execute test log level
* Update get_install_path for lib/rocprofiler-sdk-rocpd/sql.cpp
- try to resolve issues on RHEL/SLES for dladdr
* Update lib/common/logging.cpp
- enable environ overrides
* dlsym for rocpd_sql_load_schema
* Make dl_info.dli_fname lexically normal
* Implement node_info alternatives if /etc/machine-id does not exist
* Misc include fixes
* SHA256 and UUIDv7 support
* Implement UUIDv7 in generateRocpd.cpp
* Support push/pop environment variables
* Minor tweak
* Fix glog segfaults when unsetting glog env
* Updated CHANGELOG
* Updates tests/pytest-packages
- rocpd_reader.py: RocpdReader
* Update tests / marker_views.sql
- add test_rocpd_data
* Update rocpd_tables.sql
- Use AUTOINCREMENT
- insert "uuid" and "guid" into rocpd_metadata
* Minor updates to generateRocpd.cpp
- don't quote GUID
- use sqlite3_open_v2
- use sqlite3_close_v2
* Update execute_raw_sql_statements_impl
- uses sqlite3_last_insert_rowid for autoincrement
* Update SQL deferred_transaction
- CI check for nullptr to connection
* Apply suggestions from code review
Co-authored-by: Welton, Benjamin <Benjamin.Welton@amd.com>
* Code review updates
- formatting
- replace if with switch
- remove loop for {{uuid}}
* Fix pmc_groups handling in rocprofv3
* Address code review feedback
- Include rocm_version in rocprofv3 version info
- Note `--version` option for `rocprofv3` in CHANGELOG.md
- remove commented out code
* Fix packaging dependencies
* Fix install package step of CI workflow
* Fix install package step of CI workflow
---------
Co-authored-by: Jonathan R. Madsen <jonathanrmadsen@gmail.com>
Co-authored-by: Welton, Benjamin <Benjamin.Welton@amd.com>
930 rader
21 KiB
SQL
930 rader
21 KiB
SQL
--
|
|
-- Useful views
|
|
--
|
|
-- Code objects
|
|
CREATE VIEW IF NOT EXISTS
|
|
`code_objects` AS
|
|
SELECT
|
|
CO.id,
|
|
CO.guid,
|
|
CO.nid,
|
|
CO.pid,
|
|
A.absolute_index AS agent_abs_index,
|
|
CO.uri,
|
|
CO.load_base,
|
|
CO.load_size,
|
|
CO.load_delta,
|
|
CO.storage_type AS storage_type_str,
|
|
JSON_EXTRACT(CO.extdata, '$.size') AS code_object_size,
|
|
JSON_EXTRACT(CO.extdata, '$.storage_type') AS storage_type,
|
|
JSON_EXTRACT(CO.extdata, '$.memory_base') AS memory_base,
|
|
JSON_EXTRACT(CO.extdata, '$.memory_size') AS memory_size
|
|
FROM
|
|
`rocpd_info_code_object` CO
|
|
INNER JOIN `rocpd_info_agent` A ON CO.agent_id = A.id
|
|
AND CO.guid = A.guid;
|
|
|
|
CREATE VIEW IF NOT EXISTS
|
|
`kernel_symbols` AS
|
|
SELECT
|
|
KS.id,
|
|
KS.guid,
|
|
KS.nid,
|
|
KS.pid,
|
|
KS.code_object_id,
|
|
KS.kernel_name,
|
|
KS.display_name,
|
|
KS.kernel_object,
|
|
KS.kernarg_segment_size,
|
|
KS.kernarg_segment_alignment,
|
|
KS.group_segment_size,
|
|
KS.private_segment_size,
|
|
KS.sgpr_count,
|
|
KS.arch_vgpr_count,
|
|
KS.accum_vgpr_count,
|
|
JSON_EXTRACT(KS.extdata, '$.size') AS kernel_symbol_size,
|
|
JSON_EXTRACT(KS.extdata, '$.kernel_id') AS kernel_id,
|
|
JSON_EXTRACT(KS.extdata, '$.kernel_code_entry_byte_offset') AS kernel_code_entry_byte_offset,
|
|
JSON_EXTRACT(KS.extdata, '$.formatted_kernel_name') AS formatted_kernel_name,
|
|
JSON_EXTRACT(KS.extdata, '$.demangled_kernel_name') AS demangled_kernel_name,
|
|
JSON_EXTRACT(KS.extdata, '$.truncated_kernel_name') AS truncated_kernel_name,
|
|
JSON_EXTRACT(KS.extdata, '$.kernel_address.handle') AS kernel_address
|
|
FROM
|
|
`rocpd_info_kernel_symbol` KS;
|
|
|
|
-- Processes
|
|
CREATE VIEW IF NOT EXISTS
|
|
`processes` AS
|
|
SELECT
|
|
N.id AS nid,
|
|
N.machine_id,
|
|
N.system_name,
|
|
N.hostname,
|
|
N.release AS system_release,
|
|
N.version AS system_version,
|
|
P.guid,
|
|
P.ppid,
|
|
P.id AS pid,
|
|
P.init,
|
|
P.start,
|
|
P.end,
|
|
P.fini,
|
|
P.command
|
|
FROM
|
|
`rocpd_info_process` P
|
|
INNER JOIN `rocpd_info_node` N ON N.id = P.nid
|
|
AND N.guid = P.guid;
|
|
|
|
-- Threads
|
|
CREATE VIEW IF NOT EXISTS
|
|
`threads` AS
|
|
SELECT
|
|
N.id AS nid,
|
|
N.machine_id,
|
|
N.system_name,
|
|
N.hostname,
|
|
N.release AS system_release,
|
|
N.version AS system_version,
|
|
P.guid,
|
|
P.ppid,
|
|
P.id AS pid,
|
|
T.id AS tid,
|
|
T.start,
|
|
T.end,
|
|
T.name
|
|
FROM
|
|
`rocpd_info_thread` T
|
|
INNER JOIN `rocpd_info_process` P ON P.id = T.pid
|
|
AND N.guid = T.guid
|
|
INNER JOIN `rocpd_info_node` N ON N.id = T.nid
|
|
AND N.guid = T.guid;
|
|
|
|
-- CPU regions
|
|
CREATE VIEW IF NOT EXISTS
|
|
`regions` AS
|
|
SELECT
|
|
R.id,
|
|
R.guid,
|
|
(
|
|
SELECT
|
|
string
|
|
FROM
|
|
`rocpd_string` RS
|
|
WHERE
|
|
RS.id = E.category_id
|
|
AND RS.guid = E.guid
|
|
) AS category,
|
|
S.string AS name,
|
|
R.nid,
|
|
R.pid,
|
|
R.tid,
|
|
R.start,
|
|
R.end,
|
|
(R.end - R.start) AS duration,
|
|
R.event_id,
|
|
E.stack_id,
|
|
E.parent_stack_id,
|
|
E.correlation_id AS corr_id,
|
|
E.extdata,
|
|
E.call_stack,
|
|
E.line_info
|
|
FROM
|
|
`rocpd_region` R
|
|
INNER JOIN `rocpd_event` E ON E.id = R.event_id
|
|
AND E.guid = R.guid
|
|
INNER JOIN `rocpd_string` S ON S.id = R.name_id
|
|
AND S.guid = R.guid;
|
|
|
|
CREATE VIEW IF NOT EXISTS
|
|
`region_args` AS
|
|
SELECT
|
|
R.id,
|
|
R.guid,
|
|
R.nid,
|
|
R.pid,
|
|
A.type,
|
|
A.name,
|
|
A.value
|
|
FROM
|
|
`rocpd_region` R
|
|
INNER JOIN `rocpd_event` E ON E.id = R.event_id
|
|
AND E.guid = R.guid
|
|
INNER JOIN `rocpd_arg` A ON A.event_id = E.id
|
|
AND A.guid = R.guid;
|
|
|
|
--
|
|
-- Samples
|
|
CREATE VIEW IF NOT EXISTS
|
|
`samples` AS
|
|
SELECT
|
|
R.id,
|
|
R.guid,
|
|
(
|
|
SELECT
|
|
string
|
|
FROM
|
|
`rocpd_string` RS
|
|
WHERE
|
|
RS.id = E.category_id
|
|
AND RS.guid = E.guid
|
|
) AS category,
|
|
(
|
|
SELECT
|
|
string
|
|
FROM
|
|
`rocpd_string` RS
|
|
WHERE
|
|
RS.id = T.name_id
|
|
AND RS.guid = T.guid
|
|
) AS name,
|
|
T.nid,
|
|
T.pid,
|
|
T.tid,
|
|
R.timestamp,
|
|
E.stack_id AS stack_id,
|
|
E.parent_stack_id AS parent_stack_id,
|
|
E.correlation_id AS corr_id,
|
|
E.extdata AS extdata,
|
|
E.call_stack AS call_stack,
|
|
E.line_info AS line_info
|
|
FROM
|
|
`rocpd_sample` R
|
|
INNER JOIN `rocpd_track` T ON T.id = R.track_id
|
|
AND T.guid = R.guid
|
|
INNER JOIN `rocpd_event` E ON E.id = R.event_id
|
|
AND E.guid = R.guid;
|
|
|
|
--
|
|
-- Kernel information
|
|
CREATE VIEW
|
|
`kernels` AS
|
|
SELECT
|
|
K.id,
|
|
K.guid,
|
|
K.tid,
|
|
(
|
|
SELECT
|
|
string
|
|
FROM
|
|
`rocpd_string` RS
|
|
WHERE
|
|
RS.id = E.category_id
|
|
AND RS.guid = E.guid
|
|
) AS category,
|
|
R.string AS region,
|
|
S.display_name AS name,
|
|
K.nid,
|
|
Q.pid,
|
|
A.absolute_index AS agent_abs_index,
|
|
A.logical_index AS agent_log_index,
|
|
A.type_index AS agent_type_index,
|
|
A.type AS agent_type,
|
|
S.code_object_id AS code_object_id,
|
|
K.kernel_id,
|
|
K.dispatch_id,
|
|
K.stream_id,
|
|
K.queue_id,
|
|
Q.name AS queue,
|
|
ST.name AS stream,
|
|
K.start,
|
|
K.end,
|
|
(K.end - K.start) AS duration,
|
|
K.grid_size_x AS grid_x,
|
|
K.grid_size_y AS grid_y,
|
|
K.grid_size_z AS grid_z,
|
|
K.workgroup_size_x AS workgroup_x,
|
|
K.workgroup_size_y AS workgroup_y,
|
|
K.workgroup_size_z AS workgroup_z,
|
|
K.group_segment_size AS lds_size,
|
|
K.private_segment_size AS scratch_size,
|
|
S.group_segment_size AS static_lds_size,
|
|
S.private_segment_size AS static_scratch_size,
|
|
E.stack_id,
|
|
E.parent_stack_id,
|
|
E.correlation_id AS corr_id
|
|
FROM
|
|
`rocpd_kernel_dispatch` K
|
|
INNER JOIN `rocpd_info_agent` A ON A.id = K.agent_id
|
|
AND A.guid = K.guid
|
|
INNER JOIN `rocpd_event` E ON E.id = K.event_id
|
|
AND E.guid = K.guid
|
|
INNER JOIN `rocpd_string` R ON R.id = K.region_name_id
|
|
AND R.guid = K.guid
|
|
INNER JOIN `rocpd_info_kernel_symbol` S ON S.id = K.kernel_id
|
|
AND S.guid = K.guid
|
|
LEFT JOIN `rocpd_info_stream` ST ON ST.id = K.stream_id
|
|
AND ST.guid = K.guid
|
|
LEFT JOIN `rocpd_info_queue` Q ON Q.id = K.queue_id
|
|
AND Q.guid = K.guid;
|
|
|
|
CREATE VIEW
|
|
`kernels_renamed` AS
|
|
SELECT
|
|
K.id,
|
|
K.guid,
|
|
K.tid,
|
|
(
|
|
SELECT
|
|
string
|
|
FROM
|
|
`rocpd_string` RS
|
|
WHERE
|
|
RS.id = E.category_id
|
|
AND RS.guid = E.guid
|
|
) AS category,
|
|
R.string AS region,
|
|
R.string AS name,
|
|
K.nid,
|
|
Q.pid,
|
|
A.absolute_index AS agent_abs_index,
|
|
A.logical_index AS agent_log_index,
|
|
A.type_index AS agent_type_index,
|
|
A.type AS agent_type,
|
|
S.code_object_id AS code_object_id,
|
|
K.kernel_id,
|
|
K.dispatch_id,
|
|
K.stream_id,
|
|
K.queue_id,
|
|
Q.name AS queue,
|
|
ST.name AS stream,
|
|
K.start,
|
|
K.end,
|
|
(K.end - K.start) AS duration,
|
|
K.grid_size_x AS grid_x,
|
|
K.grid_size_y AS grid_y,
|
|
K.grid_size_z AS grid_z,
|
|
K.workgroup_size_x AS workgroup_x,
|
|
K.workgroup_size_y AS workgroup_y,
|
|
K.workgroup_size_z AS workgroup_z,
|
|
K.group_segment_size AS lds_size,
|
|
K.private_segment_size AS scratch_size,
|
|
S.group_segment_size AS static_lds_size,
|
|
S.private_segment_size AS static_scratch_size,
|
|
E.stack_id,
|
|
E.parent_stack_id,
|
|
E.correlation_id AS corr_id
|
|
FROM
|
|
`rocpd_kernel_dispatch` K
|
|
INNER JOIN `rocpd_info_agent` A ON A.id = K.agent_id
|
|
AND A.guid = K.guid
|
|
INNER JOIN `rocpd_event` E ON E.id = K.event_id
|
|
AND E.guid = K.guid
|
|
INNER JOIN `rocpd_string` R ON R.id = K.region_name_id
|
|
AND R.guid = K.guid
|
|
INNER JOIN `rocpd_info_kernel_symbol` S ON S.id = K.kernel_id
|
|
AND S.guid = K.guid
|
|
LEFT JOIN `rocpd_info_stream` ST ON ST.id = K.stream_id
|
|
AND ST.guid = K.guid
|
|
LEFT JOIN `rocpd_info_queue` Q ON Q.id = K.queue_id
|
|
AND Q.guid = K.guid;
|
|
|
|
--
|
|
-- Performance Monitoring Counters (PMC)
|
|
CREATE VIEW IF NOT EXISTS
|
|
`pmc_info` AS
|
|
SELECT
|
|
PMC_I.id,
|
|
PMC_I.guid,
|
|
PMC_I.nid,
|
|
PMC_I.pid,
|
|
A.absolute_index AS agent_abs_index,
|
|
PMC_I.is_constant,
|
|
PMC_I.is_derived,
|
|
PMC_I.name,
|
|
PMC_I.description,
|
|
PMC_I.block,
|
|
PMC_I.expression
|
|
FROM
|
|
`rocpd_info_pmc` PMC_I
|
|
INNER JOIN `rocpd_info_agent` A ON PMC_I.agent_id = A.id
|
|
AND PMC_I.guid = A.guid;
|
|
|
|
CREATE VIEW IF NOT EXISTS
|
|
`pmc_events` AS
|
|
SELECT
|
|
PMC_E.id,
|
|
PMC_E.guid,
|
|
PMC_E.pmc_id,
|
|
E.id AS event_id,
|
|
(
|
|
SELECT
|
|
string
|
|
FROM
|
|
`rocpd_string` RS
|
|
WHERE
|
|
RS.id = E.category_id
|
|
AND RS.guid = E.guid
|
|
) AS category,
|
|
(
|
|
SELECT
|
|
display_name
|
|
FROM
|
|
`rocpd_info_kernel_symbol` KS
|
|
WHERE
|
|
KS.id = K.kernel_id
|
|
AND KS.guid = K.guid
|
|
) AS name,
|
|
K.nid,
|
|
K.pid,
|
|
K.dispatch_id,
|
|
K.start,
|
|
K.end,
|
|
(K.end - K.start) AS duration,
|
|
PMC_I.name AS counter_name,
|
|
PMC_E.value AS counter_value
|
|
FROM
|
|
`rocpd_pmc_event` PMC_E
|
|
INNER JOIN `rocpd_info_pmc` PMC_I ON PMC_I.id = PMC_E.pmc_id
|
|
AND PMC_I.guid = PMC_E.guid
|
|
INNER JOIN `rocpd_event` E ON E.id = PMC_E.event_id
|
|
AND E.guid = PMC_E.guid
|
|
INNER JOIN `rocpd_kernel_dispatch` K ON K.event_id = PMC_E.event_id
|
|
AND K.guid = PMC_E.guid;
|
|
|
|
-- events with arguments ---
|
|
CREATE VIEW IF NOT EXISTS
|
|
`events_args` AS
|
|
SELECT
|
|
E.id AS event_id,
|
|
(
|
|
SELECT
|
|
string
|
|
FROM
|
|
`rocpd_string` RS
|
|
WHERE
|
|
RS.id = E.category_id
|
|
AND RS.guid = E.guid
|
|
) AS category,
|
|
E.stack_id,
|
|
E.parent_stack_id,
|
|
E.correlation_id,
|
|
A.position AS arg_position,
|
|
A.type AS arg_type,
|
|
A.name AS arg_name,
|
|
A.value AS arg_value,
|
|
E.call_stack,
|
|
E.line_info,
|
|
A.extdata
|
|
FROM
|
|
`rocpd_event` E
|
|
INNER JOIN `rocpd_arg` A ON A.event_id = E.id
|
|
AND A.guid = E.guid;
|
|
|
|
-- list of astream arguments enriched by the corresponding stream descriptions
|
|
CREATE VIEW IF NOT EXISTS
|
|
`stream_args` AS
|
|
SELECT
|
|
A.id AS argument_id,
|
|
A.event_id AS event_id,
|
|
A.position AS arg_position,
|
|
A.type AS arg_type,
|
|
A.value AS arg_value,
|
|
JSON_EXTRACT(A.extdata, '$.stream_id') AS stream_id,
|
|
S.nid,
|
|
S.pid,
|
|
S.name AS stream_name,
|
|
S.extdata AS extdata
|
|
FROM
|
|
`rocpd_arg` A
|
|
INNER JOIN `rocpd_info_stream` S ON JSON_EXTRACT(A.extdata, '$.stream_id') = S.id
|
|
AND A.guid = S.guid
|
|
WHERE
|
|
A.name = 'stream';
|
|
|
|
--
|
|
--
|
|
CREATE VIEW IF NOT EXISTS
|
|
`memory_copies` AS
|
|
SELECT
|
|
M.id,
|
|
M.guid,
|
|
(
|
|
SELECT
|
|
string
|
|
FROM
|
|
`rocpd_string` RS
|
|
WHERE
|
|
RS.id = E.category_id
|
|
AND RS.guid = E.guid
|
|
) AS category,
|
|
M.nid,
|
|
M.pid,
|
|
M.tid,
|
|
M.start,
|
|
M.end,
|
|
(M.end - M.start) AS duration,
|
|
S.string AS name,
|
|
R.string AS region_name,
|
|
M.stream_id,
|
|
M.queue_id,
|
|
ST.name AS stream_name,
|
|
Q.name AS queue_name,
|
|
M.size,
|
|
dst_agent.name AS dst_device,
|
|
dst_agent.absolute_index AS dst_agent_abs_index,
|
|
dst_agent.logical_index AS dst_agent_log_index,
|
|
dst_agent.type_index AS dst_agent_type_index,
|
|
dst_agent.type AS dst_agent_type,
|
|
M.dst_address,
|
|
src_agent.name AS src_device,
|
|
src_agent.absolute_index AS src_agent_abs_index,
|
|
src_agent.logical_index AS src_agent_log_index,
|
|
src_agent.type_index AS src_agent_type_index,
|
|
src_agent.type AS src_agent_type,
|
|
M.src_address,
|
|
E.stack_id,
|
|
E.parent_stack_id,
|
|
E.correlation_id AS corr_id
|
|
FROM
|
|
`rocpd_memory_copy` M
|
|
INNER JOIN `rocpd_string` S ON S.id = M.name_id
|
|
AND S.guid = M.guid
|
|
LEFT JOIN `rocpd_string` R ON R.id = M.region_name_id
|
|
AND R.guid = M.guid
|
|
INNER JOIN `rocpd_info_agent` dst_agent ON dst_agent.id = M.dst_agent_id
|
|
AND dst_agent.guid = M.guid
|
|
INNER JOIN `rocpd_info_agent` src_agent ON src_agent.id = M.src_agent_id
|
|
AND src_agent.guid = M.guid
|
|
LEFT JOIN `rocpd_info_queue` Q ON Q.id = M.queue_id
|
|
AND Q.guid = M.guid
|
|
LEFT JOIN `rocpd_info_stream` ST ON ST.id = M.stream_id
|
|
AND ST.guid = M.guid
|
|
INNER JOIN `rocpd_event` E ON E.id = M.event_id
|
|
AND E.guid = M.guid;
|
|
|
|
--
|
|
--
|
|
CREATE VIEW IF NOT EXISTS
|
|
`memory_allocations` AS
|
|
SELECT
|
|
M.id,
|
|
M.guid,
|
|
(
|
|
SELECT
|
|
string
|
|
FROM
|
|
`rocpd_string` RS
|
|
WHERE
|
|
RS.id = E.category_id
|
|
AND RS.guid = E.guid
|
|
) AS category,
|
|
M.nid,
|
|
M.pid,
|
|
M.tid,
|
|
M.start,
|
|
M.end,
|
|
(M.end - M.start) AS duration,
|
|
M.type,
|
|
M.level,
|
|
A.name AS agent_name,
|
|
A.absolute_index AS agent_abs_index,
|
|
A.logical_index AS agent_log_index,
|
|
A.type_index AS agent_type_index,
|
|
A.type AS agent_type,
|
|
M.address,
|
|
M.size,
|
|
M.queue_id,
|
|
Q.name AS queue_name,
|
|
M.stream_id,
|
|
ST.name AS stream_name,
|
|
E.stack_id,
|
|
E.parent_stack_id,
|
|
E.correlation_id AS corr_id
|
|
FROM
|
|
`rocpd_memory_allocate` M
|
|
LEFT JOIN `rocpd_info_agent` A ON M.agent_id = A.id
|
|
AND M.guid = A.guid
|
|
LEFT JOIN `rocpd_info_queue` Q ON Q.id = M.queue_id
|
|
AND Q.guid = M.guid
|
|
LEFT JOIN `rocpd_info_stream` ST ON ST.id = M.stream_id
|
|
AND ST.guid = M.guid
|
|
INNER JOIN `rocpd_event` E ON E.id = M.event_id
|
|
AND E.guid = M.guid;
|
|
|
|
--
|
|
--
|
|
CREATE VIEW IF NOT EXISTS
|
|
`scratch_memory` AS
|
|
SELECT
|
|
M.id,
|
|
M.guid,
|
|
M.nid,
|
|
M.pid,
|
|
M.type AS operation,
|
|
A.name AS agent_name,
|
|
A.absolute_index AS agent_abs_index,
|
|
A.logical_index AS agent_log_index,
|
|
A.type_index AS agent_type_index,
|
|
A.type AS agent_type,
|
|
M.queue_id,
|
|
M.tid,
|
|
JSON_EXTRACT(M.extdata, '$.flags') AS alloc_flags,
|
|
M.start,
|
|
M.end,
|
|
M.size,
|
|
M.address,
|
|
E.correlation_id,
|
|
E.stack_id,
|
|
E.parent_stack_id,
|
|
E.correlation_id AS corr_id,
|
|
(
|
|
SELECT
|
|
string
|
|
FROM
|
|
`rocpd_string` RS
|
|
WHERE
|
|
RS.id = E.category_id
|
|
AND RS.guid = E.guid
|
|
) AS category,
|
|
E.extdata AS event_extdata
|
|
FROM
|
|
`rocpd_memory_allocate` M
|
|
LEFT JOIN `rocpd_info_agent` A ON M.agent_id = A.id
|
|
AND M.guid = A.guid
|
|
LEFT JOIN `rocpd_info_queue` Q ON Q.id = M.queue_id
|
|
AND Q.guid = M.guid
|
|
INNER JOIN `rocpd_event` E ON E.id = M.event_id
|
|
AND E.guid = M.guid
|
|
WHERE
|
|
M.level = 'SCRATCH'
|
|
ORDER BY
|
|
M.start ASC;
|
|
|
|
--
|
|
--
|
|
CREATE VIEW IF NOT EXISTS
|
|
`counters_collection` AS
|
|
SELECT
|
|
MIN(PMC_E.id) AS id,
|
|
PMC_E.guid,
|
|
K.dispatch_id,
|
|
K.kernel_id,
|
|
E.id AS event_id,
|
|
E.correlation_id,
|
|
E.stack_id,
|
|
E.parent_stack_id,
|
|
K.pid,
|
|
K.tid,
|
|
K.agent_id,
|
|
A.absolute_index AS agent_abs_index,
|
|
A.logical_index AS agent_log_index,
|
|
A.type_index AS agent_type_index,
|
|
A.type AS agent_type,
|
|
K.queue_id,
|
|
k.grid_size_x AS grid_size_x,
|
|
k.grid_size_y AS grid_size_y,
|
|
k.grid_size_z AS grid_size_z,
|
|
(K.grid_size_x * K.grid_size_y * K.grid_size_z) AS grid_size,
|
|
S.display_name AS kernel_name,
|
|
(
|
|
SELECT
|
|
string
|
|
FROM
|
|
`rocpd_string` RS
|
|
WHERE
|
|
RS.id = K.region_name_id
|
|
AND RS.guid = K.guid
|
|
) AS kernel_region,
|
|
K.workgroup_size_x AS workgroup_size_x,
|
|
K.workgroup_size_y AS workgroup_size_y,
|
|
K.workgroup_size_z AS workgroup_size_z,
|
|
(K.workgroup_size_x * K.workgroup_size_y * K.workgroup_size_z) AS workgroup_size,
|
|
K.group_segment_size AS lds_block_size,
|
|
K.private_segment_size AS scratch_size,
|
|
S.arch_vgpr_count AS vgpr_count,
|
|
S.accum_vgpr_count,
|
|
S.sgpr_count,
|
|
PMC_I.name AS counter_name,
|
|
PMC_I.symbol AS counter_symbol,
|
|
PMC_I.component,
|
|
PMC_I.description,
|
|
PMC_I.block,
|
|
PMC_I.expression,
|
|
PMC_I.value_type,
|
|
PMC_I.id AS counter_id,
|
|
SUM(PMC_E.value) AS value,
|
|
K.start,
|
|
K.end,
|
|
PMC_I.is_constant,
|
|
PMC_I.is_derived,
|
|
(K.end - K.start) AS duration,
|
|
(
|
|
SELECT
|
|
string
|
|
FROM
|
|
`rocpd_string` RS
|
|
WHERE
|
|
RS.id = E.category_id
|
|
AND RS.guid = E.guid
|
|
) AS category,
|
|
K.nid,
|
|
E.extdata,
|
|
S.code_object_id
|
|
FROM
|
|
`rocpd_pmc_event` PMC_E
|
|
INNER JOIN `rocpd_info_pmc` PMC_I ON PMC_I.id = PMC_E.pmc_id
|
|
AND PMC_I.guid = PMC_E.guid
|
|
INNER JOIN `rocpd_event` E ON E.id = PMC_E.event_id
|
|
AND E.guid = PMC_E.guid
|
|
INNER JOIN `rocpd_kernel_dispatch` K ON K.event_id = PMC_E.event_id
|
|
AND K.guid = PMC_E.guid
|
|
INNER JOIN `rocpd_info_agent` A ON A.id = K.agent_id
|
|
AND A.guid = K.guid
|
|
INNER JOIN `rocpd_info_kernel_symbol` S ON S.id = K.kernel_id
|
|
AND S.guid = K.guid
|
|
GROUP BY
|
|
PMC_E.guid,
|
|
K.dispatch_id,
|
|
PMC_I.name,
|
|
K.agent_id;
|
|
|
|
--
|
|
-- RCCL API calls
|
|
CREATE VIEW IF NOT EXISTS
|
|
`rccl` AS
|
|
SELECT
|
|
R.id,
|
|
R.guid,
|
|
(
|
|
SELECT
|
|
string
|
|
FROM
|
|
`rocpd_string` RS
|
|
WHERE
|
|
RS.id = E.category_id
|
|
AND RS.guid = E.guid
|
|
) AS category,
|
|
S.string AS name,
|
|
R.nid,
|
|
R.pid,
|
|
R.tid,
|
|
R.start,
|
|
R.end,
|
|
(R.end - R.start) AS duration,
|
|
R.event_id,
|
|
E.stack_id,
|
|
E.parent_stack_id,
|
|
E.correlation_id AS corr_id,
|
|
E.extdata,
|
|
E.call_stack,
|
|
E.line_info
|
|
FROM
|
|
`rocpd_region` R
|
|
INNER JOIN `rocpd_event` E ON E.id = R.event_id
|
|
AND E.guid = R.guid
|
|
INNER JOIN `rocpd_string` S ON S.id = R.name_id
|
|
AND S.guid = R.guid
|
|
WHERE
|
|
(
|
|
SELECT
|
|
string
|
|
FROM
|
|
`rocpd_string` RS
|
|
WHERE
|
|
RS.id = E.category_id
|
|
AND RS.guid = E.guid
|
|
) LIKE 'RCCL_%'
|
|
ORDER BY
|
|
R.start ASC;
|
|
|
|
--
|
|
-- ROCJPEG API calls
|
|
CREATE VIEW IF NOT EXISTS
|
|
`rocjpeg` AS
|
|
SELECT
|
|
R.id,
|
|
R.guid,
|
|
(
|
|
SELECT
|
|
string
|
|
FROM
|
|
`rocpd_string` RS
|
|
WHERE
|
|
RS.id = E.category_id
|
|
AND RS.guid = E.guid
|
|
) AS category,
|
|
S.string AS name,
|
|
R.nid,
|
|
R.pid,
|
|
R.tid,
|
|
R.start,
|
|
R.end,
|
|
(R.end - R.start) AS duration,
|
|
R.event_id,
|
|
E.stack_id,
|
|
E.parent_stack_id,
|
|
E.correlation_id AS corr_id,
|
|
E.extdata,
|
|
E.call_stack,
|
|
E.line_info
|
|
FROM
|
|
`rocpd_region` R
|
|
INNER JOIN `rocpd_event` E ON E.id = R.event_id
|
|
AND E.guid = R.guid
|
|
INNER JOIN `rocpd_string` S ON S.id = R.name_id
|
|
AND S.guid = R.guid
|
|
WHERE
|
|
(
|
|
SELECT
|
|
string
|
|
FROM
|
|
`rocpd_string` RS
|
|
WHERE
|
|
RS.id = E.category_id
|
|
AND RS.guid = E.guid
|
|
) LIKE 'ROCJPEG_%'
|
|
ORDER BY
|
|
R.start ASC;
|
|
|
|
--
|
|
-- ROCDECODE API calls
|
|
CREATE VIEW IF NOT EXISTS
|
|
`rocdecode` AS
|
|
SELECT
|
|
R.id,
|
|
R.guid,
|
|
(
|
|
SELECT
|
|
string
|
|
FROM
|
|
`rocpd_string` RS
|
|
WHERE
|
|
RS.id = E.category_id
|
|
AND RS.guid = E.guid
|
|
) AS category,
|
|
S.string AS name,
|
|
R.nid,
|
|
R.pid,
|
|
R.tid,
|
|
R.start,
|
|
R.end,
|
|
(R.end - R.start) AS duration,
|
|
R.event_id,
|
|
E.stack_id,
|
|
E.parent_stack_id,
|
|
E.correlation_id AS corr_id,
|
|
E.extdata,
|
|
E.call_stack,
|
|
E.line_info
|
|
FROM
|
|
`rocpd_region` R
|
|
INNER JOIN `rocpd_event` E ON E.id = R.event_id
|
|
AND E.guid = R.guid
|
|
INNER JOIN `rocpd_string` S ON S.id = R.name_id
|
|
AND S.guid = R.guid
|
|
WHERE
|
|
(
|
|
SELECT
|
|
string
|
|
FROM
|
|
`rocpd_string` RS
|
|
WHERE
|
|
RS.id = E.category_id
|
|
AND RS.guid = E.guid
|
|
) LIKE 'ROCDECODE_%'
|
|
ORDER BY
|
|
R.start ASC;
|
|
|
|
-- ALL API call regions in one go
|
|
CREATE VIEW IF NOT EXISTS
|
|
`api_regions` AS
|
|
WITH
|
|
category_strings AS (
|
|
SELECT
|
|
RS.id,
|
|
RS.guid,
|
|
RS.string AS category_string
|
|
FROM
|
|
`rocpd_string` RS
|
|
)
|
|
SELECT
|
|
R.id,
|
|
R.guid,
|
|
CS.category_string AS category,
|
|
S.string AS name,
|
|
R.nid,
|
|
R.pid,
|
|
R.tid,
|
|
R.start,
|
|
R.end,
|
|
(R.end - R.start) AS duration,
|
|
R.event_id,
|
|
E.stack_id,
|
|
E.parent_stack_id,
|
|
E.correlation_id AS corr_id,
|
|
E.extdata,
|
|
E.call_stack,
|
|
E.line_info
|
|
FROM
|
|
`rocpd_region` R
|
|
INNER JOIN `rocpd_event` E ON E.id = R.event_id
|
|
AND E.guid = R.guid
|
|
INNER JOIN `rocpd_string` S ON S.id = R.name_id
|
|
AND S.guid = R.guid
|
|
INNER JOIN category_strings CS ON CS.id = E.category_id
|
|
AND CS.guid = E.guid
|
|
WHERE
|
|
CS.category_string LIKE '%HIP_%'
|
|
OR CS.category_string LIKE '%HSA_%'
|
|
OR CS.category_string LIKE 'RCCL_%'
|
|
OR CS.category_string LIKE 'ROCJPEG_%'
|
|
OR CS.category_string LIKE 'ROCDECODE_%'
|
|
ORDER BY
|
|
R.start ASC;
|
|
|
|
-- Threads participating in API calls
|
|
CREATE VIEW IF NOT EXISTS
|
|
`api_threads` AS
|
|
SELECT DISTINCT
|
|
N.id AS nid,
|
|
N.machine_id,
|
|
N.system_name,
|
|
N.hostname,
|
|
N.release AS system_release,
|
|
N.version AS system_version,
|
|
P.guid,
|
|
P.ppid,
|
|
P.id AS pid,
|
|
T.id AS tid,
|
|
T.start,
|
|
T.end,
|
|
T.name
|
|
FROM
|
|
`rocpd_info_thread` T
|
|
INNER JOIN `rocpd_info_process` P ON P.id = T.pid
|
|
AND P.guid = T.guid
|
|
INNER JOIN `rocpd_info_node` N ON N.id = T.nid
|
|
AND N.guid = T.guid
|
|
INNER JOIN (
|
|
SELECT DISTINCT
|
|
tid,
|
|
guid
|
|
FROM
|
|
`api_regions`
|
|
UNION ALL
|
|
SELECT DISTINCT
|
|
tid,
|
|
guid
|
|
FROM
|
|
`kernels`
|
|
UNION ALL
|
|
SELECT DISTINCT
|
|
tid,
|
|
guid
|
|
FROM
|
|
`memory_copies`
|
|
UNION ALL
|
|
SELECT DISTINCT
|
|
tid,
|
|
guid
|
|
FROM
|
|
`memory_allocations`
|
|
UNION ALL
|
|
SELECT DISTINCT
|
|
tid,
|
|
guid
|
|
FROM
|
|
`markers`
|
|
) AS activity ON activity.tid = T.id
|
|
AND activity.guid = T.guid;
|