summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorOwen Anderson <resistor@mac.com>2009-06-18 16:08:27 +0000
committerOwen Anderson <resistor@mac.com>2009-06-18 16:08:27 +0000
commit0fd4eaef3038694dc25b3c13ad21d8ed5b196f50 (patch)
treea13fe3c6d5cd580582acaa8bb520bf0290c6be36
parente1d15c80a381a33df843beb1d46a4e1decce554f (diff)
downloadbcm5719-llvm-0fd4eaef3038694dc25b3c13ad21d8ed5b196f50.tar.gz
bcm5719-llvm-0fd4eaef3038694dc25b3c13ad21d8ed5b196f50.zip
As pointed out by Duncan, I accidentally dropped the first MemoryFence of the
double-checked locking pattern here. llvm-svn: 73701
-rw-r--r--llvm/lib/VMCore/Pass.cpp12
1 files changed, 8 insertions, 4 deletions
diff --git a/llvm/lib/VMCore/Pass.cpp b/llvm/lib/VMCore/Pass.cpp
index 579f1029ac3..70ec108fa18 100644
--- a/llvm/lib/VMCore/Pass.cpp
+++ b/llvm/lib/VMCore/Pass.cpp
@@ -197,17 +197,21 @@ static PassRegistrar *getPassRegistrar() {
// Use double-checked locking to safely initialize the registrar when
// we're running in multithreaded mode.
- if (!PassRegistrarObj) {
+ PassRegistrar* tmp = PassRegistrarObj;
+ sys::MemoryFence();
+ if (!tmp) {
if (llvm_is_multithreaded()) {
llvm_acquire_global_lock();
- if (!PassRegistrarObj) {
- PassRegistrar* tmp = new PassRegistrar();
+ tmp = PassRegistrarObj;
+ if (!tmp) {
+ tmp = new PassRegistrar();
sys::MemoryFence();
PassRegistrarObj = tmp;
}
llvm_release_global_lock();
- } else
+ } else {
PassRegistrarObj = new PassRegistrar();
+ }
}
return PassRegistrarObj;
}
OpenPOWER on IntegriCloud