diff options
Diffstat (limited to 'clang/lib/Driver/ToolChains/RISCVToolchain.h')
| -rw-r--r-- | clang/lib/Driver/ToolChains/RISCVToolchain.h | 63 | 
1 files changed, 63 insertions, 0 deletions
| diff --git a/clang/lib/Driver/ToolChains/RISCVToolchain.h b/clang/lib/Driver/ToolChains/RISCVToolchain.h new file mode 100644 index 000000000000..673d749d76ff --- /dev/null +++ b/clang/lib/Driver/ToolChains/RISCVToolchain.h @@ -0,0 +1,63 @@ +//===--- RISCVToolchain.h - RISCV ToolChain Implementations -----*- C++ -*-===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +#ifndef LLVM_CLANG_LIB_DRIVER_TOOLCHAINS_RISCVTOOLCHAIN_H +#define LLVM_CLANG_LIB_DRIVER_TOOLCHAINS_RISCVTOOLCHAIN_H + +#include "Gnu.h" +#include "clang/Driver/ToolChain.h" + +namespace clang { +namespace driver { +namespace toolchains { + +class LLVM_LIBRARY_VISIBILITY RISCVToolChain : public Generic_ELF { +public: +  RISCVToolChain(const Driver &D, const llvm::Triple &Triple, +                 const llvm::opt::ArgList &Args); + +  bool IsIntegratedAssemblerDefault() const override { return true; } +  void addClangTargetOptions(const llvm::opt::ArgList &DriverArgs, +                             llvm::opt::ArgStringList &CC1Args, +                             Action::OffloadKind) const override; +  bool HasNativeLLVMSupport() const override { return true; } +  void +  AddClangSystemIncludeArgs(const llvm::opt::ArgList &DriverArgs, +                            llvm::opt::ArgStringList &CC1Args) const override; +  void +  addLibStdCxxIncludePaths(const llvm::opt::ArgList &DriverArgs, +                           llvm::opt::ArgStringList &CC1Args) const override; + +protected: +  Tool *buildLinker() const override; + +private: +  std::string computeSysRoot() const; +}; + +} // end namespace toolchains + +namespace tools { +namespace RISCV { +class LLVM_LIBRARY_VISIBILITY Linker : public GnuTool { +public: +  Linker(const ToolChain &TC) : GnuTool("RISCV::Linker", "ld", TC) {} +  bool hasIntegratedCPP() const override { return false; } +  bool isLinkJob() const override { return true; } +  void ConstructJob(Compilation &C, const JobAction &JA, +                    const InputInfo &Output, const InputInfoList &Inputs, +                    const llvm::opt::ArgList &TCArgs, +                    const char *LinkingOutput) const override; +}; +} // end namespace RISCV +} // end namespace tools + +} // end namespace driver +} // end namespace clang + +#endif // LLVM_CLANG_LIB_DRIVER_TOOLCHAINS_RISCVTOOLCHAIN_H | 
