summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTobias Markmann <tm@ayena.de>2015-02-01 15:34:51 (GMT)
committerSwift Review <review@swift.im>2015-02-08 12:04:23 (GMT)
commit19656914a7f9007c9e54588939c85752e509376c (patch)
treea6e2923453aec3d3e9ecc9c4328e22482cf741b9 /Swiften/Network
parent9f6d02730918faa041afc39ec51b57675b4c5c1d (diff)
downloadswift-19656914a7f9007c9e54588939c85752e509376c.zip
swift-19656914a7f9007c9e54588939c85752e509376c.tar.bz2
Fix data race in PlatformDomainNameResolver reported by TSAN
Test-Information: All tests still succeed on OS X and Linux. Change-Id: I2c02252b646b539b960cad18b6f88807afd84d32
Diffstat (limited to 'Swiften/Network')
-rw-r--r--Swiften/Network/PlatformDomainNameResolver.h5
1 files changed, 3 insertions, 2 deletions
diff --git a/Swiften/Network/PlatformDomainNameResolver.h b/Swiften/Network/PlatformDomainNameResolver.h
index 95c866a..e2d28a9 100644
--- a/Swiften/Network/PlatformDomainNameResolver.h
+++ b/Swiften/Network/PlatformDomainNameResolver.h
@@ -1,5 +1,5 @@
/*
- * Copyright (c) 2010-2013 Isode Limited.
+ * Copyright (c) 2010-2015 Isode Limited.
* All rights reserved.
* See the COPYING file for more information.
*/
@@ -12,6 +12,7 @@
#include <boost/thread/condition_variable.hpp>
#include <Swiften/Base/API.h>
+#include <Swiften/Base/Atomic.h>
#include <Swiften/Network/DomainNameResolver.h>
#include <Swiften/Network/PlatformDomainNameQuery.h>
#include <Swiften/Network/DomainNameServiceQuery.h>
@@ -38,7 +39,7 @@ namespace Swift {
friend class PlatformDomainNameAddressQuery;
IDNConverter* idnConverter;
EventLoop* eventLoop;
- bool stopRequested;
+ Atomic<bool> stopRequested;
boost::thread* thread;
std::deque<PlatformDomainNameQuery::ref> queue;
boost::mutex queueMutex;