SWDEV-509280 - Combine multiple definitions of callbackQueue into a single function.

Change-Id: Ibbb56136bec2beed71c202d75e8aec9e82640a4e


[ROCm/clr commit: 0324014710]
Αυτή η υποβολή περιλαμβάνεται σε:
kjayapra-amd
2024-12-31 09:47:38 -05:00
υποβλήθηκε από Karthik Jayaprakash
γονέας f8421ce480
υποβολή 712987ed08
3 αρχεία άλλαξαν με 38 προσθήκες και 61 διαγραφές
@@ -2957,38 +2957,6 @@ void Device::getHwEventTime(const amd::Event& event, uint64_t* start, uint64_t*
}
}
// ================================================================================================
static void callbackQueue(hsa_status_t status, hsa_queue_t* queue, void* data) {
if (status != HSA_STATUS_SUCCESS && status != HSA_STATUS_INFO_BREAK) {
Device* dev = reinterpret_cast<Device*>(data);
for (auto it : dev->vgpus()) {
roc::VirtualGPU* vgpu = reinterpret_cast<roc::VirtualGPU*>(it);
if (vgpu->gpu_queue() == queue) {
vgpu->AnalyzeAqlQueue();
}
}
// Abort on device exceptions.
const char* errorMsg = 0;
hsa_status_string(status, &errorMsg);
if (status == HSA_STATUS_ERROR_OUT_OF_RESOURCES) {
size_t global_available_mem = 0;
if (HSA_STATUS_SUCCESS != hsa_agent_get_info(dev->getBackendDevice(),
static_cast<hsa_agent_info_t>(HSA_AMD_AGENT_INFO_MEMORY_AVAIL),
&global_available_mem)) {
LogError("HSA_AMD_AGENT_INFO_MEMORY_AVAIL query failed.");
}
ClPrint(amd::LOG_NONE, amd::LOG_ALWAYS,
"Callback: Queue %p Aborting with error : %s Code: 0x%x Available Free mem : %zu MB",
queue->base_address, errorMsg, status, global_available_mem/Mi);
} else {
ClPrint(amd::LOG_NONE, amd::LOG_ALWAYS,
"Callback: Queue %p aborting with error : %s code: 0x%x", queue->base_address,
errorMsg, status);
}
abort();
}
}
// ================================================================================================
hsa_queue_t* Device::getQueueFromPool(const uint qIndex) {
// Check if queue with refCount 0 is available to use
@@ -3630,6 +3598,39 @@ ProfilingSignal::~ProfilingSignal() {
}
}
// ================================================================================================
void callbackQueue(hsa_status_t status, hsa_queue_t* queue, void* data) {
if (status != HSA_STATUS_SUCCESS && status != HSA_STATUS_INFO_BREAK) {
Device* dev = reinterpret_cast<Device*>(data);
for (auto it : dev->vgpus()) {
roc::VirtualGPU* vgpu = reinterpret_cast<roc::VirtualGPU*>(it);
if (vgpu->gpu_queue() == queue) {
vgpu->AnalyzeAqlQueue();
}
}
// Abort on device exceptions.
const char* errorMsg = 0;
hsa_status_string(status, &errorMsg);
if (status == HSA_STATUS_ERROR_OUT_OF_RESOURCES) {
size_t global_available_mem = 0;
if (HSA_STATUS_SUCCESS != hsa_agent_get_info(dev->getBackendDevice(),
static_cast<hsa_agent_info_t>(HSA_AMD_AGENT_INFO_MEMORY_AVAIL),
&global_available_mem)) {
LogError("HSA_AMD_AGENT_INFO_MEMORY_AVAIL query failed.");
}
ClPrint(amd::LOG_NONE, amd::LOG_ALWAYS,
"Callback: Queue %p Aborting with error : %s Code: 0x%x Available Free mem : %zu MB",
queue->base_address, errorMsg, status, global_available_mem/Mi);
} else {
ClPrint(amd::LOG_NONE, amd::LOG_ALWAYS,
"Callback: Queue %p aborting with error : %s code: 0x%x", queue->base_address,
errorMsg, status);
}
abort();
}
}
// ================================================================================================
#if defined(__clang__)
#if __has_feature(address_sanitizer)
device::UriLocator* Device::createUriLocator() const {
@@ -701,6 +701,9 @@ class Device : public NullDevice {
#endif
#endif
}; // class roc::Device
void callbackQueue(hsa_status_t status, hsa_queue_t* queue, void* data);
} // namespace amd::roc
/**
@@ -2979,33 +2979,6 @@ void VirtualGPU::submitMigrateMemObjects(amd::MigrateMemObjectsCommand& vcmd) {
profilingEnd(vcmd);
}
// ================================================================================================
static void callbackQueue(hsa_status_t status, hsa_queue_t* queue, void* data) {
if (status != HSA_STATUS_SUCCESS && status != HSA_STATUS_INFO_BREAK) {
VirtualGPU* vgpu = reinterpret_cast<VirtualGPU*>(data);
vgpu->AnalyzeAqlQueue();
// Abort on device exceptions.
const char* errorMsg = 0;
hsa_status_string(status, &errorMsg);
if (status == HSA_STATUS_ERROR_OUT_OF_RESOURCES) {
size_t global_available_mem = 0;
if (HSA_STATUS_SUCCESS != hsa_agent_get_info(vgpu->gpu_device(),
static_cast<hsa_agent_info_t>(HSA_AMD_AGENT_INFO_MEMORY_AVAIL),
&global_available_mem)) {
LogError("HSA_AMD_AGENT_INFO_MEMORY_AVAIL query failed.");
}
ClPrint(amd::LOG_NONE, amd::LOG_ALWAYS,
"Callback: Queue %p Aborting with error : %s Code: 0x%x Available Free mem : %zu MB",
queue->base_address, errorMsg, status, global_available_mem/Mi);
} else {
ClPrint(amd::LOG_NONE, amd::LOG_ALWAYS,
"Callback: Queue %p aborting with error : %s code: 0x%x", queue->base_address,
errorMsg, status);
}
abort();
}
}
// ================================================================================================
bool VirtualGPU::createSchedulerParam()
{
@@ -3023,8 +2996,8 @@ bool VirtualGPU::createSchedulerParam()
// The queue is written by multiple threads of the scheduler kernel
if (HSA_STATUS_SUCCESS != hsa_queue_create(gpu_device(), 2048, HSA_QUEUE_TYPE_MULTI,
callbackQueue, this, std::numeric_limits<uint>::max(), std::numeric_limits<uint>::max(),
&schedulerQueue_)) {
callbackQueue, &roc_device_, std::numeric_limits<uint>::max(),
std::numeric_limits<uint>::max(), &schedulerQueue_)) {
break;
}