| David L. Jones | f561aba | 2017-03-08 01:02:16 +0000 | [diff] [blame] | 1 | //===--- AMDGPU.h - AMDGPU ToolChain Implementations ----------*- C++ -*-===// |
| 2 | // |
| Chandler Carruth | 2946cd7 | 2019-01-19 08:50:56 +0000 | [diff] [blame] | 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 |
| David L. Jones | f561aba | 2017-03-08 01:02:16 +0000 | [diff] [blame] | 6 | // |
| 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 Kasaurov | 6618c39 | 2017-09-05 10:24:38 +0000 | [diff] [blame] | 13 | #include "clang/Driver/Options.h" |
| David L. Jones | f561aba | 2017-03-08 01:02:16 +0000 | [diff] [blame] | 14 | #include "clang/Driver/Tool.h" |
| 15 | #include "clang/Driver/ToolChain.h" |
| Matt Arsenault | c9d65a4 | 2020-03-26 11:17:53 -0400 | [diff] [blame] | 16 | #include "llvm/Support/TargetParser.h" |
| 17 | |
| Andrey Kasaurov | 6618c39 | 2017-09-05 10:24:38 +0000 | [diff] [blame] | 18 | #include <map> |
| David L. Jones | f561aba | 2017-03-08 01:02:16 +0000 | [diff] [blame] | 19 | |
| 20 | namespace clang { |
| 21 | namespace driver { |
| 22 | namespace tools { |
| David L. Jones | f561aba | 2017-03-08 01:02:16 +0000 | [diff] [blame] | 23 | namespace amdgpu { |
| 24 | |
| 25 | class LLVM_LIBRARY_VISIBILITY Linker : public GnuTool { |
| 26 | public: |
| 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 Zhuravlyov | 8914a6d | 2017-11-10 19:09:57 +0000 | [diff] [blame] | 36 | void getAMDGPUTargetFeatures(const Driver &D, const llvm::opt::ArgList &Args, |
| 37 | std::vector<StringRef> &Features); |
| 38 | |
| David L. Jones | f561aba | 2017-03-08 01:02:16 +0000 | [diff] [blame] | 39 | } // end namespace amdgpu |
| 40 | } // end namespace tools |
| 41 | |
| 42 | namespace toolchains { |
| 43 | |
| 44 | class LLVM_LIBRARY_VISIBILITY AMDGPUToolChain : public Generic_ELF { |
| Andrey Kasaurov | 6618c39 | 2017-09-05 10:24:38 +0000 | [diff] [blame] | 45 | |
| 46 | private: |
| 47 | const std::map<options::ID, const StringRef> OptionsDefault; |
| 48 | |
| David L. Jones | f561aba | 2017-03-08 01:02:16 +0000 | [diff] [blame] | 49 | protected: |
| 50 | Tool *buildLinker() const override; |
| Andrey Kasaurov | 6618c39 | 2017-09-05 10:24:38 +0000 | [diff] [blame] | 51 | 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. Jones | f561aba | 2017-03-08 01:02:16 +0000 | [diff] [blame] | 56 | |
| 57 | public: |
| 58 | AMDGPUToolChain(const Driver &D, const llvm::Triple &Triple, |
| Andrey Kasaurov | 6618c39 | 2017-09-05 10:24:38 +0000 | [diff] [blame] | 59 | const llvm::opt::ArgList &Args); |
| Scott Linder | c9de002 | 2019-11-13 12:31:50 -0500 | [diff] [blame] | 60 | unsigned GetDefaultDwarfVersion() const override { return 4; } |
| David L. Jones | f561aba | 2017-03-08 01:02:16 +0000 | [diff] [blame] | 61 | bool IsIntegratedAssemblerDefault() const override { return true; } |
| Matt Arsenault | d204987 | 2019-06-18 13:59:32 +0000 | [diff] [blame] | 62 | bool IsMathErrnoDefault() const override { return false; } |
| 63 | |
| Andrey Kasaurov | 6618c39 | 2017-09-05 10:24:38 +0000 | [diff] [blame] | 64 | llvm::opt::DerivedArgList * |
| 65 | TranslateArgs(const llvm::opt::DerivedArgList &Args, StringRef BoundArch, |
| 66 | Action::OffloadKind DeviceOffloadKind) const override; |
| Matt Arsenault | cd5bc7b | 2018-08-30 08:18:06 +0000 | [diff] [blame] | 67 | |
| 68 | void addClangTargetOptions(const llvm::opt::ArgList &DriverArgs, |
| 69 | llvm::opt::ArgStringList &CC1Args, |
| 70 | Action::OffloadKind DeviceOffloadKind) const override; |
| Matt Arsenault | a4451d8 | 2019-11-01 17:57:29 -0700 | [diff] [blame] | 71 | |
| Matt Arsenault | c9d65a4 | 2020-03-26 11:17:53 -0400 | [diff] [blame] | 72 | /// 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 Arsenault | a4451d8 | 2019-11-01 17:57:29 -0700 | [diff] [blame] | 76 | llvm::DenormalMode getDefaultDenormalModeForType( |
| 77 | const llvm::opt::ArgList &DriverArgs, |
| 78 | Action::OffloadKind DeviceOffloadKind, |
| 79 | const llvm::fltSemantics *FPType = nullptr) const override; |
| David L. Jones | f561aba | 2017-03-08 01:02:16 +0000 | [diff] [blame] | 80 | }; |
| 81 | |
| 82 | } // end namespace toolchains |
| 83 | } // end namespace driver |
| 84 | } // end namespace clang |
| 85 | |
| 86 | #endif // LLVM_CLANG_LIB_DRIVER_TOOLCHAINS_AMDGPU_H |