Loading clang/lib/Driver/Driver.cpp +0 −4 Original line number Diff line number Diff line Loading @@ -1981,10 +1981,6 @@ const ToolChain &Driver::getToolChain(const ArgList &Args, TC = new toolchains::XCore(*this, Target, Args); break; } if (Target.isOSBinFormatELF()) { TC = new toolchains::Generic_ELF(*this, Target, Args); break; } TC = new toolchains::Generic_GCC(*this, Target, Args); break; } Loading clang/lib/Driver/ToolChains.cpp +13 −15 Original line number Diff line number Diff line Loading @@ -1622,21 +1622,6 @@ bool Generic_GCC::isPICDefaultForced() const { return false; } void Generic_ELF::addClangTargetOptions(const ArgList &DriverArgs, ArgStringList &CC1Args) const { const Generic_GCC::GCCVersion &V = GCCInstallation.getVersion(); bool UseInitArrayDefault = getTriple().getArch() == llvm::Triple::aarch64 || (getTriple().getOS() == llvm::Triple::Linux && ( !V.isOlderThan(4, 7, 0) || getTriple().getEnvironment() == llvm::Triple::Android)); if (DriverArgs.hasFlag(options::OPT_fuse_init_array, options::OPT_fno_use_init_array, UseInitArrayDefault)) CC1Args.push_back("-fuse-init-array"); } /// Hexagon Toolchain std::string Hexagon_TC::GetGnuDir(const std::string &InstalledDir) { Loading Loading @@ -2551,6 +2536,19 @@ Tool *Linux::buildAssembler() const { return new tools::gnutools::Assemble(*this); } void Linux::addClangTargetOptions(const ArgList &DriverArgs, ArgStringList &CC1Args) const { const Generic_GCC::GCCVersion &V = GCCInstallation.getVersion(); bool UseInitArrayDefault = !V.isOlderThan(4, 7, 0) || getTriple().getArch() == llvm::Triple::aarch64 || getTriple().getEnvironment() == llvm::Triple::Android; if (DriverArgs.hasFlag(options::OPT_fuse_init_array, options::OPT_fno_use_init_array, UseInitArrayDefault)) CC1Args.push_back("-fuse-init-array"); } std::string Linux::computeSysRoot() const { if (!getDriver().SysRoot.empty()) return getDriver().SysRoot; Loading clang/lib/Driver/ToolChains.h +8 −2 Original line number Diff line number Diff line Loading @@ -427,8 +427,12 @@ public: const llvm::opt::ArgList &Args) : Generic_GCC(D, Triple, Args) {} virtual void addClangTargetOptions(const llvm::opt::ArgList &DriverArgs, llvm::opt::ArgStringList &CC1Args) const; virtual bool IsIntegratedAssemblerDefault() const { // Default integrated assembler to on for x86. return (getTriple().getArch() == llvm::Triple::aarch64 || getTriple().getArch() == llvm::Triple::x86 || getTriple().getArch() == llvm::Triple::x86_64); } }; class LLVM_LIBRARY_VISIBILITY AuroraUX : public Generic_GCC { Loading Loading @@ -575,6 +579,8 @@ public: virtual void AddClangSystemIncludeArgs(const llvm::opt::ArgList &DriverArgs, llvm::opt::ArgStringList &CC1Args) const; virtual void addClangTargetOptions(const llvm::opt::ArgList &DriverArgs, llvm::opt::ArgStringList &CC1Args) const; virtual void AddClangCXXStdlibIncludeArgs(const llvm::opt::ArgList &DriverArgs, llvm::opt::ArgStringList &CC1Args) const; Loading clang/test/Driver/constructors.c +0 −9 Original line number Diff line number Diff line Loading @@ -46,12 +46,3 @@ // RUN: -target i386-unknown-linux-android \ // RUN: --sysroot=%S/Inputs/basic_android_tree/sysroot \ // RUN: | FileCheck --check-prefix=CHECK-INIT-ARRAY %s // // RUN: %clang -no-canonical-prefixes %s -### -fsyntax-only 2>&1 \ // RUN: -target aarch64-none-linux-gnu \ // RUN: --sysroot=%S/Inputs/basic_linux_tree \ // RUN: | FileCheck --check-prefix=CHECK-INIT-ARRAY %s // // RUN: %clang -no-canonical-prefixes %s -### -fsyntax-only 2>&1 \ // RUN: -target aarch64-none-none-eabi \ // RUN: | FileCheck --check-prefix=CHECK-INIT-ARRAY %s Loading
clang/lib/Driver/Driver.cpp +0 −4 Original line number Diff line number Diff line Loading @@ -1981,10 +1981,6 @@ const ToolChain &Driver::getToolChain(const ArgList &Args, TC = new toolchains::XCore(*this, Target, Args); break; } if (Target.isOSBinFormatELF()) { TC = new toolchains::Generic_ELF(*this, Target, Args); break; } TC = new toolchains::Generic_GCC(*this, Target, Args); break; } Loading
clang/lib/Driver/ToolChains.cpp +13 −15 Original line number Diff line number Diff line Loading @@ -1622,21 +1622,6 @@ bool Generic_GCC::isPICDefaultForced() const { return false; } void Generic_ELF::addClangTargetOptions(const ArgList &DriverArgs, ArgStringList &CC1Args) const { const Generic_GCC::GCCVersion &V = GCCInstallation.getVersion(); bool UseInitArrayDefault = getTriple().getArch() == llvm::Triple::aarch64 || (getTriple().getOS() == llvm::Triple::Linux && ( !V.isOlderThan(4, 7, 0) || getTriple().getEnvironment() == llvm::Triple::Android)); if (DriverArgs.hasFlag(options::OPT_fuse_init_array, options::OPT_fno_use_init_array, UseInitArrayDefault)) CC1Args.push_back("-fuse-init-array"); } /// Hexagon Toolchain std::string Hexagon_TC::GetGnuDir(const std::string &InstalledDir) { Loading Loading @@ -2551,6 +2536,19 @@ Tool *Linux::buildAssembler() const { return new tools::gnutools::Assemble(*this); } void Linux::addClangTargetOptions(const ArgList &DriverArgs, ArgStringList &CC1Args) const { const Generic_GCC::GCCVersion &V = GCCInstallation.getVersion(); bool UseInitArrayDefault = !V.isOlderThan(4, 7, 0) || getTriple().getArch() == llvm::Triple::aarch64 || getTriple().getEnvironment() == llvm::Triple::Android; if (DriverArgs.hasFlag(options::OPT_fuse_init_array, options::OPT_fno_use_init_array, UseInitArrayDefault)) CC1Args.push_back("-fuse-init-array"); } std::string Linux::computeSysRoot() const { if (!getDriver().SysRoot.empty()) return getDriver().SysRoot; Loading
clang/lib/Driver/ToolChains.h +8 −2 Original line number Diff line number Diff line Loading @@ -427,8 +427,12 @@ public: const llvm::opt::ArgList &Args) : Generic_GCC(D, Triple, Args) {} virtual void addClangTargetOptions(const llvm::opt::ArgList &DriverArgs, llvm::opt::ArgStringList &CC1Args) const; virtual bool IsIntegratedAssemblerDefault() const { // Default integrated assembler to on for x86. return (getTriple().getArch() == llvm::Triple::aarch64 || getTriple().getArch() == llvm::Triple::x86 || getTriple().getArch() == llvm::Triple::x86_64); } }; class LLVM_LIBRARY_VISIBILITY AuroraUX : public Generic_GCC { Loading Loading @@ -575,6 +579,8 @@ public: virtual void AddClangSystemIncludeArgs(const llvm::opt::ArgList &DriverArgs, llvm::opt::ArgStringList &CC1Args) const; virtual void addClangTargetOptions(const llvm::opt::ArgList &DriverArgs, llvm::opt::ArgStringList &CC1Args) const; virtual void AddClangCXXStdlibIncludeArgs(const llvm::opt::ArgList &DriverArgs, llvm::opt::ArgStringList &CC1Args) const; Loading
clang/test/Driver/constructors.c +0 −9 Original line number Diff line number Diff line Loading @@ -46,12 +46,3 @@ // RUN: -target i386-unknown-linux-android \ // RUN: --sysroot=%S/Inputs/basic_android_tree/sysroot \ // RUN: | FileCheck --check-prefix=CHECK-INIT-ARRAY %s // // RUN: %clang -no-canonical-prefixes %s -### -fsyntax-only 2>&1 \ // RUN: -target aarch64-none-linux-gnu \ // RUN: --sysroot=%S/Inputs/basic_linux_tree \ // RUN: | FileCheck --check-prefix=CHECK-INIT-ARRAY %s // // RUN: %clang -no-canonical-prefixes %s -### -fsyntax-only 2>&1 \ // RUN: -target aarch64-none-none-eabi \ // RUN: | FileCheck --check-prefix=CHECK-INIT-ARRAY %s