7f631de401
* Update lib/rocprofiler/agent.{hpp,cpp}
- get_agents() function for internal access to agent pointers
* Update AgentCache
- make member variables and member functions distinguish b/t hsa agent and rocprofiler agent clear
* Change ctor of AgentCache
* Update lib/rocprofiler/hsa/queue_controller.cpp
- QueueController::init uses agent::get_agent_cache
* Update lib/rocprofiler/hsa/agent_cache.*
- member function to get index
- operator== for rocprofiler_agent_t and hsa_agent_t
- removed hsa_iterate_agents from ctor (now in agent.cpp)
* Update lib/rocprofiler/agent.*
- construct_agent_cache function
- functions for rocprofiler agent <-> HSA agent
- functions for getting agent cache
* Update lib/rocprofiler/registration.cpp
- invoke construct_agent_cache when HSA table is receieved
* Update lib/rocprofiler/agent.cpp
- loosen failure conditions
- handle spurious duplicate entry warning
* Update lib/rocprofiler/agent.cpp
- improve read_map diagnostics
* Update lib/rocprofiler/agent.cpp
- avoid infinite loop in read_map
* Update lib/rocprofiler/agent.cpp
- handle empty kfd node properties file
* Update lib/rocprofiler/agent.cpp
- check for permissions to read a node properties file
* Update lib/rocprofiler/agent.cpp
- more checks on file readability
* Update lib/rocprofiler/tests/agent.cpp
- print virtual kfd topology
* Update lib/rocprofiler/tests/agent.cpp
- verify id.handle == hsa_agent internal node id
* Update lib/rocprofiler/tests/agent.cpp
- check node_id
- check location id
- check device id
- update abi test
* Update include/rocprofiler/agent.h
- add node_id field
- add reserved0 field to ensure new field increases struct size
* Update lib/rocprofiler/agent.cpp
- node_id instead of id.handle
* Update lib/rocprofiler/agent_cache.cpp
- node_id instead of id.handle
* Update samples/pc_sampling
- node_id for agent instead of id.handle
* Update lib/rocprofiler/buffer.cpp
- remove debug prints
152 строки
4.5 KiB
C++
152 строки
4.5 KiB
C++
#include <glog/logging.h>
|
|
#include <gtest/gtest.h>
|
|
|
|
#include <functional>
|
|
#include <map>
|
|
#include <unordered_set>
|
|
|
|
#include <hsa/hsa.h>
|
|
#include <hsa/hsa_api_trace.h>
|
|
#include <hsa/hsa_ven_amd_aqlprofile.h>
|
|
|
|
#include "lib/rocprofiler/aql/helpers.hpp"
|
|
#include "lib/rocprofiler/aql/packet_construct.hpp"
|
|
#include "lib/rocprofiler/counters/metrics.hpp"
|
|
#include "lib/rocprofiler/hsa/agent_cache.hpp"
|
|
#include "lib/rocprofiler/hsa/queue.hpp"
|
|
#include "lib/rocprofiler/hsa/queue_controller.hpp"
|
|
|
|
namespace rocprofiler
|
|
{
|
|
AmdExtTable
|
|
get_ext_table()
|
|
{
|
|
return {.hsa_amd_memory_pool_get_info_fn = hsa_amd_memory_pool_get_info,
|
|
.hsa_amd_agent_iterate_memory_pools_fn = hsa_amd_agent_iterate_memory_pools,
|
|
.hsa_amd_memory_pool_allocate_fn = hsa_amd_memory_pool_allocate,
|
|
.hsa_amd_memory_pool_free_fn = hsa_amd_memory_pool_free,
|
|
.hsa_amd_agent_memory_pool_get_info_fn = hsa_amd_agent_memory_pool_get_info,
|
|
.hsa_amd_agents_allow_access_fn = hsa_amd_agents_allow_access};
|
|
}
|
|
|
|
auto
|
|
findDeviceMetrics(const hsa::AgentCache& agent, const std::unordered_set<std::string>& metrics)
|
|
{
|
|
std::vector<counters::Metric> ret;
|
|
auto all_counters = counters::getBaseHardwareMetrics();
|
|
|
|
auto gfx_metrics = common::get_val(all_counters, std::string(agent.name()));
|
|
if(!gfx_metrics) return ret;
|
|
|
|
for(auto& counter : *gfx_metrics)
|
|
{
|
|
if(metrics.count(counter.name()) > 0 || metrics.empty())
|
|
{
|
|
ret.push_back(counter);
|
|
}
|
|
}
|
|
return ret;
|
|
}
|
|
|
|
} // namespace rocprofiler
|
|
|
|
using namespace rocprofiler::aql;
|
|
|
|
TEST(aql_profile, construct_packets)
|
|
{
|
|
hsa_init();
|
|
try
|
|
{
|
|
auto agents = rocprofiler::hsa::get_queue_controller().get_supported_agents();
|
|
for(const auto& [_, agent] : agents)
|
|
{
|
|
LOG(WARNING) << fmt::format("Found Agent: {}", agent.get_hsa_agent().handle);
|
|
auto metrics = rocprofiler::findDeviceMetrics(agent, {"SQ_WAVES"});
|
|
ASSERT_EQ(metrics.size(), 1);
|
|
AQLPacketConstruct(agent, metrics);
|
|
}
|
|
} catch(std::runtime_error&)
|
|
{
|
|
LOG(WARNING) << "Could not fetch agents on host, skipping test";
|
|
return;
|
|
}
|
|
hsa_shut_down();
|
|
}
|
|
|
|
TEST(aql_profile, too_many_counters)
|
|
{
|
|
hsa_init();
|
|
try
|
|
{
|
|
auto agents = rocprofiler::hsa::get_queue_controller().get_supported_agents();
|
|
|
|
for(const auto& [_, agent] : agents)
|
|
{
|
|
LOG(WARNING) << fmt::format("Found Agent: {}", agent.get_hsa_agent().handle);
|
|
|
|
auto metrics = rocprofiler::findDeviceMetrics(agent, {});
|
|
EXPECT_THROW(
|
|
{
|
|
try
|
|
{
|
|
AQLPacketConstruct(agent, metrics);
|
|
} catch(const std::exception& e)
|
|
{
|
|
EXPECT_NE(e.what(), nullptr) << e.what();
|
|
throw;
|
|
}
|
|
},
|
|
std::runtime_error);
|
|
}
|
|
} catch(std::runtime_error&)
|
|
{
|
|
LOG(WARNING) << "Could not fetch agents on host, skipping test";
|
|
return;
|
|
}
|
|
hsa_shut_down();
|
|
}
|
|
|
|
TEST(aql_profile, packet_generation_single)
|
|
{
|
|
hsa_init();
|
|
try
|
|
{
|
|
auto agents = rocprofiler::hsa::get_queue_controller().get_supported_agents();
|
|
for(const auto& [_, agent] : agents)
|
|
{
|
|
auto metrics = rocprofiler::findDeviceMetrics(agent, {"SQ_WAVES"});
|
|
AQLPacketConstruct pkt(agent, metrics);
|
|
auto test_pkt = pkt.construct_packet(rocprofiler::get_ext_table());
|
|
EXPECT_TRUE(test_pkt);
|
|
}
|
|
} catch(std::runtime_error&)
|
|
{
|
|
LOG(WARNING) << "Could not fetch agents on host, skipping test";
|
|
return;
|
|
}
|
|
|
|
hsa_shut_down();
|
|
}
|
|
|
|
TEST(aql_profile, packet_generation_multi)
|
|
{
|
|
hsa_init();
|
|
try
|
|
{
|
|
auto agents = rocprofiler::hsa::get_queue_controller().get_supported_agents();
|
|
for(const auto& [_, agent] : agents)
|
|
{
|
|
auto metrics =
|
|
rocprofiler::findDeviceMetrics(agent, {"SQ_WAVES", "TA_FLAT_READ_WAVEFRONTS"});
|
|
AQLPacketConstruct pkt(agent, metrics);
|
|
auto test_pkt = pkt.construct_packet(rocprofiler::get_ext_table());
|
|
EXPECT_TRUE(test_pkt);
|
|
}
|
|
} catch(std::runtime_error&)
|
|
{
|
|
LOG(WARNING) << "Could not fetch agents on host, skipping test";
|
|
return;
|
|
}
|
|
hsa_shut_down();
|
|
}
|