68ae6cf65f
* adding summary.py to generate tmp <category_region>_summary views
* migrating CSV summary to SDK method of writing CSVs
- Add domain_view to summary.py
- omit the C++ code of writing CSV because it gets revered later anyway
* Add summary subparser and write_sql_view_to_csv function
* adding all <>_summary views generation to summary.py
* add summary_per_rank feature
* add --summary-per-rank
* reconstruct generate_summary_view and create_domain_view
-introduce by_rank
* remove sqr and variance in summary views
* use RocpdImportData instead of connection
* two fixes on summary.py
--modify the generate_summary_view function to return a tuple with view name and sql code
add if_not_exits parameter to generete_summary_view
* Refactor summary.py to allow output path and filename args, and apply time_window
- clean up summary table column headers
- only generate by-rank views if that param is specified
* Add ProcessID to Hostname output and csv, so users can identify the system in the by-rank summaries
* Summary.py, just add hostname to by-rank summaries, instead of creating mapping table
* Summary - migrate csv writer to pandas, for more future flexibility
* Adding a few simple tests for summary.py
* Linting fixes
* add region_categories to summary options
- Automatically retrieve region categories from the database if argument is None
* add backticks for view_names
* fix tests after rebase
* Made code review changes
- fixed whitespace in CMakelists.txt
- adding query.py module & subparser in __main__.py
- refactor summary function to return query
- used query.py to output csv
- used query.py to also output summary to console
- provided new command line options to select summary output to csv or console
* Made fix to jinja template in query.py, as suggested by copilot
* Consolidated output calls to query in export_view function based on feedback
- refactored: helpers, query functions, create view functions
- extended formats to include what query supports (md, html, pdf, json)
- added json format to query, and changed orient=records
- adding jinja2 and reportlab to requirements.txt
* Add version_info for rocpd and roctx
* Add rocpd commandline tool
* Add executable permissions to source/bin/rocpd.py
* Removed rocpd2query, and cleaned up --help examples
---------
Co-authored-by: acanadas <acanadas@amd.com>
Co-authored-by: Jin Tao <jintao12@amd.com>
Co-authored-by: a-canadasruiz <Araceli.CanadasRuiz@amd.com>
Co-authored-by: Jonathan R. Madsen <Jonathan.Madsen@amd.com>
[ROCm/rocprofiler-sdk commit: 3954cedd25]
106 lines
3.1 KiB
Python
106 lines
3.1 KiB
Python
###############################################################################
|
|
# MIT License
|
|
#
|
|
# Copyright (c) 2023 Advanced Micro Devices, Inc.
|
|
#
|
|
# Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
# of this software and associated documentation files (the "Software"), to deal
|
|
# in the Software without restriction, including without limitation the rights
|
|
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
# copies of the Software, and to permit persons to whom the Software is
|
|
# furnished to do so, subject to the following conditions:
|
|
#
|
|
# The above copyright notice and this permission notice shall be included in
|
|
# all copies or substantial portions of the Software.
|
|
#
|
|
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
# THE SOFTWARE.
|
|
###############################################################################
|
|
|
|
|
|
from . import libpyroctx
|
|
from . import context_decorators
|
|
|
|
__all__ = [
|
|
"mark",
|
|
"profilerPause",
|
|
"profilerResume",
|
|
"getThreadId",
|
|
"rangePush",
|
|
"rangePop",
|
|
"rangeStart",
|
|
"rangeStop",
|
|
"nameOsThread",
|
|
"nameHipDevice",
|
|
"context_decorators",
|
|
"version_info",
|
|
]
|
|
|
|
version_info = {
|
|
"version": "@PROJECT_VERSION@",
|
|
"major": int("@PROJECT_VERSION_MAJOR@"),
|
|
"minor": int("@PROJECT_VERSION_MINOR@"),
|
|
"patch": int("@PROJECT_VERSION_PATCH@"),
|
|
"git_revision": "@ROCPROFILER_SDK_GIT_REVISION@",
|
|
"library_arch": "@CMAKE_LIBRARY_ARCHITECTURE@",
|
|
"system_name": "@CMAKE_SYSTEM_NAME@",
|
|
"system_processor": "@CMAKE_SYSTEM_PROCESSOR@",
|
|
"system_version": "@CMAKE_SYSTEM_VERSION@",
|
|
"compiler_id": "@CMAKE_CXX_COMPILER_ID@",
|
|
"compiler_version": "@CMAKE_CXX_COMPILER_VERSION@",
|
|
"rocm_version": "@rocm_version_FULL_VERSION@",
|
|
}
|
|
|
|
|
|
def mark(msg):
|
|
return libpyroctx.roctxMark(msg) if msg is not None else None
|
|
|
|
|
|
def profilerPause(tid=0):
|
|
return libpyroctx.roctxProfilerPause(tid)
|
|
|
|
|
|
def profilerResume(tid=0):
|
|
return libpyroctx.roctxProfilerResume(tid)
|
|
|
|
|
|
def getThreadId():
|
|
return libpyroctx.roctxGetThreadId()
|
|
|
|
|
|
def rangePush(msg):
|
|
return libpyroctx.roctxRangePush(msg)
|
|
|
|
|
|
def rangePop():
|
|
return libpyroctx.roctxRangePop()
|
|
|
|
|
|
def rangeStart(msg):
|
|
return libpyroctx.roctxRangeStart(msg) if msg is not None else None
|
|
|
|
|
|
def rangeStop(id=0):
|
|
return libpyroctx.roctxRangeStop(id) if id is not None else None
|
|
|
|
|
|
def nameOsThread(name):
|
|
return libpyroctx.roctxNameOsThread(name)
|
|
|
|
|
|
# def nameHsaAgent(name, agent):
|
|
# return libpyroctx.roctxNameHsaAgent(name, agent)
|
|
|
|
|
|
def nameHipDevice(name, device_id=0):
|
|
return libpyroctx.roctxNameHipDevice(name, device_id)
|
|
|
|
|
|
# def nameHipStream(name, stream):
|
|
# return libpyroctx.roctxNameHipStream(name, stream)
|