<div dir="ltr"><div>The MSVC STL has a similar problem, and call_once isn't available in mingw64-win32. We have some hand-rolled double checked locking that you can probably use to workaround it.</div><div><br></div><div>That said, in the long term I would like to be able to rely on standard C++11 constructs.</div></div><div class="gmail_extra"><br><div class="gmail_quote">On Mon, Nov 3, 2014 at 5:19 PM, Samuel F Antao <span dir="ltr"><<a href="mailto:sfantao@us.ibm.com" target="_blank">sfantao@us.ibm.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div>
<p><font face="sans-serif">Hi all,</font><br>
<br>
<font face="sans-serif">I observe that r220932 (Removing the static initializer in ManagedStatic.cpp by using llvm_call_once to initialize the ManagedStatic mutex.) is causing tablegen to segfault in PPC platforms during static initialization. The crash happens while calling  std::call_once introduced by this patch in the wrapper used in getManagedStaticMutex. </font><br>
<br>
<font face="sans-serif">I understand this call is buggy for some platforms (or probably some oldish libstdc++ versions). Is this a known issue? Should we guard LLVM_DEFINE_ONCE_FLAG definition with platform specific macros to avoid the crash, at least for the moment?</font><br>
<br>
<font face="sans-serif">Thanks!</font><span class="HOEnZb"><font color="#888888"><br>
<font face="sans-serif">Samuel</font><br>
</font></span></p></div><br>_______________________________________________<br>
LLVM Developers mailing list<br>
<a href="mailto:LLVMdev@cs.uiuc.edu">LLVMdev@cs.uiuc.edu</a>         <a href="http://llvm.cs.uiuc.edu" target="_blank">http://llvm.cs.uiuc.edu</a><br>
<a href="http://lists.cs.uiuc.edu/mailman/listinfo/llvmdev" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/llvmdev</a><br>
<br></blockquote></div><br></div>