mirror of
https://github.com/oxen-io/lokinet.git
synced 2024-11-03 23:15:52 +00:00
126 lines
2.2 KiB
C++
126 lines
2.2 KiB
C++
#ifndef LLARP_THREADPOOL_HPP
|
|
#define LLARP_THREADPOOL_HPP
|
|
|
|
#include <llarp/threadpool.h>
|
|
#include <llarp/threading.hpp>
|
|
|
|
#include <functional>
|
|
#include <queue>
|
|
|
|
#include <thread>
|
|
#include <vector>
|
|
|
|
namespace llarp
|
|
{
|
|
namespace thread
|
|
{
|
|
typedef util::Mutex mtx_t;
|
|
typedef util::Lock lock_t;
|
|
struct Pool
|
|
{
|
|
virtual void
|
|
Spawn(size_t sz, const char* name);
|
|
|
|
void
|
|
QueueJob(const llarp_thread_job& job);
|
|
|
|
virtual void
|
|
Join();
|
|
|
|
void
|
|
Stop();
|
|
std::vector< std::thread > threads;
|
|
|
|
struct Job_t
|
|
{
|
|
uint32_t id;
|
|
llarp_thread_job* job;
|
|
Job_t(uint32_t jobid, llarp_thread_job* j) : id(jobid), job(j)
|
|
{
|
|
}
|
|
|
|
bool
|
|
operator<(const Job_t& j) const
|
|
{
|
|
return id < j.id;
|
|
}
|
|
};
|
|
|
|
std::priority_queue< Job_t > jobs;
|
|
uint32_t ids = 0;
|
|
mtx_t queue_mutex;
|
|
util::Condition condition;
|
|
util::Condition done;
|
|
bool stop;
|
|
};
|
|
|
|
struct IsolatedPool : public Pool
|
|
{
|
|
IsolatedPool(int flags) : Pool(), m_flags(flags)
|
|
{
|
|
}
|
|
|
|
void
|
|
Spawn(size_t workers, const char* name);
|
|
|
|
void
|
|
Join();
|
|
|
|
// override me to do specific setups after isolation
|
|
// return true for success
|
|
virtual bool
|
|
Isolated()
|
|
{
|
|
return true;
|
|
}
|
|
|
|
/// called when isolation failed
|
|
virtual void
|
|
Fail()
|
|
{
|
|
}
|
|
|
|
std::thread* m_isolated = nullptr;
|
|
int m_flags;
|
|
int m_IsolatedWorkers = 0;
|
|
const char* m_IsolatedName = nullptr;
|
|
|
|
virtual void
|
|
MainLoop()
|
|
{
|
|
}
|
|
};
|
|
|
|
struct NetIsolatedPool : public IsolatedPool
|
|
{
|
|
NetIsolatedPool(std::function< bool(void*, bool) > setupNet,
|
|
std::function< void(void*) > runMain, void* user);
|
|
|
|
bool
|
|
Isolated()
|
|
{
|
|
return m_NetSetup(m_user, true);
|
|
}
|
|
|
|
void
|
|
Fail()
|
|
{
|
|
m_NetSetup(m_user, false);
|
|
}
|
|
|
|
void
|
|
MainLoop()
|
|
{
|
|
m_RunMain(m_user);
|
|
}
|
|
|
|
std::function< bool(void*, bool) > m_NetSetup;
|
|
std::function< void(void*) > m_RunMain;
|
|
void* m_user;
|
|
};
|
|
|
|
} // namespace thread
|
|
} // namespace llarp
|
|
|
|
#endif
|