blob: 65d862bfccfdaf975a08a0eb0e95665eaf560a59 [file]
//===- QueueingTaskDispatcher.cpp -----------------------------------------===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
//
// Contains the implementation of APIs in the orc-rt/QueueingTaskDispatcher.h
// header.
//
//===----------------------------------------------------------------------===//
#include "orc-rt/QueueingTaskDispatcher.h"
#include <cassert>
namespace orc_rt {
void QueueingTaskDispatcher::TaskQueue::addTask(std::unique_ptr<Task> T) {
{
std::scoped_lock<std::mutex> Lock(M);
if (State == Running)
Tasks.push_back(std::move(T));
}
CV.notify_one();
}
void QueueingTaskDispatcher::TaskQueue::shutdown() {
{
std::scoped_lock<std::mutex> Lock(M);
State = Shutdown;
}
CV.notify_all();
}
std::unique_ptr<Task> QueueingTaskDispatcher::TaskQueue::takeLastIn() {
std::unique_lock<std::mutex> Lock(M);
CV.wait(Lock, [&]() { return !Tasks.empty() || State == Shutdown; });
if (Tasks.empty())
return nullptr;
auto T = std::move(Tasks.back());
Tasks.pop_back();
return T;
}
std::unique_ptr<Task> QueueingTaskDispatcher::TaskQueue::takeFirstIn() {
std::unique_lock<std::mutex> Lock(M);
CV.wait(Lock, [&]() { return !Tasks.empty() || State == Shutdown; });
if (Tasks.empty())
return nullptr;
auto T = std::move(Tasks.front());
Tasks.pop_front();
return T;
}
void QueueingTaskDispatcher::TaskQueue::runLIFOUntilEmpty() {
while (auto T = takeLastIn())
T->run();
}
void QueueingTaskDispatcher::TaskQueue::runFIFOUntilEmpty() {
while (auto T = takeFirstIn())
T->run();
}
void QueueingTaskDispatcher::dispatch(std::unique_ptr<Task> T) {
Q.addTask(std::move(T));
}
void QueueingTaskDispatcher::shutdown() { Q.shutdown(); }
} // namespace orc_rt