summaryrefslogtreecommitdiff
path: root/controller/JSONDB.hpp
diff options
context:
space:
mode:
authorAdam Ierymenko <adam.ierymenko@gmail.com>2017-04-26 12:17:43 -0700
committerAdam Ierymenko <adam.ierymenko@gmail.com>2017-04-26 12:17:43 -0700
commite8ab6adf8902dce98b4721e2f4a5382e54bcbcbc (patch)
tree83265f860d94999bbb7d4eb765b779d8a7ab75e5 /controller/JSONDB.hpp
parent7c184cf9919fb9d01b8279397e7b20fa756dc981 (diff)
downloadinfinitytier-e8ab6adf8902dce98b4721e2f4a5382e54bcbcbc.tar.gz
infinitytier-e8ab6adf8902dce98b4721e2f4a5382e54bcbcbc.zip
Deadlock fix.
Diffstat (limited to 'controller/JSONDB.hpp')
-rw-r--r--controller/JSONDB.hpp19
1 files changed, 6 insertions, 13 deletions
diff --git a/controller/JSONDB.hpp b/controller/JSONDB.hpp
index 55ead4ea..f89ff6c9 100644
--- a/controller/JSONDB.hpp
+++ b/controller/JSONDB.hpp
@@ -82,19 +82,12 @@ public:
inline bool getNetworkSummaryInfo(const uint64_t networkId,NetworkSummaryInfo &ns) const
{
- for(;;) {
- {
- Mutex::Lock _l(_networks_m);
- std::unordered_map<uint64_t,_NW>::const_iterator i(_networks.find(networkId));
- if (i == _networks.end())
- return false;
- if (i->second.summaryInfoLastComputed) {
- ns = i->second.summaryInfo;
- return true;
- }
- }
- Thread::sleep(100); // wait for this to be done the first time, which happens when we start
- }
+ Mutex::Lock _l(_networks_m);
+ std::unordered_map<uint64_t,_NW>::const_iterator i(_networks.find(networkId));
+ if (i == _networks.end())
+ return false;
+ ns = i->second.summaryInfo;
+ return true;
}
/**