diff options
author | Anders Carlsson <andersca@mac.com> | 2010-02-06 23:23:06 +0000 |
---|---|---|
committer | Anders Carlsson <andersca@mac.com> | 2010-02-06 23:23:06 +0000 |
commit | fcd764a168a7b7c2cab7ed719d8a1f1b74763f0d (patch) | |
tree | a595f4ee3e657f1eb4b4437d09b66b109b78e554 /clang/lib/Frontend/CompilerInvocation.cpp | |
parent | d59cddc09833b538724779f04a6f6bb7d1cef564 (diff) | |
download | llvm-fcd764a168a7b7c2cab7ed719d8a1f1b74763f0d.zip llvm-fcd764a168a7b7c2cab7ed719d8a1f1b74763f0d.tar.gz llvm-fcd764a168a7b7c2cab7ed719d8a1f1b74763f0d.tar.bz2 |
Add support for threadsafe statics, and make them the default (matching gcc).
Daniel, I'd appreciate a review of the driver/cc1 parts.
llvm-svn: 95508
Diffstat (limited to 'clang/lib/Frontend/CompilerInvocation.cpp')
-rw-r--r-- | clang/lib/Frontend/CompilerInvocation.cpp | 8 |
1 files changed, 5 insertions, 3 deletions
diff --git a/clang/lib/Frontend/CompilerInvocation.cpp b/clang/lib/Frontend/CompilerInvocation.cpp index 464c993..5b64c7e 100644 --- a/clang/lib/Frontend/CompilerInvocation.cpp +++ b/clang/lib/Frontend/CompilerInvocation.cpp @@ -480,8 +480,8 @@ static void LangOptsToArgs(const LangOptions &Opts, Res.push_back("-fno-builtin"); if (!Opts.AssumeSaneOperatorNew) Res.push_back("-fno-assume-sane-operator-new"); - if (Opts.ThreadsafeStatics) - llvm::llvm_report_error("FIXME: Not yet implemented!"); + if (!Opts.ThreadsafeStatics) + Res.push_back("-fno-threadsafe-statics"); if (Opts.POSIXThreads) Res.push_back("-pthread"); if (Opts.Blocks) @@ -1155,7 +1155,9 @@ static void ParseLangArgs(LangOptions &Opts, ArgList &Args, Opts.Microsoft = Args.hasArg(OPT_fms_extensions); Opts.WritableStrings = Args.hasArg(OPT_fwritable_strings); if (Args.hasArg(OPT_fno_lax_vector_conversions)) - Opts.LaxVectorConversions = 0; + Opts.LaxVectorConversions = 0; + if (Args.hasArg(OPT_fno_threadsafe_statics)) + Opts.ThreadsafeStatics = 0; Opts.Exceptions = Args.hasArg(OPT_fexceptions); Opts.RTTI = !Args.hasArg(OPT_fno_rtti); Opts.Blocks = Args.hasArg(OPT_fblocks); |