a579c70b71
* Adding Trace Period feature to rocprofv3 * Adding feature documentation * Update source/bin/rocprofv3.py Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * Fixing format * Moving to Collection Period and changing the input params * Format Fixes * Fixing rebasing issues * Removing atomic include from the tool * Adding more options for units, optimizing the code * Fixing rocprofv3.py * Fixing time conv & adding time controlled app * Fixing format * Changing to shared memory testing methodology * use of shmem use * Fix include headers for transpose-time-controlled.cpp * Format upload-image-to-github.py * Removing shmem and using only env var to dump timestamps from the tool * Tool Fixes + Test Config * Adding Tests * Fixing Review comments * Update trace period implementation * Update trace period tests * check between start and stop timestamps * Merge Fix * Update validate.py * Improve safety of rocprofiler_stop_context after finalization * Pass context id to collection_period_cntrl by value * Adding 20 us error margin * Ensure log level for collection-period test is not more than warning --------- Co-authored-by: Ammar ELWazir <aelwazir@amd.com> Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: Jonathan R. Madsen <jonathanrmadsen@gmail.com>
135 라인
4.8 KiB
C++
135 라인
4.8 KiB
C++
// MIT License
|
|
//
|
|
// Copyright (c) 2023 Advanced Micro Devices, Inc. All rights reserved.
|
|
//
|
|
// 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.
|
|
|
|
#include <rocprofiler-sdk/context.h>
|
|
#include <rocprofiler-sdk/fwd.h>
|
|
#include <rocprofiler-sdk/rocprofiler.h>
|
|
|
|
#include "lib/rocprofiler-sdk/context/context.hpp"
|
|
#include "lib/rocprofiler-sdk/context/domain.hpp"
|
|
#include "lib/rocprofiler-sdk/hsa/hsa.hpp"
|
|
#include "lib/rocprofiler-sdk/registration.hpp"
|
|
|
|
#include <atomic>
|
|
#include <vector>
|
|
|
|
namespace
|
|
{
|
|
constexpr auto rocprofiler_context_none = ROCPROFILER_CONTEXT_NONE;
|
|
}
|
|
|
|
extern "C" {
|
|
rocprofiler_status_t
|
|
rocprofiler_create_context(rocprofiler_context_id_t* context_id)
|
|
{
|
|
if(context_id->handle != 0) return ROCPROFILER_STATUS_ERROR_CONTEXT_ID_NOT_ZERO;
|
|
// context already registered
|
|
if(rocprofiler::context::get_registered_context(*context_id))
|
|
return ROCPROFILER_STATUS_ERROR_CONTEXT_INVALID;
|
|
|
|
// always set to none first
|
|
*context_id = rocprofiler_context_none;
|
|
|
|
if(rocprofiler::registration::get_init_status() > -1)
|
|
return ROCPROFILER_STATUS_ERROR_CONFIGURATION_LOCKED;
|
|
|
|
auto cfg_id = rocprofiler::context::allocate_context();
|
|
if(!cfg_id) return ROCPROFILER_STATUS_ERROR_CONTEXT_ERROR;
|
|
*context_id = *cfg_id;
|
|
return ROCPROFILER_STATUS_SUCCESS;
|
|
}
|
|
|
|
rocprofiler_status_t
|
|
rocprofiler_start_context(rocprofiler_context_id_t context_id)
|
|
{
|
|
if(context_id.handle == rocprofiler_context_none.handle ||
|
|
!rocprofiler::context::get_registered_context(context_id))
|
|
return ROCPROFILER_STATUS_ERROR_CONTEXT_NOT_FOUND;
|
|
|
|
// if currently finalizing or finalized, don't allow starting a context
|
|
if(rocprofiler::registration::get_fini_status() != 0)
|
|
return ROCPROFILER_STATUS_ERROR_CONFIGURATION_LOCKED;
|
|
|
|
return rocprofiler::context::start_context(context_id);
|
|
}
|
|
|
|
rocprofiler_status_t
|
|
rocprofiler_stop_context(rocprofiler_context_id_t context_id)
|
|
{
|
|
if(context_id.handle == rocprofiler_context_none.handle ||
|
|
!rocprofiler::context::get_registered_context(context_id))
|
|
return ROCPROFILER_STATUS_ERROR_CONTEXT_NOT_FOUND;
|
|
|
|
// if finalized, context is already stopped
|
|
if(rocprofiler::registration::get_fini_status() > 0) return ROCPROFILER_STATUS_SUCCESS;
|
|
|
|
return rocprofiler::context::stop_context(context_id);
|
|
}
|
|
|
|
rocprofiler_status_t
|
|
rocprofiler_context_is_active(rocprofiler_context_id_t context_id, int* status)
|
|
{
|
|
// make sure that status is zero (if not active) regardless of initial value
|
|
*status = 0;
|
|
|
|
// return context not found if not registered
|
|
if(context_id.handle == rocprofiler_context_none.handle ||
|
|
!rocprofiler::context::get_registered_context(context_id))
|
|
return ROCPROFILER_STATUS_ERROR_CONTEXT_NOT_FOUND;
|
|
|
|
// set status to 1 if found in active context array
|
|
for(const auto* itr : rocprofiler::context::get_active_contexts())
|
|
{
|
|
if(itr && itr->context_idx == context_id.handle)
|
|
{
|
|
*status = 1;
|
|
return ROCPROFILER_STATUS_SUCCESS;
|
|
}
|
|
}
|
|
|
|
// context was not found in active array so status value is still zero
|
|
return ROCPROFILER_STATUS_SUCCESS;
|
|
}
|
|
|
|
rocprofiler_status_t
|
|
rocprofiler_context_is_valid(rocprofiler_context_id_t context_id, int* status)
|
|
{
|
|
*status = 0;
|
|
|
|
if(context_id.handle == rocprofiler_context_none.handle ||
|
|
!rocprofiler::context::get_registered_context(context_id))
|
|
return ROCPROFILER_STATUS_ERROR_CONTEXT_NOT_FOUND;
|
|
|
|
for(const auto& itr : rocprofiler::context::get_registered_contexts())
|
|
{
|
|
if(itr && itr->context_idx == context_id.handle)
|
|
{
|
|
auto _ret = rocprofiler::context::validate_context(itr);
|
|
*status = (_ret == ROCPROFILER_STATUS_SUCCESS) ? 1 : 0;
|
|
return _ret;
|
|
}
|
|
}
|
|
|
|
return ROCPROFILER_STATUS_ERROR_CONTEXT_NOT_FOUND;
|
|
}
|
|
}
|