blob: e7a873efb0085d7c9d3eddbcc6c15fae5480063a [file] [log] [blame]
David L. Jonesf561aba2017-03-08 01:02:16 +00001//===--- AMDGPU.h - AMDGPU ToolChain Implementations ----------*- C++ -*-===//
2//
Chandler Carruth2946cd72019-01-19 08:50:56 +00003// 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
David L. Jonesf561aba2017-03-08 01:02:16 +00006//
7//===----------------------------------------------------------------------===//
8
9#ifndef LLVM_CLANG_LIB_DRIVER_TOOLCHAINS_AMDGPU_H
10#define LLVM_CLANG_LIB_DRIVER_TOOLCHAINS_AMDGPU_H
11
12#include "Gnu.h"
Andrey Kasaurov6618c392017-09-05 10:24:38 +000013#include "clang/Driver/Options.h"
David L. Jonesf561aba2017-03-08 01:02:16 +000014#include "clang/Driver/Tool.h"
15#include "clang/Driver/ToolChain.h"
Matt Arsenaultc9d65a42020-03-26 11:17:53 -040016#include "llvm/Support/TargetParser.h"
17
Andrey Kasaurov6618c392017-09-05 10:24:38 +000018#include <map>
David L. Jonesf561aba2017-03-08 01:02:16 +000019
20namespace clang {
21namespace driver {
22namespace tools {
David L. Jonesf561aba2017-03-08 01:02:16 +000023namespace amdgpu {
24
25class LLVM_LIBRARY_VISIBILITY Linker : public GnuTool {
26public:
27 Linker(const ToolChain &TC) : GnuTool("amdgpu::Linker", "ld.lld", TC) {}
28 bool isLinkJob() const override { return true; }
29 bool hasIntegratedCPP() const override { return false; }
30 void ConstructJob(Compilation &C, const JobAction &JA,
31 const InputInfo &Output, const InputInfoList &Inputs,
32 const llvm::opt::ArgList &TCArgs,
33 const char *LinkingOutput) const override;
34};
35
Konstantin Zhuravlyov8914a6d2017-11-10 19:09:57 +000036void getAMDGPUTargetFeatures(const Driver &D, const llvm::opt::ArgList &Args,
37 std::vector<StringRef> &Features);
38
David L. Jonesf561aba2017-03-08 01:02:16 +000039} // end namespace amdgpu
40} // end namespace tools
41
42namespace toolchains {
43
44class LLVM_LIBRARY_VISIBILITY AMDGPUToolChain : public Generic_ELF {
Andrey Kasaurov6618c392017-09-05 10:24:38 +000045
46private:
47 const std::map<options::ID, const StringRef> OptionsDefault;
48
David L. Jonesf561aba2017-03-08 01:02:16 +000049protected:
50 Tool *buildLinker() const override;
Andrey Kasaurov6618c392017-09-05 10:24:38 +000051 const StringRef getOptionDefault(options::ID OptID) const {
52 auto opt = OptionsDefault.find(OptID);
53 assert(opt != OptionsDefault.end() && "No Default for Option");
54 return opt->second;
55 }
David L. Jonesf561aba2017-03-08 01:02:16 +000056
57public:
58 AMDGPUToolChain(const Driver &D, const llvm::Triple &Triple,
Andrey Kasaurov6618c392017-09-05 10:24:38 +000059 const llvm::opt::ArgList &Args);
Scott Linderc9de0022019-11-13 12:31:50 -050060 unsigned GetDefaultDwarfVersion() const override { return 4; }
David L. Jonesf561aba2017-03-08 01:02:16 +000061 bool IsIntegratedAssemblerDefault() const override { return true; }
Matt Arsenaultd2049872019-06-18 13:59:32 +000062 bool IsMathErrnoDefault() const override { return false; }
63
Andrey Kasaurov6618c392017-09-05 10:24:38 +000064 llvm::opt::DerivedArgList *
65 TranslateArgs(const llvm::opt::DerivedArgList &Args, StringRef BoundArch,
66 Action::OffloadKind DeviceOffloadKind) const override;
Matt Arsenaultcd5bc7b2018-08-30 08:18:06 +000067
68 void addClangTargetOptions(const llvm::opt::ArgList &DriverArgs,
69 llvm::opt::ArgStringList &CC1Args,
70 Action::OffloadKind DeviceOffloadKind) const override;
Matt Arsenaulta4451d82019-11-01 17:57:29 -070071
Matt Arsenaultc9d65a42020-03-26 11:17:53 -040072 /// Return whether denormals should be flushed, and treated as 0 by default
73 /// for the subtarget.
74 static bool getDefaultDenormsAreZeroForTarget(llvm::AMDGPU::GPUKind GPUKind);
75
Matt Arsenaulta4451d82019-11-01 17:57:29 -070076 llvm::DenormalMode getDefaultDenormalModeForType(
77 const llvm::opt::ArgList &DriverArgs,
78 Action::OffloadKind DeviceOffloadKind,
79 const llvm::fltSemantics *FPType = nullptr) const override;
David L. Jonesf561aba2017-03-08 01:02:16 +000080};
81
82} // end namespace toolchains
83} // end namespace driver
84} // end namespace clang
85
86#endif // LLVM_CLANG_LIB_DRIVER_TOOLCHAINS_AMDGPU_H