1 //===--- Hexagon.h - Hexagon ToolChain Implementations ----------*- C++ -*-===//
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
7 //===----------------------------------------------------------------------===//
9 #ifndef LLVM_CLANG_LIB_DRIVER_TOOLCHAINS_HEXAGON_H
10 #define LLVM_CLANG_LIB_DRIVER_TOOLCHAINS_HEXAGON_H
13 #include "clang/Driver/Tool.h"
14 #include "clang/Driver/ToolChain.h"
20 // For Hexagon, we do not need to instantiate tools for PreProcess, PreCompile
22 // We simply use "clang -cc1" for those actions.
23 class LLVM_LIBRARY_VISIBILITY Assembler final
: public Tool
{
25 Assembler(const ToolChain
&TC
)
26 : Tool("hexagon::Assembler", "hexagon-as", TC
) {}
28 bool hasIntegratedCPP() const override
{ return false; }
30 void RenderExtraToolArgs(const JobAction
&JA
,
31 llvm::opt::ArgStringList
&CmdArgs
) const;
32 void ConstructJob(Compilation
&C
, const JobAction
&JA
,
33 const InputInfo
&Output
, const InputInfoList
&Inputs
,
34 const llvm::opt::ArgList
&TCArgs
,
35 const char *LinkingOutput
) const override
;
38 class LLVM_LIBRARY_VISIBILITY Linker final
: public Tool
{
40 Linker(const ToolChain
&TC
) : Tool("hexagon::Linker", "hexagon-ld", TC
) {}
42 bool hasIntegratedCPP() const override
{ return false; }
43 bool isLinkJob() const override
{ return true; }
45 virtual void RenderExtraToolArgs(const JobAction
&JA
,
46 llvm::opt::ArgStringList
&CmdArgs
) const;
47 void ConstructJob(Compilation
&C
, const JobAction
&JA
,
48 const InputInfo
&Output
, const InputInfoList
&Inputs
,
49 const llvm::opt::ArgList
&TCArgs
,
50 const char *LinkingOutput
) const override
;
53 void getHexagonTargetFeatures(const Driver
&D
, const llvm::Triple
&Triple
,
54 const llvm::opt::ArgList
&Args
,
55 std::vector
<StringRef
> &Features
);
57 } // end namespace hexagon.
58 } // end namespace tools
60 namespace toolchains
{
62 class LLVM_LIBRARY_VISIBILITY HexagonToolChain
: public Linux
{
64 GCCVersion GCCLibAndIncVersion
;
65 Tool
*buildAssembler() const override
;
66 Tool
*buildLinker() const override
;
68 unsigned getOptimizationLevel(const llvm::opt::ArgList
&DriverArgs
) const;
71 HexagonToolChain(const Driver
&D
, const llvm::Triple
&Triple
,
72 const llvm::opt::ArgList
&Args
);
73 ~HexagonToolChain() override
;
75 void addClangTargetOptions(const llvm::opt::ArgList
&DriverArgs
,
76 llvm::opt::ArgStringList
&CC1Args
,
77 Action::OffloadKind DeviceOffloadKind
) const override
;
79 AddClangSystemIncludeArgs(const llvm::opt::ArgList
&DriverArgs
,
80 llvm::opt::ArgStringList
&CC1Args
) const override
;
81 void addLibStdCxxIncludePaths(
82 const llvm::opt::ArgList
&DriverArgs
,
83 llvm::opt::ArgStringList
&CC1Args
) const override
;
85 void addLibCxxIncludePaths(const llvm::opt::ArgList
&DriverArgs
,
86 llvm::opt::ArgStringList
&CC1Args
) const override
;
88 const char *getDefaultLinker() const override
{
89 return getTriple().isMusl() ? "ld.lld" : "hexagon-link";
92 CXXStdlibType
GetCXXStdlibType(const llvm::opt::ArgList
&Args
) const override
;
94 void AddCXXStdlibLibArgs(const llvm::opt::ArgList
&Args
,
95 llvm::opt::ArgStringList
&CmdArgs
) const override
;
97 StringRef
GetGCCLibAndIncVersion() const { return GCCLibAndIncVersion
.Text
; }
99 std::string
getHexagonTargetDir(
100 const std::string
&InstalledDir
,
101 const SmallVectorImpl
<std::string
> &PrefixDirs
) const;
102 void getHexagonLibraryPaths(const llvm::opt::ArgList
&Args
,
103 ToolChain::path_list
&LibPaths
) const;
105 std::string
getCompilerRTPath() const override
;
107 static bool isAutoHVXEnabled(const llvm::opt::ArgList
&Args
);
108 static StringRef
GetDefaultCPU();
109 static StringRef
GetTargetCPUVersion(const llvm::opt::ArgList
&Args
);
111 static std::optional
<unsigned>
112 getSmallDataThreshold(const llvm::opt::ArgList
&Args
);
115 } // end namespace toolchains
116 } // end namespace driver
117 } // end namespace clang
119 #endif // LLVM_CLANG_LIB_DRIVER_TOOLCHAINS_HEXAGON_H