63775f241a
* EvaluateAST and validation of RawAST * Adding MetricDimension class and concepts * set_dimensions() and improved ValidateRawAST() * source formatting (clang-format v11) (#124) Co-authored-by: bwelton <bwelton@users.noreply.github.com> * Addressing 1st round of review comments * Modified the parser production rules to support the right syntax for REDUCE and SELECT derived metric expressions * changes to raw_ast.hpp and fmt::format() * Parser tests updated to support corrected REDUCE and SELECT syntax * changes to EvaluateAST::set_dimensions() and other dimension related code changes * Added a test for EvaluateAST::evaluate() to test basic arithmetic on EvaluateAST * Format source code (via clang-format v11) on sauverma/evaluate-ast (#146) * source formatting (clang-format v11) * Add dimension information to counter record Restructures counter records to have the following design: rocprofiler_record_id_t which is an int64_t that encodes both the counter id and dimension information for the record. The first 16 bits are reserved for the counter id while the last 48 are split among the dimensions specified in rocprofiler_dimension_t (currently 8 bits per dimension). Each of the 8 bits for the dimension stores the dimension value for that dimension for this record (i.e. a value of 8 on dimension XCC would denote XCC[8] for the counter). The split among the dimensions will automatically adjust as dimensions are added or removed. The record also contains a union of {int64_t hw_counter, double derived_counter} to specify the value of the record at rocprofiler_record_id_t. int64_t denotes a physical hardware counter that has integer types while the double is used for derived counters (which type this counters values are needs to be queried separately). * Integration of new id type + other fixes --------- Co-authored-by: sauverma93 <sauverma93@users.noreply.github.com> Co-authored-by: Benjamin Welton <bewelton@amd.com> * Fixed sissues with reduce() implementation and added a test for reduce() * Updated parser syntax for reduce() and updated the parser test. Disabled the test for select() * Build warning fixes * Modifications to support fetching xcc/etc info from agent * Initial plumbing working for single counters, cleanup+tests still needed * Remove string comparison from reduce ops * source formatting (clang-format v11) (#163) Co-authored-by: bwelton <bwelton@users.noreply.github.com> * cmake formatting (cmake-format) (#164) Co-authored-by: bwelton <bwelton@users.noreply.github.com> * source formatting (clang-format v11) (#171) Co-authored-by: bwelton <bwelton@users.noreply.github.com> * Merged with master * source formatting (clang-format v11) (#172) Co-authored-by: bwelton <bwelton@users.noreply.github.com> * source formatting (clang-format v11) (#173) Co-authored-by: bwelton <bwelton@users.noreply.github.com> * Test fix --------- Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: bwelton <bwelton@users.noreply.github.com> Co-authored-by: sauverma93 <sauverma93@users.noreply.github.com> Co-authored-by: Benjamin Welton <bewelton@amd.com>
52 γραμμές
1.8 KiB
C++
52 γραμμές
1.8 KiB
C++
#include <rocprofiler/rocprofiler.h>
|
|
|
|
#include "lib/common/synchronized.hpp"
|
|
#include "lib/common/utility.hpp"
|
|
#include "lib/rocprofiler/aql/helpers.hpp"
|
|
#include "lib/rocprofiler/counters/core.hpp"
|
|
#include "lib/rocprofiler/counters/evaluate_ast.hpp"
|
|
#include "lib/rocprofiler/counters/metrics.hpp"
|
|
#include "lib/rocprofiler/hsa/agent_cache.hpp"
|
|
|
|
extern "C" {
|
|
/**
|
|
* @brief Create Profile Configuration.
|
|
*
|
|
* @param [in] agent Agent identifier
|
|
* @param [in] counters_list List of GPU counters
|
|
* @param [in] counters_count Size of counters list
|
|
* @param [out] config_id Identifier for GPU counters group
|
|
* @return ::rocprofiler_status_t
|
|
*/
|
|
rocprofiler_status_t ROCPROFILER_API
|
|
rocprofiler_create_profile_config(rocprofiler_agent_t agent,
|
|
rocprofiler_counter_id_t* counters_list,
|
|
size_t counters_count,
|
|
rocprofiler_profile_config_id_t* config_id)
|
|
{
|
|
rocprofiler::counters::profile_config config;
|
|
const auto& id_map = rocprofiler::counters::getMetricIdMap();
|
|
|
|
for(size_t i = 0; i < counters_count; i++)
|
|
{
|
|
auto& counter_id = counters_list[i];
|
|
|
|
const auto* metric_ptr = rocprofiler::common::get_val(id_map, counter_id.handle);
|
|
if(!metric_ptr) return ROCPROFILER_STATUS_ERROR_COUNTER_NOT_FOUND;
|
|
config.metrics.push_back(*metric_ptr);
|
|
}
|
|
|
|
config.agent = agent;
|
|
config_id->handle = rocprofiler::counters::create_counter_profile(std::move(config));
|
|
|
|
return ROCPROFILER_STATUS_SUCCESS;
|
|
}
|
|
|
|
rocprofiler_status_t ROCPROFILER_API
|
|
rocprofiler_destroy_profile_config(rocprofiler_profile_config_id_t config_id)
|
|
{
|
|
rocprofiler::counters::destroy_counter_profile(config_id.handle);
|
|
return ROCPROFILER_STATUS_SUCCESS;
|
|
}
|
|
}
|