r212138 - Driver: Handle /GR- in a compatible way with MSVC
Timur Iskhodzhanov
timurrrr at google.com
Tue Jul 8 05:16:48 PDT 2014
This is clearly related to r212125 rather than r212138 so let's continue on
the r212125 thread.
2014-07-08 13:01 GMT+04:00 Timur Iskhodzhanov <timurrrr at google.com>:
> Can you clarify what you're suggesting?
> a) disable ASan instrumentation of vftables
> b) adjust the linkage of vftables to be ASan-friendly
> OR
> c) something else
>
>
> 2014-07-08 4:39 GMT+04:00 David Majnemer <david.majnemer at gmail.com>:
>
> ASAN replaces one internal global with another. Because the new symbol
>> isn't in a Comdat, it's alias isn't either. This makes the alias a
>> strong definition.
>>
>> On Mon, Jul 7, 2014 at 9:43 AM, Timur Iskhodzhanov <timurrrr at google.com>
>> wrote:
>> > I think either this or r212125 broke "check-asan" and Chromium build
>> but it
>> > was hidden by another build failure (r211216).
>> >
>> > Can you please take a look at "TestCases/Windows/dll_cerr.cc" (or
>> Chromium
>> > failures) ?
>> >
>> >
>> > 2014-07-02 2:24 GMT+04:00 David Majnemer <david.majnemer at gmail.com>:
>> >
>> >> Author: majnemer
>> >> Date: Tue Jul 1 17:24:56 2014
>> >> New Revision: 212138
>> >>
>> >> URL: http://llvm.org/viewvc/llvm-project?rev=212138&view=rev
>> >> Log:
>> >> Driver: Handle /GR- in a compatible way with MSVC
>> >>
>> >> There are slight differences between /GR- and -fno-rtti which made
>> >> mapping one to the other inappropriate.
>> >>
>> >> -fno-rtti disables dynamic_cast, typeid, and does not emit RTTI related
>> >> information for the v-table.
>> >>
>> >> /GR- does not generate complete object locators and thus will not
>> >> reference them in vftables. However, constructs like dynamic_cast and
>> >> typeid are permitted.
>> >>
>> >> This should bring our implementation of RTTI up to semantic parity with
>> >> MSVC modulo bugs.
>> >>
>> >> Added:
>> >> cfe/trunk/test/CodeGenCXX/microsoft-no-rtti-data.cpp
>> >> Modified:
>> >> cfe/trunk/include/clang/Basic/LangOptions.def
>> >> cfe/trunk/include/clang/Driver/CC1Options.td
>> >> cfe/trunk/include/clang/Driver/CLCompatOptions.td
>> >> cfe/trunk/lib/AST/VTableBuilder.cpp
>> >> cfe/trunk/lib/Basic/Targets.cpp
>> >> cfe/trunk/lib/CodeGen/MicrosoftCXXABI.cpp
>> >> cfe/trunk/lib/CodeGen/MicrosoftRTTI.cpp
>> >> cfe/trunk/lib/Driver/Tools.cpp
>> >> cfe/trunk/lib/Frontend/CompilerInvocation.cpp
>> >> cfe/trunk/test/Driver/cl-fallback.c
>> >> cfe/trunk/test/Driver/cl-options.c
>> >>
>> >> Modified: cfe/trunk/include/clang/Basic/LangOptions.def
>> >> URL:
>> >>
>> http://llvm.org/viewvc/llvm-project/cfe/trunk/include/clang/Basic/LangOptions.def?rev=212138&r1=212137&r2=212138&view=diff
>> >>
>> >>
>> ==============================================================================
>> >> --- cfe/trunk/include/clang/Basic/LangOptions.def (original)
>> >> +++ cfe/trunk/include/clang/Basic/LangOptions.def Tue Jul 1 17:24:56
>> 2014
>> >> @@ -84,6 +84,7 @@ LANGOPT(CXXExceptions , 1, 0, "C++ e
>> >> LANGOPT(SjLjExceptions , 1, 0, "setjmp-longjump exception
>> handling")
>> >> LANGOPT(TraditionalCPP , 1, 0, "traditional CPP emulation")
>> >> LANGOPT(RTTI , 1, 1, "run-time type information")
>> >> +LANGOPT(RTTIData , 1, 1, "emit run-time type information
>> data")
>> >> LANGOPT(MSBitfields , 1, 0, "Microsoft-compatible structure
>> >> layout")
>> >> LANGOPT(Freestanding, 1, 0, "freestanding implementation")
>> >> LANGOPT(NoBuiltin , 1, 0, "disable builtin functions")
>> >>
>> >> Modified: cfe/trunk/include/clang/Driver/CC1Options.td
>> >> URL:
>> >>
>> http://llvm.org/viewvc/llvm-project/cfe/trunk/include/clang/Driver/CC1Options.td?rev=212138&r1=212137&r2=212138&view=diff
>> >>
>> >>
>> ==============================================================================
>> >> --- cfe/trunk/include/clang/Driver/CC1Options.td (original)
>> >> +++ cfe/trunk/include/clang/Driver/CC1Options.td Tue Jul 1 17:24:56
>> 2014
>> >> @@ -484,6 +484,8 @@ def fobjc_subscripting_legacy_runtime :
>> >> HelpText<"Allow Objective-C array and dictionary subscripting in
>> legacy
>> >> runtime">;
>> >> def vtordisp_mode_EQ : Joined<["-"], "vtordisp-mode=">,
>> >> HelpText<"Control vtordisp placement on win32 targets">;
>> >> +def fno_rtti_data : Flag<["-"], "fno-rtti-data">,
>> >> + HelpText<"Control emission of RTTI data">;
>> >>
>> >>
>> >>
>> //===----------------------------------------------------------------------===//
>> >> // Header Search Options
>> >>
>> >> Modified: cfe/trunk/include/clang/Driver/CLCompatOptions.td
>> >> URL:
>> >>
>> http://llvm.org/viewvc/llvm-project/cfe/trunk/include/clang/Driver/CLCompatOptions.td?rev=212138&r1=212137&r2=212138&view=diff
>> >>
>> >>
>> ==============================================================================
>> >> --- cfe/trunk/include/clang/Driver/CLCompatOptions.td (original)
>> >> +++ cfe/trunk/include/clang/Driver/CLCompatOptions.td Tue Jul 1
>> 17:24:56
>> >> 2014
>> >> @@ -58,8 +58,8 @@ def _SLASH_c : CLFlag<"c">, HelpText<"Co
>> >> def _SLASH_D : CLJoinedOrSeparate<"D">, HelpText<"Define macro">,
>> >> MetaVarName<"<macro[=value]>">, Alias<D>;
>> >> def _SLASH_E : CLFlag<"E">, HelpText<"Preprocess to stdout">,
>> Alias<E>;
>> >> -def _SLASH_GR : CLFlag<"GR">, HelpText<"Enable RTTI">, Alias<frtti>;
>> >> -def _SLASH_GR_ : CLFlag<"GR-">, HelpText<"Disable RTTI">,
>> >> Alias<fno_rtti>;
>> >> +def _SLASH_GR : CLFlag<"GR">, HelpText<"Enable emission of RTTI
>> data">;
>> >> +def _SLASH_GR_ : CLFlag<"GR-">, HelpText<"Disable emission of RTTI
>> >> data">;
>> >> def _SLASH_GF_ : CLFlag<"GF-">, HelpText<"Disable string pooling">,
>> >> Alias<fwritable_strings>;
>> >> def _SLASH_Gy : CLFlag<"Gy">, HelpText<"Put each function in its own
>> >> section">,
>> >>
>> >> Modified: cfe/trunk/lib/AST/VTableBuilder.cpp
>> >> URL:
>> >>
>> http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/AST/VTableBuilder.cpp?rev=212138&r1=212137&r2=212138&view=diff
>> >>
>> >>
>> ==============================================================================
>> >> --- cfe/trunk/lib/AST/VTableBuilder.cpp (original)
>> >> +++ cfe/trunk/lib/AST/VTableBuilder.cpp Tue Jul 1 17:24:56 2014
>> >> @@ -2579,7 +2579,7 @@ public:
>> >> Overriders(MostDerivedClass, CharUnits(), MostDerivedClass) {
>> >> // Only include the RTTI component if we know that we will
>> provide a
>> >> // definition of the vftable.
>> >> - HasRTTIComponent = Context.getLangOpts().RTTI &&
>> >> + HasRTTIComponent = Context.getLangOpts().RTTIData &&
>> >> !MostDerivedClass->hasAttr<DLLImportAttr>();
>> >> if (HasRTTIComponent)
>> >>
>> Components.push_back(VTableComponent::MakeRTTI(MostDerivedClass));
>> >>
>> >> Modified: cfe/trunk/lib/Basic/Targets.cpp
>> >> URL:
>> >>
>> http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Basic/Targets.cpp?rev=212138&r1=212137&r2=212138&view=diff
>> >>
>> >>
>> ==============================================================================
>> >> --- cfe/trunk/lib/Basic/Targets.cpp (original)
>> >> +++ cfe/trunk/lib/Basic/Targets.cpp Tue Jul 1 17:24:56 2014
>> >> @@ -572,7 +572,7 @@ protected:
>> >> void getVisualStudioDefines(const LangOptions &Opts,
>> >> MacroBuilder &Builder) const {
>> >> if (Opts.CPlusPlus) {
>> >> - if (Opts.RTTI)
>> >> + if (Opts.RTTIData)
>> >> Builder.defineMacro("_CPPRTTI");
>> >>
>> >> if (Opts.Exceptions)
>> >>
>> >> Modified: cfe/trunk/lib/CodeGen/MicrosoftCXXABI.cpp
>> >> URL:
>> >>
>> http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/CodeGen/MicrosoftCXXABI.cpp?rev=212138&r1=212137&r2=212138&view=diff
>> >>
>> >>
>> ==============================================================================
>> >> --- cfe/trunk/lib/CodeGen/MicrosoftCXXABI.cpp (original)
>> >> +++ cfe/trunk/lib/CodeGen/MicrosoftCXXABI.cpp Tue Jul 1 17:24:56 2014
>> >> @@ -1152,7 +1152,7 @@ llvm::GlobalVariable *MicrosoftCXXABI::g
>> >> llvm::GlobalValue::ExternalLinkage;
>> >> llvm::ArrayType *VTableType =
>> >> llvm::ArrayType::get(CGM.Int8PtrTy, NumVTableSlots);
>> >> - if (getContext().getLangOpts().RTTI) {
>> >> + if (getContext().getLangOpts().RTTIData) {
>> >> VTableLinkage = llvm::GlobalValue::PrivateLinkage;
>> >> VTableName = "";
>> >> }
>> >> @@ -1163,7 +1163,8 @@ llvm::GlobalVariable *MicrosoftCXXABI::g
>> >> CGM.getModule(), VTableType, /*isConstant=*/true,
>> >> VTableLinkage,
>> >> /*Initializer=*/nullptr, VTableName);
>> >> VTable->setUnnamedAddr(true);
>> >> - if (getContext().getLangOpts().RTTI &&
>> >> !RD->hasAttr<DLLImportAttr>()) {
>> >> + if (getContext().getLangOpts().RTTIData &&
>> >> + !RD->hasAttr<DLLImportAttr>()) {
>> >> llvm::Value *GEPIndices[] = {llvm::ConstantInt::get(CGM.IntTy,
>> >> 0),
>> >> llvm::ConstantInt::get(CGM.IntTy,
>> >> 1)};
>> >> llvm::Constant *VTableGEP =
>> >>
>> >> Modified: cfe/trunk/lib/CodeGen/MicrosoftRTTI.cpp
>> >> URL:
>> >>
>> http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/CodeGen/MicrosoftRTTI.cpp?rev=212138&r1=212137&r2=212138&view=diff
>> >>
>> >>
>> ==============================================================================
>> >> --- cfe/trunk/lib/CodeGen/MicrosoftRTTI.cpp (original)
>> >> +++ cfe/trunk/lib/CodeGen/MicrosoftRTTI.cpp Tue Jul 1 17:24:56 2014
>> >> @@ -508,7 +508,7 @@ llvm::Constant *CodeGenModule::getMSType
>> >> llvm::Constant *
>> >> CodeGenModule::getMSCompleteObjectLocator(const CXXRecordDecl *RD,
>> >> const VPtrInfo *Info) {
>> >> - if (!getLangOpts().RTTI)
>> >> + if (!getLangOpts().RTTIData)
>> >> return llvm::Constant::getNullValue(Int8PtrTy);
>> >> return MSRTTIBuilder(*this, RD).getCompleteObjectLocator(Info);
>> >> }
>> >>
>> >> Modified: cfe/trunk/lib/Driver/Tools.cpp
>> >> URL:
>> >>
>> http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Driver/Tools.cpp?rev=212138&r1=212137&r2=212138&view=diff
>> >>
>> >>
>> ==============================================================================
>> >> --- cfe/trunk/lib/Driver/Tools.cpp (original)
>> >> +++ cfe/trunk/lib/Driver/Tools.cpp Tue Jul 1 17:24:56 2014
>> >> @@ -4193,15 +4193,7 @@ void Clang::ConstructJob(Compilation &C,
>> >> (InputType == types::TY_C || InputType == types::TY_CXX)) {
>> >> Command *CLCommand = getCLFallback()->GetCommand(C, JA, Output,
>> >> Inputs,
>> >> Args,
>> >> LinkingOutput);
>> >> - // RTTI support in clang-cl is a work in progress. Fall back to
>> MSVC
>> >> early
>> >> - // if we are using 'clang-cl /fallback /GR'.
>> >> - // FIXME: Remove this when RTTI is finished.
>> >> - if (Args.hasFlag(options::OPT_frtti, options::OPT_fno_rtti,
>> false)) {
>> >> - D.Diag(diag::warn_drv_rtti_fallback) <<
>> CLCommand->getExecutable();
>> >> - C.addCommand(CLCommand);
>> >> - } else {
>> >> - C.addCommand(new FallbackCommand(JA, *this, Exec, CmdArgs,
>> >> CLCommand));
>> >> - }
>> >> + C.addCommand(new FallbackCommand(JA, *this, Exec, CmdArgs,
>> >> CLCommand));
>> >> } else {
>> >> C.addCommand(new Command(JA, *this, Exec, CmdArgs));
>> >> }
>> >> @@ -4446,9 +4438,10 @@ void Clang::AddClangCLArgs(const ArgList
>> >> if (Arg *A = Args.getLastArg(options::OPT_show_includes))
>> >> A->render(Args, CmdArgs);
>> >>
>> >> - // RTTI is currently not supported, so disable it by default.
>> >> - if (!Args.hasArg(options::OPT_frtti, options::OPT_fno_rtti))
>> >> - CmdArgs.push_back("-fno-rtti");
>> >> + // This controls whether or not we emit RTTI data for polymorphic
>> >> types.
>> >> + if (Args.hasFlag(options::OPT__SLASH_GR_, options::OPT__SLASH_GR,
>> >> + /*default=*/false))
>> >> + CmdArgs.push_back("-fno-rtti-data");
>> >>
>> >> const Driver &D = getToolChain().getDriver();
>> >> EHFlags EH = parseClangCLEHFlags(D, Args);
>> >> @@ -7709,9 +7702,9 @@ Command *visualstudio::Compile::GetComma
>> >> // Flags for which clang-cl have an alias.
>> >> // FIXME: How can we ensure this stays in sync with relevant
>> clang-cl
>> >> options?
>> >>
>> >> - if (Arg *A = Args.getLastArg(options::OPT_frtti,
>> >> options::OPT_fno_rtti))
>> >> - CmdArgs.push_back(A->getOption().getID() == options::OPT_frtti ?
>> >> "/GR"
>> >> - :
>> >> "/GR-");
>> >> + if (Args.hasFlag(options::OPT__SLASH_GR_, options::OPT__SLASH_GR,
>> >> + /*default=*/false))
>> >> + CmdArgs.push_back("/GR-");
>> >> if (Arg *A = Args.getLastArg(options::OPT_ffunction_sections,
>> >> options::OPT_fno_function_sections))
>> >> CmdArgs.push_back(A->getOption().getID() ==
>> >> options::OPT_ffunction_sections
>> >>
>> >> Modified: cfe/trunk/lib/Frontend/CompilerInvocation.cpp
>> >> URL:
>> >>
>> http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Frontend/CompilerInvocation.cpp?rev=212138&r1=212137&r2=212138&view=diff
>> >>
>> >>
>> ==============================================================================
>> >> --- cfe/trunk/lib/Frontend/CompilerInvocation.cpp (original)
>> >> +++ cfe/trunk/lib/Frontend/CompilerInvocation.cpp Tue Jul 1 17:24:56
>> 2014
>> >> @@ -1447,6 +1447,7 @@ static void ParseLangArgs(LangOptions &O
>> >> Opts.TraditionalCPP = Args.hasArg(OPT_traditional_cpp);
>> >>
>> >> Opts.RTTI = !Args.hasArg(OPT_fno_rtti);
>> >> + Opts.RTTIData = Opts.RTTI && !Args.hasArg(OPT_fno_rtti_data);
>> >> Opts.Blocks = Args.hasArg(OPT_fblocks);
>> >> Opts.BlocksRuntimeOptional =
>> Args.hasArg(OPT_fblocks_runtime_optional);
>> >> Opts.Modules = Args.hasArg(OPT_fmodules);
>> >>
>> >> Added: cfe/trunk/test/CodeGenCXX/microsoft-no-rtti-data.cpp
>> >> URL:
>> >>
>> http://llvm.org/viewvc/llvm-project/cfe/trunk/test/CodeGenCXX/microsoft-no-rtti-data.cpp?rev=212138&view=auto
>> >>
>> >>
>> ==============================================================================
>> >> --- cfe/trunk/test/CodeGenCXX/microsoft-no-rtti-data.cpp (added)
>> >> +++ cfe/trunk/test/CodeGenCXX/microsoft-no-rtti-data.cpp Tue Jul 1
>> >> 17:24:56 2014
>> >> @@ -0,0 +1,21 @@
>> >> +// RUN: %clang_cc1 %s -fno-rtti-data -triple=i386-pc-win32 -o -
>> >> -emit-llvm | FileCheck %s
>> >> +
>> >> +// vftable shouldn't have RTTI data in it.
>> >> +// CHECK: @"\01??_7S@@6B@" = linkonce_odr unnamed_addr constant [1 x
>> i8*]
>> >> [i8* bitcast ({{.*}} @"\01??_GS@@UAEPAXI at Z" to i8*)]
>> >> +
>> >> +struct type_info;
>> >> +namespace std { using ::type_info; }
>> >> +
>> >> +struct S {
>> >> + virtual ~S();
>> >> +} s;
>> >> +
>> >> +struct U : S {
>> >> + virtual ~U();
>> >> +};
>> >> +
>> >> +extern S *getS();
>> >> +
>> >> +const std::type_info &ti = typeid(*getS());
>> >> +const U &u = dynamic_cast<U &>(*getS());
>> >> +// CHECK: call i8* @__RTDynamicCast(i8* %0, i32 0, i8* bitcast ({{.*}}
>> >> @"\01??_R0?AUS@@@8" to i8*), i8* bitcast ({{.*}} @"\01??_R0?AUU@@@8"
>> to
>> >> i8*), i32 1)
>> >>
>> >> Modified: cfe/trunk/test/Driver/cl-fallback.c
>> >> URL:
>> >>
>> http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Driver/cl-fallback.c?rev=212138&r1=212137&r2=212138&view=diff
>> >>
>> >>
>> ==============================================================================
>> >> --- cfe/trunk/test/Driver/cl-fallback.c (original)
>> >> +++ cfe/trunk/test/Driver/cl-fallback.c Tue Jul 1 17:24:56 2014
>> >> @@ -31,6 +31,10 @@
>> >> // CHECK: "/Tc" "{{.*cl-fallback.c}}"
>> >> // CHECK: "/Fo{{.*cl-fallback.*.obj}}"
>> >>
>> >> +// RUN: %clang_cl /fallback /GR- -### -- %s 2>&1 | FileCheck
>> >> -check-prefix=GR %s
>> >> +// GR: cl.exe
>> >> +// GR: "/GR-"
>> >> +
>> >> // RUN: %clang_cl /fallback /Od -### -- %s 2>&1 | FileCheck
>> >> -check-prefix=O0 %s
>> >> // O0: cl.exe
>> >> // O0: "/Od"
>> >> @@ -56,15 +60,12 @@
>> >> // RUN: FileCheck -check-prefix=ErrWarn %s
>> >> // ErrWarn: warning: falling back to {{.*}}cl.exe
>> >>
>> >> -// Don't attempt to run clang -cc1 with /fallback and /GR. It isn't
>> >> ready yet.
>> >> -// RUN: %clang_cl /fallback /c /GR -### -- %s 2>&1 | \
>> >> -// RUN: FileCheck -check-prefix=RTTI %s
>> >> -// RTTI: warning: cannot compile RTTI yet, falling back to
>> {{.*}}cl.exe
>> >> // RUN: %clang_cl /fallback /c /GR /GR- -### -- %s 2>&1 | \
>> >> // RUN: FileCheck -check-prefix=NO_RTTI %s
>> >> // NO_RTTI: "-cc1"
>> >> // NO_RTTI: ||
>> >> // NO_RTTI: cl.exe
>> >> +// NO_RTTI: "/GR-"
>> >>
>> >> // Don't fall back on non-C or C++ files.
>> >> // RUN: %clang_cl /fallback -### -- %S/Inputs/file.ll 2>&1 | FileCheck
>> >> -check-prefix=LL %s
>> >>
>> >> Modified: cfe/trunk/test/Driver/cl-options.c
>> >> URL:
>> >>
>> http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Driver/cl-options.c?rev=212138&r1=212137&r2=212138&view=diff
>> >>
>> >>
>> ==============================================================================
>> >> --- cfe/trunk/test/Driver/cl-options.c (original)
>> >> +++ cfe/trunk/test/Driver/cl-options.c Tue Jul 1 17:24:56 2014
>> >> @@ -289,10 +289,12 @@
>> >> // RUN: %clang_cl /Zs /WX -m32 -m64 -### -- 2>&1 %s | FileCheck
>> >> -check-prefix=MFLAGS %s
>> >> // MFLAGS-NOT: argument unused during compilation
>> >>
>> >> -// Use -fno-rtti by default.
>> >> -// RUN: %clang_cl /c -### -- %s 2>&1 | FileCheck -check-prefix=NoRTTI
>> %s
>> >> -// NoRTTI: "-fno-rtti"
>> >> +// RTTI is on by default. /GR- controls -fno-rtti-data.
>> >> +// RUN: %clang_cl /c /GR- -### -- %s 2>&1 | FileCheck
>> >> -check-prefix=NoRTTI %s
>> >> +// NoRTTI: "-fno-rtti-data"
>> >> +// NoRTTI-NOT: "-fno-rtti"
>> >> // RUN: %clang_cl /c /GR -### -- %s 2>&1 | FileCheck
>> -check-prefix=RTTI
>> >> %s
>> >> +// RTTI-NOT: "-fno-rtti-data"
>> >> // RTTI-NOT: "-fno-rtti"
>> >>
>> >>
>> >>
>> >>
>> >> _______________________________________________
>> >> cfe-commits mailing list
>> >> cfe-commits at cs.uiuc.edu
>> >> http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits
>> >
>> >
>>
>
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20140708/6dcbf2bf/attachment.html>
More information about the cfe-commits
mailing list