diff options
author | Fangrui Song <maskray@google.com> | 2019-12-12 10:49:46 -0800 |
---|---|---|
committer | Fangrui Song <maskray@google.com> | 2019-12-13 14:06:51 -0800 |
commit | e4fce659a759ecdd59ceee750f1ff9b44f9de3f3 (patch) | |
tree | 15ad038aa1ad8ce430a82d65edba1c65d424dc0a /clang/lib/Driver/ToolChains/Gnu.cpp | |
parent | 8035bb4a6573f7d20f17044a68a1405691000525 (diff) | |
download | bcm5719-llvm-e4fce659a759ecdd59ceee750f1ff9b44f9de3f3.tar.gz bcm5719-llvm-e4fce659a759ecdd59ceee750f1ff9b44f9de3f3.zip |
[Driver] Use .init_array for all gcc installations and simplify Generic_ELF -fno-use-init-array rules
D39317 made clang use .init_array when no gcc installations is found.
This change changes all gcc installations to use .init_array .
GCC 4.7 by default stopped providing .ctors/.dtors compatible crt files,
and stopped emitting .ctors for __attribute__((constructor)).
.init_array should always work.
FreeBSD rules are moved to FreeBSD.cpp to make Generic_ELF rules clean.
Reviewed By: rnk
Differential Revision: https://reviews.llvm.org/D71434
Diffstat (limited to 'clang/lib/Driver/ToolChains/Gnu.cpp')
-rw-r--r-- | clang/lib/Driver/ToolChains/Gnu.cpp | 18 |
1 files changed, 1 insertions, 17 deletions
diff --git a/clang/lib/Driver/ToolChains/Gnu.cpp b/clang/lib/Driver/ToolChains/Gnu.cpp index 0d950852bac..250e924fb84 100644 --- a/clang/lib/Driver/ToolChains/Gnu.cpp +++ b/clang/lib/Driver/ToolChains/Gnu.cpp @@ -2782,23 +2782,7 @@ void Generic_ELF::anchor() {} void Generic_ELF::addClangTargetOptions(const ArgList &DriverArgs, ArgStringList &CC1Args, Action::OffloadKind) const { - const Generic_GCC::GCCVersion &V = GCCInstallation.getVersion(); - bool UseInitArrayDefault = - getTriple().getArch() == llvm::Triple::aarch64 || - getTriple().getArch() == llvm::Triple::aarch64_be || - (getTriple().isOSFreeBSD() && - getTriple().getOSMajorVersion() >= 12) || - (getTriple().getOS() == llvm::Triple::Linux && - ((!GCCInstallation.isValid() || !V.isOlderThan(4, 7, 0)) || - getTriple().isAndroid())) || - getTriple().getOS() == llvm::Triple::NaCl || - (getTriple().getVendor() == llvm::Triple::MipsTechnologies && - !getTriple().hasEnvironment()) || - getTriple().getOS() == llvm::Triple::Solaris || - getTriple().getArch() == llvm::Triple::riscv32 || - getTriple().getArch() == llvm::Triple::riscv64; - if (!DriverArgs.hasFlag(options::OPT_fuse_init_array, - options::OPT_fno_use_init_array, UseInitArrayDefault)) + options::OPT_fno_use_init_array, true)) CC1Args.push_back("-fno-use-init-array"); } |