summaryrefslogtreecommitdiff
path: root/controller
diff options
context:
space:
mode:
authorAdam Ierymenko <adam.ierymenko@gmail.com>2017-05-03 09:48:08 -0700
committerAdam Ierymenko <adam.ierymenko@gmail.com>2017-05-03 09:48:08 -0700
commit39db45e144275092716ad612d58c7b9ba1bc8eed (patch)
treee6e6dc484ec779f3e09e1eaee262fcc6153ac3fa /controller
parent41c187ba12fc05f6e9ccd5f8acbc248c2a3d16e1 (diff)
downloadinfinitytier-39db45e144275092716ad612d58c7b9ba1bc8eed.tar.gz
infinitytier-39db45e144275092716ad612d58c7b9ba1bc8eed.zip
Fix crash on exit (sometimes) in controller.
Diffstat (limited to 'controller')
-rw-r--r--controller/EmbeddedNetworkController.cpp9
1 files changed, 3 insertions, 6 deletions
diff --git a/controller/EmbeddedNetworkController.cpp b/controller/EmbeddedNetworkController.cpp
index 16839c18..8ff8eb83 100644
--- a/controller/EmbeddedNetworkController.cpp
+++ b/controller/EmbeddedNetworkController.cpp
@@ -436,19 +436,16 @@ EmbeddedNetworkController::EmbeddedNetworkController(Node *node,const char *dbPa
EmbeddedNetworkController::~EmbeddedNetworkController()
{
- _running = false;
std::vector<Thread> t;
{
Mutex::Lock _l(_threads_m);
+ _running = false;
t = _threads;
}
if (t.size() > 0) {
- for(unsigned long i=0,j=(unsigned long)(t.size() * 4);i<j;++i)
- _queue.post((_RQEntry *)0);
- /*
+ _queue.stop();
for(std::vector<Thread>::iterator i(t.begin());i!=t.end();++i)
Thread::join(*i);
- */
}
}
@@ -1117,7 +1114,7 @@ void EmbeddedNetworkController::threadMain()
{
uint64_t lastCircuitTestCheck = 0;
_RQEntry *qe = (_RQEntry *)0;
- while ((_running)&&((qe = _queue.get()))) {
+ while ((_running)&&(_queue.get(qe))) {
try {
if (qe->type == _RQEntry::RQENTRY_TYPE_REQUEST) {
_request(qe->nwid,qe->fromAddr,qe->requestPacketId,qe->identity,qe->metaData);