forked from OSchip/llvm-project
Enable -fuse-init-array for all AArch64 ELF targets by default, not just linux.
llvm-svn: 198940
This commit is contained in:
parent
26d0f7ce7d
commit
fb38729d78
|
@ -1992,6 +1992,10 @@ 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;
|
||||
}
|
||||
|
|
|
@ -1680,6 +1680,21 @@ bool Generic_GCC::IsIntegratedAssemblerDefault() const {
|
|||
getTriple().getArch() == llvm::Triple::thumb;
|
||||
}
|
||||
|
||||
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) {
|
||||
|
@ -2595,19 +2610,6 @@ 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;
|
||||
|
|
|
@ -428,6 +428,9 @@ public:
|
|||
Generic_ELF(const Driver &D, const llvm::Triple &Triple,
|
||||
const llvm::opt::ArgList &Args)
|
||||
: Generic_GCC(D, Triple, Args) {}
|
||||
|
||||
virtual void addClangTargetOptions(const llvm::opt::ArgList &DriverArgs,
|
||||
llvm::opt::ArgStringList &CC1Args) const;
|
||||
};
|
||||
|
||||
class LLVM_LIBRARY_VISIBILITY AuroraUX : public Generic_GCC {
|
||||
|
@ -579,8 +582,6 @@ 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;
|
||||
|
|
|
@ -46,3 +46,12 @@
|
|||
// 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…
Reference in New Issue