Files
compute-runtime/shared/source/command_stream/host_function_worker_cv.cpp
Kamil Kopryk f84a5fbee9 feature: add host functions workers
* add common host function worker interface
* add worker as a single thread per csr with 3 modes
* add logic for waiting on internal tag, check gpu hang
* if tag is in pending state, read callback data, run callback
and signal completion
* threads will exit the work loop once stop request
is called in finish
* add multi thread unit tests

Related-To: NEO-14577
Signed-off-by: Kamil Kopryk <kamil.kopryk@intel.com>
2025-11-03 12:11:17 +01:00

76 lines
1.9 KiB
C++

/*
* Copyright (C) 2025 Intel Corporation
*
* SPDX-License-Identifier: MIT
*
*/
#include "shared/source/command_stream/host_function_worker_cv.h"
#include "shared/source/command_stream/command_stream_receiver.h"
#include "shared/source/command_stream/host_function.h"
#include "shared/source/utilities/wait_util.h"
namespace NEO {
HostFunctionWorkerCV::HostFunctionWorkerCV(bool skipHostFunctionExecution,
const std::function<void(GraphicsAllocation &)> &downloadAllocationImpl,
GraphicsAllocation *allocation,
HostFunctionData *data)
: IHostFunctionWorker(skipHostFunctionExecution, downloadAllocationImpl, allocation, data) {
}
HostFunctionWorkerCV::~HostFunctionWorkerCV() = default;
void HostFunctionWorkerCV::start() {
std::lock_guard<std::mutex> lg{workerMutex};
if (!worker) {
worker = std::make_unique<std::jthread>([this](std::stop_token st) {
this->workerLoop(st);
});
}
}
void HostFunctionWorkerCV::finish() {
std::lock_guard<std::mutex> lg{workerMutex};
if (worker) {
worker->request_stop();
cv.notify_one();
worker.reset(nullptr);
}
}
void HostFunctionWorkerCV::submit() noexcept {
{
std::lock_guard<std::mutex> lock{pendingAccessMutex};
++pending;
}
cv.notify_one();
}
void HostFunctionWorkerCV::workerLoop(std::stop_token st) noexcept {
std::unique_lock<std::mutex> lock{pendingAccessMutex, std::defer_lock};
while (true) {
lock.lock();
cv.wait(lock, [&]() {
return pending > 0 || st.stop_requested();
});
if (st.stop_requested()) [[unlikely]] {
return;
}
--pending;
lock.unlock();
bool sucess = this->runHostFunction(st);
if (!sucess) [[unlikely]] {
return;
}
}
}
} // namespace NEO