mirror of
https://github.com/zerotier/ZeroTierOne.git
synced 2025-06-06 20:43:44 +02:00
Fix crash on exit (sometimes) in controller.
This commit is contained in:
parent
41c187ba12
commit
39db45e144
2 changed files with 24 additions and 12 deletions
|
@ -436,19 +436,16 @@ EmbeddedNetworkController::EmbeddedNetworkController(Node *node,const char *dbPa
|
||||||
|
|
||||||
EmbeddedNetworkController::~EmbeddedNetworkController()
|
EmbeddedNetworkController::~EmbeddedNetworkController()
|
||||||
{
|
{
|
||||||
_running = false;
|
|
||||||
std::vector<Thread> t;
|
std::vector<Thread> t;
|
||||||
{
|
{
|
||||||
Mutex::Lock _l(_threads_m);
|
Mutex::Lock _l(_threads_m);
|
||||||
|
_running = false;
|
||||||
t = _threads;
|
t = _threads;
|
||||||
}
|
}
|
||||||
if (t.size() > 0) {
|
if (t.size() > 0) {
|
||||||
for(unsigned long i=0,j=(unsigned long)(t.size() * 4);i<j;++i)
|
_queue.stop();
|
||||||
_queue.post((_RQEntry *)0);
|
|
||||||
/*
|
|
||||||
for(std::vector<Thread>::iterator i(t.begin());i!=t.end();++i)
|
for(std::vector<Thread>::iterator i(t.begin());i!=t.end();++i)
|
||||||
Thread::join(*i);
|
Thread::join(*i);
|
||||||
*/
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1117,7 +1114,7 @@ void EmbeddedNetworkController::threadMain()
|
||||||
{
|
{
|
||||||
uint64_t lastCircuitTestCheck = 0;
|
uint64_t lastCircuitTestCheck = 0;
|
||||||
_RQEntry *qe = (_RQEntry *)0;
|
_RQEntry *qe = (_RQEntry *)0;
|
||||||
while ((_running)&&((qe = _queue.get()))) {
|
while ((_running)&&(_queue.get(qe))) {
|
||||||
try {
|
try {
|
||||||
if (qe->type == _RQEntry::RQENTRY_TYPE_REQUEST) {
|
if (qe->type == _RQEntry::RQENTRY_TYPE_REQUEST) {
|
||||||
_request(qe->nwid,qe->fromAddr,qe->requestPacketId,qe->identity,qe->metaData);
|
_request(qe->nwid,qe->fromAddr,qe->requestPacketId,qe->identity,qe->metaData);
|
||||||
|
|
|
@ -42,7 +42,7 @@ template <class T>
|
||||||
class BlockingQueue
|
class BlockingQueue
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
BlockingQueue(void) {}
|
BlockingQueue(void) : r(true) {}
|
||||||
|
|
||||||
inline void post(T t)
|
inline void post(T t)
|
||||||
{
|
{
|
||||||
|
@ -51,19 +51,34 @@ public:
|
||||||
c.notify_one();
|
c.notify_one();
|
||||||
}
|
}
|
||||||
|
|
||||||
inline T get(void)
|
inline void stop(void)
|
||||||
|
{
|
||||||
|
std::lock_guard<std::mutex> lock(m);
|
||||||
|
r = false;
|
||||||
|
c.notify_all();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param value Value to set to next queue item if return value is true
|
||||||
|
* @return False if stop() has been called, true otherwise
|
||||||
|
*/
|
||||||
|
inline bool get(T &value)
|
||||||
{
|
{
|
||||||
std::unique_lock<std::mutex> lock(m);
|
std::unique_lock<std::mutex> lock(m);
|
||||||
while(q.empty())
|
if (!r) return false;
|
||||||
|
while (q.empty()) {
|
||||||
c.wait(lock);
|
c.wait(lock);
|
||||||
T val = q.front();
|
if (!r) return false;
|
||||||
|
}
|
||||||
|
value = q.front();
|
||||||
q.pop();
|
q.pop();
|
||||||
return val;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
volatile bool r;
|
||||||
std::queue<T> q;
|
std::queue<T> q;
|
||||||
mutable std::mutex m;
|
std::mutex m;
|
||||||
std::condition_variable c;
|
std::condition_variable c;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue