r303873 - Don't defer to the GCC driver for linking arm-baremetal

Jonathan Roelofs via cfe-commits cfe-commits at lists.llvm.org
Thu May 25 11:55:58 PDT 2017



On 5/25/17 11:39 AM, Galina Kistanova wrote:
> Hello Jonathan,
>
> This commit broke one of our builders:
>
> http://lab.llvm.org:8011/builders/llvm-clang-x86_64-expensive-checks-win/builds/2608/steps/build-unified-tree/logs/stdio
>
> Please have a look at this?

r303898 should take care of that.


Jon

>
> Thanks
>
> Galina
>
> On Thu, May 25, 2017 at 8:42 AM, Jonathan Roelofs via cfe-commits 
> <cfe-commits at lists.llvm.org <mailto:cfe-commits at lists.llvm.org>> wrote:
>
>     Author: jroelofs
>     Date: Thu May 25 10:42:13 2017
>     New Revision: 303873
>
>     URL: http://llvm.org/viewvc/llvm-project?rev=303873&view=rev
>     <http://llvm.org/viewvc/llvm-project?rev=303873&view=rev>
>     Log:
>     Don't defer to the GCC driver for linking arm-baremetal
>
>     Also comes with a cmake cache for building the runtime bits:
>
>      $ cmake <normal cmake flags> \
>        -DBAREMETAL_ARMV6M_SYSROOT=/path/to/sysroot \
>        -DBAREMETAL_ARMV7M_SYSROOT=/path/to/sysroot \
>        -DBAREMETAL_ARMV7EM_SYSROOT=/path/to/sysroot \
>        -C /path/to/clang/cmake/caches/BaremetalARM.cmake \
>        /path/to/llvm
>
>     https://reviews.llvm.org/D33259 <https://reviews.llvm.org/D33259>
>
>     Added:
>         cfe/trunk/cmake/caches/BaremetalARM.cmake
>         cfe/trunk/lib/Driver/ToolChains/BareMetal.cpp
>         cfe/trunk/lib/Driver/ToolChains/BareMetal.h
>         cfe/trunk/test/Driver/Inputs/baremetal_arm/
>         cfe/trunk/test/Driver/Inputs/baremetal_arm/include/
>         cfe/trunk/test/Driver/Inputs/baremetal_arm/include/c++/
>         cfe/trunk/test/Driver/Inputs/baremetal_arm/include/c++/5.0.0/
>         cfe/trunk/test/Driver/Inputs/baremetal_arm/include/c++/5.0.0/.keep
>         cfe/trunk/test/Driver/Inputs/baremetal_arm/include/c++/6.0.0/
>         cfe/trunk/test/Driver/Inputs/baremetal_arm/include/c++/6.0.0/.keep
>         cfe/trunk/test/Driver/Inputs/baremetal_arm/include/c++/v1/
>         cfe/trunk/test/Driver/Inputs/baremetal_arm/include/c++/v1/.keep
>         cfe/trunk/test/Driver/baremetal.cpp
>     Modified:
>         cfe/trunk/lib/Driver/CMakeLists.txt
>         cfe/trunk/lib/Driver/Driver.cpp
>         cfe/trunk/lib/Driver/ToolChains/Gnu.cpp
>         cfe/trunk/lib/Driver/ToolChains/Linux.cpp
>         cfe/trunk/test/Frontend/gnu-mcount.c
>
>     Added: cfe/trunk/cmake/caches/BaremetalARM.cmake
>     URL:
>     http://llvm.org/viewvc/llvm-project/cfe/trunk/cmake/caches/BaremetalARM.cmake?rev=303873&view=auto
>     <http://llvm.org/viewvc/llvm-project/cfe/trunk/cmake/caches/BaremetalARM.cmake?rev=303873&view=auto>
>     ==============================================================================
>     --- cfe/trunk/cmake/caches/BaremetalARM.cmake (added)
>     +++ cfe/trunk/cmake/caches/BaremetalARM.cmake Thu May 25 10:42:13 2017
>     @@ -0,0 +1,50 @@
>     +set(LLVM_TARGETS_TO_BUILD ARM;X86 CACHE STRING "")
>     +
>     +# Builtins
>     +set(LLVM_BUILTIN_TARGETS
>     "armv7m-none-eabi;armv6m-none-eabi;armv7em-none-eabi" CACHE STRING
>     "Builtin Targets")
>     +
>     +set(BUILTINS_armv6m-none-eabi_CMAKE_SYSROOT
>     ${BAREMETAL_ARMV6M_SYSROOT} CACHE STRING "armv6m-none-eabi Sysroot")
>     +set(BUILTINS_armv6m-none-eabi_CMAKE_SYSTEM_NAME Generic CACHE
>     STRING "armv6m-none-eabi System Name")
>     +set(BUILTINS_armv6m-none-eabi_COMPILER_RT_BAREMETAL_BUILD ON
>     CACHE BOOL "armv6m-none-eabi Baremetal build")
>     +set(BUILTINS_armv6m-none-eabi_COMPILER_RT_OS_DIR "baremetal"
>     CACHE STRING "armv6m-none-eabi os dir")
>     +
>     +set(BUILTINS_armv7m-none-eabi_CMAKE_SYSROOT
>     ${BAREMETAL_ARMV7M_SYSROOT} CACHE STRING "armv7m-none-eabi Sysroot")
>     +set(BUILTINS_armv7m-none-eabi_CMAKE_SYSTEM_NAME Generic CACHE
>     STRING "armv7m-none-eabi System Name")
>     +set(BUILTINS_armv7m-none-eabi_COMPILER_RT_BAREMETAL_BUILD ON
>     CACHE BOOL "armv7m-none-eabi Baremetal build")
>     +set(BUILTINS_armv7m-none-eabi_CMAKE_C_FLAGS "-mfpu=fp-armv8"
>     CACHE STRING "armv7m-none-eabi C Flags")
>     +set(BUILTINS_armv7m-none-eabi_CMAKE_ASM_FLAGS "-mfpu=fp-armv8"
>     CACHE STRING "armv7m-none-eabi ASM Flags")
>     +set(BUILTINS_armv7m-none-eabi_COMPILER_RT_OS_DIR "baremetal"
>     CACHE STRING "armv7m-none-eabi os dir")
>     +
>     +set(BUILTINS_armv7em-none-eabi_CMAKE_SYSROOT
>     ${BAREMETAL_ARMV7EM_SYSROOT} CACHE STRING "armv7em-none-eabi Sysroot")
>     +set(BUILTINS_armv7em-none-eabi_CMAKE_SYSTEM_NAME Generic CACHE
>     STRING "armv7em-none-eabi System Name")
>     +set(BUILTINS_armv7em-none-eabi_COMPILER_RT_BAREMETAL_BUILD ON
>     CACHE BOOL "armv7em-none-eabi Baremetal build")
>     +set(BUILTINS_armv7em-none-eabi_CMAKE_C_FLAGS "-mfpu=fp-armv8"
>     CACHE STRING "armv7em-none-eabi C Flags")
>     +set(BUILTINS_armv7em-none-eabi_CMAKE_ASM_FLAGS "-mfpu=fp-armv8"
>     CACHE STRING "armv7em-none-eabi ASM Flags")
>     +set(BUILTINS_armv7em-none-eabi_COMPILER_RT_OS_DIR "baremetal"
>     CACHE STRING "armv7em-none-eabi os dir")
>     +
>     +set(LLVM_INSTALL_TOOLCHAIN_ONLY ON CACHE BOOL "")
>     +set(LLVM_TOOLCHAIN_TOOLS
>     +  llc
>     +  llvm-ar
>     +  llvm-cxxfilt
>     +  llvm-dwarfdump
>     +  llvm-dsymutil
>     +  llvm-nm
>     +  llvm-objdump
>     +  llvm-ranlib
>     +  llvm-readobj
>     +  llvm-size
>     +  llvm-symbolizer
>     +  opt
>     +  CACHE STRING "")
>     +
>     +set(LLVM_DISTRIBUTION_COMPONENTS
>     +  clang
>     +  lld
>     +  clang-headers
>     +  builtins-armv6m-none-eabi
>     +  builtins-armv7m-none-eabi
>     +  builtins-armv7em-none-eabi
>     +  runtimes
>     +  ${LLVM_TOOLCHAIN_TOOLS}
>     +  CACHE STRING "")
>
>     Modified: cfe/trunk/lib/Driver/CMakeLists.txt
>     URL:
>     http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Driver/CMakeLists.txt?rev=303873&r1=303872&r2=303873&view=diff
>     <http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Driver/CMakeLists.txt?rev=303873&r1=303872&r2=303873&view=diff>
>     ==============================================================================
>     --- cfe/trunk/lib/Driver/CMakeLists.txt (original)
>     +++ cfe/trunk/lib/Driver/CMakeLists.txt Thu May 25 10:42:13 2017
>     @@ -30,6 +30,7 @@ add_clang_library(clangDriver
>        ToolChains/AMDGPU.cpp
>        ToolChains/AVR.cpp
>        ToolChains/Bitrig.cpp
>     +  ToolChains/BareMetal.cpp
>        ToolChains/Clang.cpp
>        ToolChains/CloudABI.cpp
>        ToolChains/CommonArgs.cpp
>
>     Modified: cfe/trunk/lib/Driver/Driver.cpp
>     URL:
>     http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Driver/Driver.cpp?rev=303873&r1=303872&r2=303873&view=diff
>     <http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Driver/Driver.cpp?rev=303873&r1=303872&r2=303873&view=diff>
>     ==============================================================================
>     --- cfe/trunk/lib/Driver/Driver.cpp (original)
>     +++ cfe/trunk/lib/Driver/Driver.cpp Thu May 25 10:42:13 2017
>     @@ -22,6 +22,7 @@
>      #include "ToolChains/FreeBSD.h"
>      #include "ToolChains/Fuchsia.h"
>      #include "ToolChains/Gnu.h"
>     +#include "ToolChains/BareMetal.h"
>      #include "ToolChains/Haiku.h"
>      #include "ToolChains/Hexagon.h"
>      #include "ToolChains/Lanai.h"
>     @@ -3828,6 +3829,8 @@ const ToolChain &Driver::getToolChain(co
>              if (Target.getVendor() == llvm::Triple::Myriad)
>                TC =
>     llvm::make_unique<toolchains::MyriadToolChain>(*this, Target,
>          Args);
>     +        else if (toolchains::BareMetal::handlesTarget(Target))
>     +          TC = llvm::make_unique<toolchains::BareMetal>(*this,
>     Target, Args);
>              else if (Target.isOSBinFormatELF())
>                TC = llvm::make_unique<toolchains::Generic_ELF>(*this,
>     Target, Args);
>              else if (Target.isOSBinFormatMachO())
>
>     Added: cfe/trunk/lib/Driver/ToolChains/BareMetal.cpp
>     URL:
>     http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Driver/ToolChains/BareMetal.cpp?rev=303873&view=auto
>     <http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Driver/ToolChains/BareMetal.cpp?rev=303873&view=auto>
>     ==============================================================================
>     --- cfe/trunk/lib/Driver/ToolChains/BareMetal.cpp (added)
>     +++ cfe/trunk/lib/Driver/ToolChains/BareMetal.cpp Thu May 25
>     10:42:13 2017
>     @@ -0,0 +1,209 @@
>     +//===--- BaremMetal.cpp - Bare Metal ToolChain
>     ------------------*- C++ -*-===//
>     +//
>     +//                     The LLVM Compiler Infrastructure
>     +//
>     +// This file is distributed under the University of Illinois Open
>     Source
>     +// License. See LICENSE.TXT for details.
>     +//
>     +//===----------------------------------------------------------------------===//
>     +
>     +#include "BareMetal.h"
>     +
>     +#include "CommonArgs.h"
>     +#include "InputInfo.h"
>     +#include "Gnu.h"
>     +
>     +#include "clang/Basic/VirtualFileSystem.h"
>     +#include "clang/Driver/Compilation.h"
>     +#include "clang/Driver/Driver.h"
>     +#include "clang/Driver/DriverDiagnostic.h"
>     +#include "clang/Driver/Options.h"
>     +#include "llvm/Option/ArgList.h"
>     +#include "llvm/Support/Path.h"
>     +#include "llvm/Support/raw_ostream.h"
>     +
>     +using namespace llvm::opt;
>     +using namespace clang;
>     +using namespace clang::driver;
>     +using namespace clang::driver::tools;
>     +using namespace clang::driver::toolchains;
>     +
>     +BareMetal::BareMetal(const Driver &D, const llvm::Triple &Triple,
>     +                           const ArgList &Args)
>     +    : ToolChain(D, Triple, Args) {
>     +  getProgramPaths().push_back(getDriver().getInstalledDir());
>     +  if (getDriver().getInstalledDir() != getDriver().Dir)
>     +    getProgramPaths().push_back(getDriver().Dir);
>     +}
>     +
>     +BareMetal::~BareMetal() {}
>     +
>     +/// Is the triple {arm,thumb}-none-none-{eabi,eabihf} ?
>     +static bool isARMBareMetal(const llvm::Triple &Triple) {
>     +  if (Triple.getArch() != llvm::Triple::arm &&
>     +      Triple.getArch() != llvm::Triple::thumb)
>     +    return false;
>     +
>     +  if (Triple.getVendor() != llvm::Triple::UnknownVendor)
>     +    return false;
>     +
>     +  if (Triple.getOS() != llvm::Triple::UnknownOS)
>     +    return false;
>     +
>     +  if (Triple.getEnvironment() != llvm::Triple::EABI &&
>     +      Triple.getEnvironment() != llvm::Triple::EABIHF)
>     +    return false;
>     +
>     +  return true;
>     +}
>     +
>     +bool BareMetal::handlesTarget(const llvm::Triple &Triple) {
>     +  return isARMBareMetal(Triple);
>     +}
>     +
>     +Tool *BareMetal::buildLinker() const {
>     +  return new tools::baremetal::Linker(*this);
>     +}
>     +
>     +std::string BareMetal::getThreadModel() const {
>     +  return "single";
>     +}
>     +
>     +bool BareMetal::isThreadModelSupported(const StringRef Model) const {
>     +  return Model == "single";
>     +}
>     +
>     +std::string BareMetal::getRuntimesDir() const {
>     +  SmallString<128> Dir(getDriver().ResourceDir);
>     +  llvm::sys::path::append(Dir, "lib", "baremetal");
>     +  return Dir.str();
>     +}
>     +
>     +void BareMetal::AddClangSystemIncludeArgs(const ArgList &DriverArgs,
>     +                                          ArgStringList &CC1Args)
>     const {
>     +  if (DriverArgs.hasArg(options::OPT_nostdinc))
>     +    return;
>     +
>     +  if (!DriverArgs.hasArg(options::OPT_nobuiltininc)) {
>     +    SmallString<128> Dir(getDriver().ResourceDir);
>     +    llvm::sys::path::append(Dir, "include");
>     +    addSystemInclude(DriverArgs, CC1Args, Dir.str());
>     +  }
>     +
>     +  if (!DriverArgs.hasArg(options::OPT_nostdlibinc)) {
>     +    SmallString<128> Dir(getDriver().SysRoot);
>     +    llvm::sys::path::append(Dir, "include");
>     +    addSystemInclude(DriverArgs, CC1Args, Dir.str());
>     +  }
>     +}
>     +
>     +void BareMetal::addClangTargetOptions(const ArgList &DriverArgs,
>     +                                      ArgStringList &CC1Args) const {
>     +  CC1Args.push_back("-nostdsysteminc");
>     +}
>     +
>     +std::string BareMetal::findLibCxxIncludePath(CXXStdlibType
>     LibType) const {
>     +  StringRef SysRoot = getDriver().SysRoot;
>     +  if (SysRoot.empty())
>     +    return "";
>     +
>     +  switch (LibType) {
>     +  case ToolChain::CST_Libcxx: {
>     +    SmallString<128> Dir(SysRoot);
>     +    llvm::sys::path::append(Dir, "include", "c++", "v1");
>     +    return Dir.str();
>     +  }
>     +  case ToolChain::CST_Libstdcxx: {
>     +    SmallString<128> Dir(SysRoot);
>     +    llvm::sys::path::append(Dir, "include", "c++");
>     +    std::error_code EC;
>     +    Generic_GCC::GCCVersion Version = {"", -1, -1, -1, "", "", ""};
>     +    // Walk the subdirs, and find the one with the newest gcc
>     version:
>     +    for (vfs::directory_iterator LI =
>     +           getDriver().getVFS().dir_begin(Dir.str(), EC), LE;
>     +         !EC && LI != LE; LI = LI.increment(EC)) {
>     +      StringRef VersionText =
>     llvm::sys::path::filename(LI->getName());
>     +      auto CandidateVersion =
>     Generic_GCC::GCCVersion::Parse(VersionText);
>     +      if (CandidateVersion.Major == -1)
>     +        continue;
>     +      if (CandidateVersion <= Version)
>     +        continue;
>     +      Version = CandidateVersion;
>     +    }
>     +    if (Version.Major == -1)
>     +      return "";
>     +    llvm::sys::path::append(Dir, Version.Text);
>     +    return Dir.str();
>     +  }
>     +  }
>     +}
>     +
>     +void BareMetal::AddClangCXXStdlibIncludeArgs(
>     +    const ArgList &DriverArgs, ArgStringList &CC1Args) const {
>     +  if (DriverArgs.hasArg(options::OPT_nostdinc) ||
>     +      DriverArgs.hasArg(options::OPT_nostdlibinc) ||
>     +      DriverArgs.hasArg(options::OPT_nostdincxx))
>     +    return;
>     +
>     +  std::string Path =
>     findLibCxxIncludePath(GetCXXStdlibType(DriverArgs));
>     +  if (!Path.empty())
>     +    addSystemInclude(DriverArgs, CC1Args, Path);
>     +}
>     +
>     +void BareMetal::AddCXXStdlibLibArgs(const ArgList &Args,
>     +                                    ArgStringList &CmdArgs) const {
>     +  switch (GetCXXStdlibType(Args)) {
>     +  case ToolChain::CST_Libcxx:
>     +    CmdArgs.push_back("-lc++");
>     +    CmdArgs.push_back("-lc++abi");
>     +    break;
>     +  case ToolChain::CST_Libstdcxx:
>     +    CmdArgs.push_back("-lstdc++");
>     +    CmdArgs.push_back("-lsupc++");
>     +    break;
>     +  }
>     +  CmdArgs.push_back("-lunwind");
>     +}
>     +
>     +void BareMetal::AddLinkRuntimeLib(const ArgList &Args,
>     +                                  ArgStringList &CmdArgs) const {
>     +  CmdArgs.push_back(Args.MakeArgString("-lclang_rt.builtins-" +
>     +  getTriple().getArchName() + ".a"));
>     +}
>     +
>     +void baremetal::Linker::ConstructJob(Compilation &C, const
>     JobAction &JA,
>     +                                     const InputInfo &Output,
>     +                                     const InputInfoList &Inputs,
>     +                                     const ArgList &Args,
>     +                                     const char *LinkingOutput)
>     const {
>     +  ArgStringList CmdArgs;
>     +
>     +  auto &TC = static_cast<const
>     toolchains::BareMetal&>(getToolChain());
>     +
>     +  AddLinkerInputs(TC, Inputs, Args, CmdArgs, JA);
>     +
>     +  CmdArgs.push_back("-Bstatic");
>     +
>     +  CmdArgs.push_back(Args.MakeArgString("-L" + TC.getRuntimesDir()));
>     +
>     +  Args.AddAllArgs(CmdArgs, {options::OPT_L, options::OPT_T_Group,
>     +                            options::OPT_e, options::OPT_s,
>     options::OPT_t,
>     +                            options::OPT_Z_Flag, options::OPT_r});
>     +
>     +  if (!Args.hasArg(options::OPT_nostdlib,
>     options::OPT_nodefaultlibs)) {
>     +    if (C.getDriver().CCCIsCXX())
>     +      TC.AddCXXStdlibLibArgs(Args, CmdArgs);
>     +
>     +    CmdArgs.push_back("-lc");
>     +    CmdArgs.push_back("-lm");
>     +
>     +    TC.AddLinkRuntimeLib(Args, CmdArgs);
>     +  }
>     +
>     +  CmdArgs.push_back("-o");
>     +  CmdArgs.push_back(Output.getFilename());
>     +
>     +  C.addCommand(llvm::make_unique<Command>(JA, *this,
>     + Args.MakeArgString(TC.GetLinkerPath()),
>     +                                          CmdArgs, Inputs));
>     +}
>
>     Added: cfe/trunk/lib/Driver/ToolChains/BareMetal.h
>     URL:
>     http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Driver/ToolChains/BareMetal.h?rev=303873&view=auto
>     <http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Driver/ToolChains/BareMetal.h?rev=303873&view=auto>
>     ==============================================================================
>     --- cfe/trunk/lib/Driver/ToolChains/BareMetal.h (added)
>     +++ cfe/trunk/lib/Driver/ToolChains/BareMetal.h Thu May 25
>     10:42:13 2017
>     @@ -0,0 +1,90 @@
>     +//===--- BareMetal.h - Bare Metal Tool and ToolChain
>     -------------*- C++ -*-===//
>     +//
>     +//                     The LLVM Compiler Infrastructure
>     +//
>     +// This file is distributed under the University of Illinois Open
>     Source
>     +// License. See LICENSE.TXT for details.
>     +//
>     +//===----------------------------------------------------------------------===//
>     +
>     +#ifndef LLVM_CLANG_LIB_DRIVER_TOOLCHAINS_BAREMETAL_H
>     +#define LLVM_CLANG_LIB_DRIVER_TOOLCHAINS_BAREMETAL_H
>     +
>     +#include "clang/Driver/Tool.h"
>     +#include "clang/Driver/ToolChain.h"
>     +
>     +#include <string>
>     +
>     +namespace clang {
>     +namespace driver {
>     +
>     +namespace toolchains {
>     +
>     +class LLVM_LIBRARY_VISIBILITY BareMetal : public ToolChain {
>     +public:
>     +  BareMetal(const Driver &D, const llvm::Triple &Triple,
>     +            const llvm::opt::ArgList &Args);
>     +  ~BareMetal() override;
>     +
>     +  static bool handlesTarget(const llvm::Triple &Triple);
>     +protected:
>     +  Tool *buildLinker() const override;
>     +
>     +public:
>     +  bool useIntegratedAs() const override { return true; }
>     +  bool isCrossCompiling() const override { return true; }
>     +  bool isPICDefault() const override { return false; }
>     +  bool isPIEDefault() const override { return false; }
>     +  bool isPICDefaultForced() const override { return false; }
>     +  bool SupportsProfiling() const override { return false; }
>     +  bool SupportsObjCGC() const override { return false; }
>     +  std::string getThreadModel() const override;
>     +  bool isThreadModelSupported(const StringRef Model) const override;
>     +
>     +  RuntimeLibType GetDefaultRuntimeLibType() const override {
>     +    return ToolChain::RLT_CompilerRT;
>     +  }
>     +  CXXStdlibType GetDefaultCXXStdlibType() const override {
>     +    return ToolChain::CST_Libcxx;
>     +  }
>     +
>     +  const char *getDefaultLinker() const override { return "ld.lld"; }
>     +
>     +  std::string getRuntimesDir() const;
>     +  void AddClangSystemIncludeArgs(const llvm::opt::ArgList
>     &DriverArgs,
>     +                                 llvm::opt::ArgStringList
>     &CC1Args) const override;
>     +  void addClangTargetOptions(const llvm::opt::ArgList &DriverArgs,
>     +                             llvm::opt::ArgStringList &CC1Args)
>     const override;
>     +  std::string findLibCxxIncludePath(ToolChain::CXXStdlibType
>     LibType) const;
>     +  void AddClangCXXStdlibIncludeArgs(
>     +      const llvm::opt::ArgList &DriverArgs,
>     +      llvm::opt::ArgStringList &CC1Args) const override;
>     +  void AddCXXStdlibLibArgs(const llvm::opt::ArgList &Args,
>     +                           llvm::opt::ArgStringList &CmdArgs)
>     const override;
>     +  void AddLinkRuntimeLib(const llvm::opt::ArgList &Args,
>     +                         llvm::opt::ArgStringList &CmdArgs) const;
>     +};
>     +
>     +} // namespace toolchains
>     +
>     +namespace tools {
>     +namespace baremetal {
>     +
>     +class LLVM_LIBRARY_VISIBILITY Linker : public Tool {
>     +public:
>     +  Linker(const ToolChain &TC) : Tool("baremetal::Linker",
>     "ld.lld", TC) {}
>     +  bool isLinkJob() const override { return true; }
>     +  bool hasIntegratedCPP() const override { return false; }
>     +  void ConstructJob(Compilation &C, const JobAction &JA,
>     +                    const InputInfo &Output, const InputInfoList
>     &Inputs,
>     +                    const llvm::opt::ArgList &TCArgs,
>     +                    const char *LinkingOutput) const override;
>     +};
>     +
>     +} // namespace baremetal
>     +} // namespace tools
>     +
>     +} // namespace driver
>     +} // namespace clang
>     +
>     +#endif
>
>     Modified: cfe/trunk/lib/Driver/ToolChains/Gnu.cpp
>     URL:
>     http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Driver/ToolChains/Gnu.cpp?rev=303873&r1=303872&r2=303873&view=diff
>     <http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Driver/ToolChains/Gnu.cpp?rev=303873&r1=303872&r2=303873&view=diff>
>     ==============================================================================
>     --- cfe/trunk/lib/Driver/ToolChains/Gnu.cpp (original)
>     +++ cfe/trunk/lib/Driver/ToolChains/Gnu.cpp Thu May 25 10:42:13 2017
>     @@ -1598,6 +1598,49 @@ bool Generic_GCC::GCCVersion::isOlderTha
>        return false;
>      }
>
>     +/// \brief Parse a GCCVersion object out of a string of text.
>     +///
>     +/// This is the primary means of forming GCCVersion objects.
>     +/*static*/
>     +Generic_GCC::GCCVersion Generic_GCC::GCCVersion::Parse(StringRef
>     VersionText) {
>     +  const GCCVersion BadVersion = {VersionText.str(), -1, -1, -1,
>     "", "", ""};
>     +  std::pair<StringRef, StringRef> First = VersionText.split('.');
>     +  std::pair<StringRef, StringRef> Second = First.second.split('.');
>     +
>     +  GCCVersion GoodVersion = {VersionText.str(), -1, -1, -1, "",
>     "", ""};
>     +  if (First.first.getAsInteger(10, GoodVersion.Major) ||
>     GoodVersion.Major < 0)
>     +    return BadVersion;
>     +  GoodVersion.MajorStr = First.first.str();
>     +  if (First.second.empty())
>     +    return GoodVersion;
>     +  if (Second.first.getAsInteger(10, GoodVersion.Minor) ||
>     GoodVersion.Minor < 0)
>     +    return BadVersion;
>     +  GoodVersion.MinorStr = Second.first.str();
>     +
>     +  // First look for a number prefix and parse that if present.
>     Otherwise just
>     +  // stash the entire patch string in the suffix, and leave the
>     number
>     +  // unspecified. This covers versions strings such as:
>     +  //   5        (handled above)
>     +  //   4.4
>     +  //   4.4.0
>     +  //   4.4.x
>     +  //   4.4.2-rc4
>     +  //   4.4.x-patched
>     +  // And retains any patch number it finds.
>     +  StringRef PatchText = GoodVersion.PatchSuffix =
>     Second.second.str();
>     +  if (!PatchText.empty()) {
>     +    if (size_t EndNumber =
>     PatchText.find_first_not_of("0123456789")) {
>     +      // Try to parse the number and any suffix.
>     +      if (PatchText.slice(0, EndNumber).getAsInteger(10,
>     GoodVersion.Patch) ||
>     +          GoodVersion.Patch < 0)
>     +        return BadVersion;
>     +      GoodVersion.PatchSuffix = PatchText.substr(EndNumber);
>     +    }
>     +  }
>     +
>     +  return GoodVersion;
>     +}
>     +
>      static llvm::StringRef getGCCToolchainDir(const ArgList &Args) {
>        const Arg *A =
>     Args.getLastArg(clang::driver::options::OPT_gcc_toolchain);
>        if (A)
>
>     Modified: cfe/trunk/lib/Driver/ToolChains/Linux.cpp
>     URL:
>     http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Driver/ToolChains/Linux.cpp?rev=303873&r1=303872&r2=303873&view=diff
>     <http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Driver/ToolChains/Linux.cpp?rev=303873&r1=303872&r2=303873&view=diff>
>     ==============================================================================
>     --- cfe/trunk/lib/Driver/ToolChains/Linux.cpp (original)
>     +++ cfe/trunk/lib/Driver/ToolChains/Linux.cpp Thu May 25 10:42:13 2017
>     @@ -372,49 +372,6 @@ Linux::Linux(const Driver &D, const llvm
>        addPathIfExists(D, SysRoot + "/usr/lib", Paths);
>      }
>
>     -/// \brief Parse a GCCVersion object out of a string of text.
>     -///
>     -/// This is the primary means of forming GCCVersion objects.
>     -/*static*/
>     -Generic_GCC::GCCVersion Linux::GCCVersion::Parse(StringRef
>     VersionText) {
>     -  const GCCVersion BadVersion = {VersionText.str(), -1, -1, -1,
>     "", "", ""};
>     -  std::pair<StringRef, StringRef> First = VersionText.split('.');
>     -  std::pair<StringRef, StringRef> Second = First.second.split('.');
>     -
>     -  GCCVersion GoodVersion = {VersionText.str(), -1, -1, -1, "",
>     "", ""};
>     -  if (First.first.getAsInteger(10, GoodVersion.Major) ||
>     GoodVersion.Major < 0)
>     -    return BadVersion;
>     -  GoodVersion.MajorStr = First.first.str();
>     -  if (First.second.empty())
>     -    return GoodVersion;
>     -  if (Second.first.getAsInteger(10, GoodVersion.Minor) ||
>     GoodVersion.Minor < 0)
>     -    return BadVersion;
>     -  GoodVersion.MinorStr = Second.first.str();
>     -
>     -  // First look for a number prefix and parse that if present.
>     Otherwise just
>     -  // stash the entire patch string in the suffix, and leave the
>     number
>     -  // unspecified. This covers versions strings such as:
>     -  //   5        (handled above)
>     -  //   4.4
>     -  //   4.4.0
>     -  //   4.4.x
>     -  //   4.4.2-rc4
>     -  //   4.4.x-patched
>     -  // And retains any patch number it finds.
>     -  StringRef PatchText = GoodVersion.PatchSuffix =
>     Second.second.str();
>     -  if (!PatchText.empty()) {
>     -    if (size_t EndNumber =
>     PatchText.find_first_not_of("0123456789")) {
>     -      // Try to parse the number and any suffix.
>     -      if (PatchText.slice(0, EndNumber).getAsInteger(10,
>     GoodVersion.Patch) ||
>     -          GoodVersion.Patch < 0)
>     -        return BadVersion;
>     -      GoodVersion.PatchSuffix = PatchText.substr(EndNumber);
>     -    }
>     -  }
>     -
>     -  return GoodVersion;
>     -}
>     -
>      bool Linux::HasNativeLLVMSupport() const { return true; }
>
>      Tool *Linux::buildLinker() const { return new
>     tools::gnutools::Linker(*this); }
>
>     Added:
>     cfe/trunk/test/Driver/Inputs/baremetal_arm/include/c++/5.0.0/.keep
>     URL:
>     http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Driver/Inputs/baremetal_arm/include/c%2B%2B/5.0.0/.keep?rev=303873&view=auto
>     <http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Driver/Inputs/baremetal_arm/include/c%2B%2B/5.0.0/.keep?rev=303873&view=auto>
>     ==============================================================================
>         (empty)
>
>     Added:
>     cfe/trunk/test/Driver/Inputs/baremetal_arm/include/c++/6.0.0/.keep
>     URL:
>     http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Driver/Inputs/baremetal_arm/include/c%2B%2B/6.0.0/.keep?rev=303873&view=auto
>     <http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Driver/Inputs/baremetal_arm/include/c%2B%2B/6.0.0/.keep?rev=303873&view=auto>
>     ==============================================================================
>         (empty)
>
>     Added: cfe/trunk/test/Driver/Inputs/baremetal_arm/include/c++/v1/.keep
>     URL:
>     http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Driver/Inputs/baremetal_arm/include/c%2B%2B/v1/.keep?rev=303873&view=auto
>     <http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Driver/Inputs/baremetal_arm/include/c%2B%2B/v1/.keep?rev=303873&view=auto>
>     ==============================================================================
>         (empty)
>
>     Added: cfe/trunk/test/Driver/baremetal.cpp
>     URL:
>     http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Driver/baremetal.cpp?rev=303873&view=auto
>     <http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Driver/baremetal.cpp?rev=303873&view=auto>
>     ==============================================================================
>     --- cfe/trunk/test/Driver/baremetal.cpp (added)
>     +++ cfe/trunk/test/Driver/baremetal.cpp Thu May 25 10:42:13 2017
>     @@ -0,0 +1,77 @@
>     +// RUN: %clang -no-canonical-prefixes %s -### -o %t.o 2>&1 \
>     +// RUN:     -target armv6m-none-eabi \
>     +// RUN:     -T semihosted.lds \
>     +// RUN:     -L some/directory/user/asked/for \
>     +// RUN:     --sysroot=%S/Inputs/baremetal_arm \
>     +// RUN:   | FileCheck --check-prefix=CHECK-V6M-C %s
>     +// CHECK-V6M-C: "[[PREFIX_DIR:.*]]/bin/clang" "-cc1" "-triple"
>     "thumbv6m-none--eabi"
>     +// CHECK-V6M-C-SAME: "-resource-dir"
>     "[[PREFIX_DIR]]/lib/clang/[[VERSION:[^"]*]]"
>     +// CHECK-V6M-C-SAME: "-isysroot" "[[SYSROOT:[^"]*]]"
>     +// CHECK-V6M-C-SAME: "-internal-isystem" "[[SYSROOT]]/include/c++/v1"
>     +// CHECk-V6M-C-SAME: "-internal-isystem" "[[SYSROOT]]/include"
>     +// CHECK-V6M-C-SAME: "-x" "c++" "{{.*}}baremetal.cpp"
>     +// CHECK-V6M-C-NEXT: "[[PREFIX_DIR:.*]]/bin/ld.lld" "{{.*}}.o"
>     "-Bstatic"
>     +// CHECK-V6M-C-SAME:
>     "-L[[PREFIX_DIR]]/lib/clang/[[VERSION]]/lib/baremetal"
>     +// CHECK-V6M-C-SAME: "-T" "semihosted.lds"
>     "-Lsome/directory/user/asked/for"
>     +// CHECK-V6M-C-SAME: "-lc" "-lm" "-lclang_rt.builtins-armv6m.a"
>     +// CHECK-V6M-C-SAME: "-o" "{{.*}}.o"
>     +
>     +// RUN: %clang -no-canonical-prefixes %s -### -o %t.o 2>&1 \
>     +// RUN:     -target armv6m-none-eabi \
>     +// RUN:     -nostdlibinc -nobuiltininc \
>     +// RUN:     --sysroot=%S/Inputs/baremetal_arm \
>     +// RUN:   | FileCheck --check-prefix=CHECK-V6M-LIBINC %s
>     +// RUN: %clang -no-canonical-prefixes %s -### -o %t.o 2>&1 \
>     +// RUN:     -target armv6m-none-eabi \
>     +// RUN:     -nostdinc \
>     +// RUN:     --sysroot=%S/Inputs/baremetal_arm \
>     +// RUN:   | FileCheck --check-prefix=CHECK-V6M-LIBINC %s
>     +// CHECK-V6M-LIBINC-NOT: "-internal-isystem"
>     +
>     +// RUN: %clangxx -no-canonical-prefixes %s -### -o %t.o 2>&1 \
>     +// RUN:     -target armv6m-none-eabi \
>     +// RUN:     --sysroot=%S/Inputs/baremetal_arm \
>     +// RUN:   | FileCheck --check-prefix=CHECK-V6M-DEFAULTCXX %s
>     +// CHECK-V6M-DEFAULTCXX: "[[PREFIX_DIR:.*]]/bin/ld.lld"
>     "{{.*}}.o" "-Bstatic"
>     +// CHECK-V6M-DEFAULTCXX-SAME:
>     "-L[[PREFIX_DIR]]/lib/clang/{{.*}}/lib/baremetal"
>     +// CHECK-V6M-DEFAULTCXX-SAME: "-lc++" "-lc++abi" "-lunwind"
>     +// CHECK-V6M-DEFAULTCXX-SAME: "-lc" "-lm"
>     "-lclang_rt.builtins-armv6m.a"
>     +// CHECK-V6M-DEFAULTCXX-SAME: "-o" "{{.*}}.o"
>     +
>     +// RUN: %clangxx -no-canonical-prefixes %s -### -o %t.o 2>&1 \
>     +// RUN:     -target armv6m-none-eabi \
>     +// RUN:     --sysroot=%S/Inputs/baremetal_arm \
>     +// RUN:     -stdlib=libc++ \
>     +// RUN:   | FileCheck --check-prefix=CHECK-V6M-LIBCXX %s
>     +// CHECK-V6M-LIBCXX-NOT: "-internal-isystem"
>     "{{[^"]+}}/include/c++/{{[^v].*}}"
>     +// CHECK-V6M-LIBCXX: "-internal-isystem" "{{[^"]+}}/include/c++/v1"
>     +// CHECK-V6M-LIBCXX: "[[PREFIX_DIR:.*]]/bin/ld.lld" "{{.*}}.o"
>     "-Bstatic"
>     +// CHECK-V6M-LIBCXX-SAME:
>     "-L[[PREFIX_DIR]]/lib/clang/{{.*}}/lib/baremetal"
>     +// CHECK-V6M-LIBCXX-SAME: "-lc++" "-lc++abi" "-lunwind"
>     +// CHECK-V6M-LIBCXX-SAME: "-lc" "-lm" "-lclang_rt.builtins-armv6m.a"
>     +// CHECK-V6M-LIBCXX-SAME: "-o" "{{.*}}.o"
>     +
>     +// RUN: %clangxx -no-canonical-prefixes %s -### -o %t.o 2>&1 \
>     +// RUN:     -target armv6m-none-eabi \
>     +// RUN:     --sysroot=%S/Inputs/baremetal_arm \
>     +// RUN:     -stdlib=libstdc++ \
>     +// RUN:   | FileCheck --check-prefix=CHECK-V6M-LIBSTDCXX %s
>     +// CHECK-V6M-LIBSTDCXX-NOT: "-internal-isystem"
>     "{{[^"]+}}/include/c++/v1"
>     +// CHECK-V6M-LIBSTDCXX: "-internal-isystem"
>     "{{[^"]+}}/include/c++/6.0.0"
>     +// CHECK-V6M-LIBSTDCXX: "[[PREFIX_DIR:.*]]/bin/ld.lld" "{{.*}}.o"
>     "-Bstatic"
>     +// CHECK-V6M-LIBSTDCXX-SAME:
>     "-L[[PREFIX_DIR]]/lib/clang/{{.*}}/lib/baremetal"
>     +// CHECK-V6M-LIBSTDCXX-SAME: "-lstdc++" "-lsupc++" "-lunwind"
>     +// CHECK-V6M-LIBSTDCXX-SAME: "-lc" "-lm"
>     "-lclang_rt.builtins-armv6m.a"
>     +// CHECK-V6M-LIBSTDCXX-SAME: "-o" "{{.*}}.o"
>     +
>     +// RUN: %clangxx -no-canonical-prefixes %s -### -o %t.o 2>&1 \
>     +// RUN:     -target armv6m-none-eabi \
>     +// RUN:     --sysroot=%S/Inputs/baremetal_arm \
>     +// RUN:     -nodefaultlibs \
>     +// RUN:   | FileCheck --check-prefix=CHECK-V6M-NDL %s
>     +// CHECK-V6M-NDL: "[[PREFIX_DIR:.*]]/bin/ld.lld" "{{.*}}.o"
>     "-Bstatic"
>     +// CHECK-V6M-NDL-SAME:
>     "-L[[PREFIX_DIR]]/lib/clang/{{.*}}/lib/baremetal" "-o" "{{.*}}.o"
>     +
>     +// RUN: %clangxx -target arm-none-eabi -v 2>&1 \
>     +// RUN:   | FileCheck %s --check-prefix=CHECK-THREAD-MODEL
>     +// CHECK-THREAD-MODEL: Thread model: single
>
>     Modified: cfe/trunk/test/Frontend/gnu-mcount.c
>     URL:
>     http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Frontend/gnu-mcount.c?rev=303873&r1=303872&r2=303873&view=diff
>     <http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Frontend/gnu-mcount.c?rev=303873&r1=303872&r2=303873&view=diff>
>     ==============================================================================
>     --- cfe/trunk/test/Frontend/gnu-mcount.c (original)
>     +++ cfe/trunk/test/Frontend/gnu-mcount.c Thu May 25 10:42:13 2017
>     @@ -1,9 +1,9 @@
>      // REQUIRES: arm-registered-target,aarch64-registered-target
>
>     -// RUN: %clang -target armv7-unknown-none-eabi -pg -S -emit-llvm
>     -o - %s | FileCheck %s -check-prefix CHECK -check-prefix
>     CHECK-ARM-EABI
>     -// RUN: %clang -target armv7-unknown-none-eabi -pg -meabi gnu -S
>     -emit-llvm -o - %s | FileCheck %s -check-prefix CHECK
>     -check-prefix CHECK-ARM-EABI-MEABI-GNU
>     -// RUN: %clang -target aarch64-unknown-none-eabi -pg -S
>     -emit-llvm -o - %s | FileCheck %s -check-prefix CHECK
>     -check-prefix CHECK-ARM64-EABI
>     -// RUN: %clang -target aarch64-unknown-none-eabi -pg -meabi gnu
>     -S -emit-llvm -o - %s | FileCheck %s -check-prefix CHECK
>     -check-prefix CHECK-ARM64-EABI-MEABI-GNU
>     +// RUN: %clang -target armv7-unknown-none-eabi -pg -S -emit-llvm
>     -o - %s | FileCheck %s -check-prefix CHECK -check-prefix
>     CHECK-ARM-BAREMETAL-EABI
>     +// RUN: %clang -target armv7-unknown-none-eabi -pg -meabi gnu -S
>     -emit-llvm -o - %s | FileCheck %s -check-prefix CHECK
>     -check-prefix CHECK-ARM-BAREMETAL-EABI-MEABI-GNU
>     +// RUN: %clang -target aarch64-unknown-none-eabi -pg -S
>     -emit-llvm -o - %s | FileCheck %s -check-prefix CHECK
>     -check-prefix CHECK-ARM64-BAREMETAL-EABI
>     +// RUN: %clang -target aarch64-unknown-none-eabi -pg -meabi gnu
>     -S -emit-llvm -o - %s | FileCheck %s -check-prefix CHECK
>     -check-prefix CHECK-ARM64-BAREMETAL-EABI-MEABI-GNU
>      // RUN: %clang -target armv7-unknown-linux-gnueabi -pg -S
>     -emit-llvm -o - %s | FileCheck %s -check-prefix CHECK
>     -check-prefix CHECK-ARM-EABI
>      // RUN: %clang -target armv7-unknown-linux-gnueabi -meabi gnu -pg
>     -S -emit-llvm -o - %s | FileCheck %s -check-prefix CHECK
>     -check-prefix CHECK-ARM-EABI-MEABI-GNU
>      // RUN: %clang -target aarch64-unknown-linux-gnueabi -pg -S
>     -emit-llvm -o - %s | FileCheck %s -check-prefix CHECK
>     -check-prefix CHECK-ARM64-EABI-LINUX
>     @@ -46,6 +46,11 @@ int f() {
>      }
>
>      // CHECK-LABEL: f
>     +// TODO: add profiling support for arm-baremetal
>     +// CHECK-ARM-BAREMETAL-EABI-NOT: attributes #{{[0-9]+}} = {
>     {{.*}}"counting-function"="\01mcount"{{.*}} }
>     +// CHECK-ARM-BAREMETAL-EABI-NOT: attributes #{{[0-9]+}} = {
>     {{.*}}"counting-function"="\01__gnu_mcount_nc"{{.*}} }
>     +// CHECK-ARM64-BAREMETAL-EABI: attributes #{{[0-9]+}} = {
>     {{.*}}"counting-function"="mcount"{{.*}} }
>     +// CHECK-ARM64-BAREMETAL-EABI-MEABI-GNU: attributes #{{[0-9]+}} =
>     { {{.*}}"counting-function"="\01_mcount"{{.*}} }
>      // CHECK-ARM-IOS-NOT: attributes #{{[0-9]+}} = {
>     {{.*}}"counting-function"="_mcount"{{.*}} }
>      // CHECK-ARM-IOS-NOT: attributes #{{[0-9]+}} = {
>     {{.*}}"counting-function"="\01__gnu_mcount_nc"{{.*}} }
>      // CHECK-ARM-EABI: attributes #{{[0-9]+}} = {
>     {{.*}}"counting-function"="\01mcount"{{.*}} }
>
>
>     _______________________________________________
>     cfe-commits mailing list
>     cfe-commits at lists.llvm.org <mailto:cfe-commits at lists.llvm.org>
>     http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits
>     <http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits>
>
>

-- 
Jon Roelofs
jonathan at codesourcery.com
CodeSourcery / Mentor Embedded / Siemens

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20170525/10dc6743/attachment-0001.html>


More information about the cfe-commits mailing list