diff options
author | Owen Anderson <resistor@mac.com> | 2009-06-18 16:08:27 +0000 |
---|---|---|
committer | Owen Anderson <resistor@mac.com> | 2009-06-18 16:08:27 +0000 |
commit | 0fd4eaef3038694dc25b3c13ad21d8ed5b196f50 (patch) | |
tree | a13fe3c6d5cd580582acaa8bb520bf0290c6be36 | |
parent | e1d15c80a381a33df843beb1d46a4e1decce554f (diff) | |
download | bcm5719-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.cpp | 12 |
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; } |