diff options
author | Douglas Gregor <dgregor@apple.com> | 2010-12-07 00:05:48 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2010-12-07 00:05:48 +0000 |
commit | 9aeaa4d65074c3f4b25551f7b20adf5c87734ad7 (patch) | |
tree | 79a83aa18df886e832f62f122c1c6db16e6f5958 /clang/tools/libclang/CIndexCodeCompletion.cpp | |
parent | 9e1994698d3da8cecec5a6cc5e95b18db913ef4b (diff) | |
download | bcm5719-llvm-9aeaa4d65074c3f4b25551f7b20adf5c87734ad7.tar.gz bcm5719-llvm-9aeaa4d65074c3f4b25551f7b20adf5c87734ad7.zip |
Use atomic operations for libclang's object count tracking.
llvm-svn: 121073
Diffstat (limited to 'clang/tools/libclang/CIndexCodeCompletion.cpp')
-rw-r--r-- | clang/tools/libclang/CIndexCodeCompletion.cpp | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/clang/tools/libclang/CIndexCodeCompletion.cpp b/clang/tools/libclang/CIndexCodeCompletion.cpp index 7441f4fa1d0..02e45052aba 100644 --- a/clang/tools/libclang/CIndexCodeCompletion.cpp +++ b/clang/tools/libclang/CIndexCodeCompletion.cpp @@ -24,6 +24,7 @@ #include "clang/Sema/CodeCompleteConsumer.h" #include "llvm/ADT/SmallString.h" #include "llvm/ADT/StringExtras.h" +#include "llvm/Support/Atomic.h" #include "llvm/Support/CrashRecoveryContext.h" #include "llvm/Support/MemoryBuffer.h" #include "llvm/Support/Timer.h" @@ -256,7 +257,7 @@ struct AllocatedCXCodeCompleteResults : public CXCodeCompleteResults { /// currently active. /// /// Used for debugging purposes only. -static unsigned CodeCompletionResultObjects; +static llvm::sys::cas_flag CodeCompletionResultObjects; AllocatedCXCodeCompleteResults::AllocatedCXCodeCompleteResults() : CXCodeCompleteResults(), @@ -265,7 +266,7 @@ AllocatedCXCodeCompleteResults::AllocatedCXCodeCompleteResults() FileMgr(FileSystemOpts), SourceMgr(*Diag, FileMgr) { if (getenv("LIBCLANG_OBJTRACKING")) { - ++CodeCompletionResultObjects; + llvm::sys::AtomicIncrement(&CodeCompletionResultObjects); fprintf(stderr, "+++ %d completion results\n", CodeCompletionResultObjects); } } @@ -281,7 +282,7 @@ AllocatedCXCodeCompleteResults::~AllocatedCXCodeCompleteResults() { delete TemporaryBuffers[I]; if (getenv("LIBCLANG_OBJTRACKING")) { - --CodeCompletionResultObjects; + llvm::sys::AtomicDecrement(&CodeCompletionResultObjects); fprintf(stderr, "--- %d completion results\n", CodeCompletionResultObjects); } } |