diff options
author | Tobias Markmann <tm@ayena.de> | 2015-02-01 15:34:51 (GMT) |
---|---|---|
committer | Swift Review <review@swift.im> | 2015-02-08 12:04:23 (GMT) |
commit | 19656914a7f9007c9e54588939c85752e509376c (patch) | |
tree | a6e2923453aec3d3e9ecc9c4328e22482cf741b9 /Swiften/Network | |
parent | 9f6d02730918faa041afc39ec51b57675b4c5c1d (diff) | |
download | swift-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.h | 5 |
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; |