10b57cec5SDimitry Andric //===--- PS4CPU.h - PS4CPU ToolChain Implementations ------------*- C++ -*-===//
20b57cec5SDimitry Andric //
30b57cec5SDimitry Andric // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
40b57cec5SDimitry Andric // See https://llvm.org/LICENSE.txt for license information.
50b57cec5SDimitry Andric // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
60b57cec5SDimitry Andric //
70b57cec5SDimitry Andric //===----------------------------------------------------------------------===//
80b57cec5SDimitry Andric 
90b57cec5SDimitry Andric #ifndef LLVM_CLANG_LIB_DRIVER_TOOLCHAINS_PS4CPU_H
100b57cec5SDimitry Andric #define LLVM_CLANG_LIB_DRIVER_TOOLCHAINS_PS4CPU_H
110b57cec5SDimitry Andric 
120b57cec5SDimitry Andric #include "Gnu.h"
13e8d8bef9SDimitry Andric #include "clang/Basic/LangOptions.h"
140b57cec5SDimitry Andric #include "clang/Driver/Tool.h"
150b57cec5SDimitry Andric #include "clang/Driver/ToolChain.h"
160b57cec5SDimitry Andric 
170b57cec5SDimitry Andric namespace clang {
180b57cec5SDimitry Andric namespace driver {
190b57cec5SDimitry Andric namespace tools {
200b57cec5SDimitry Andric 
210b57cec5SDimitry Andric namespace PS4cpu {
220b57cec5SDimitry Andric 
230b57cec5SDimitry Andric void addProfileRTArgs(const ToolChain &TC, const llvm::opt::ArgList &Args,
240b57cec5SDimitry Andric                       llvm::opt::ArgStringList &CmdArgs);
250b57cec5SDimitry Andric 
260b57cec5SDimitry Andric void addSanitizerArgs(const ToolChain &TC, llvm::opt::ArgStringList &CmdArgs);
270b57cec5SDimitry Andric 
280b57cec5SDimitry Andric class LLVM_LIBRARY_VISIBILITY Assemble : public Tool {
290b57cec5SDimitry Andric public:
305ffd83dbSDimitry Andric   Assemble(const ToolChain &TC) : Tool("PS4cpu::Assemble", "assembler", TC) {}
310b57cec5SDimitry Andric 
320b57cec5SDimitry Andric   bool hasIntegratedCPP() const override { return false; }
330b57cec5SDimitry Andric 
340b57cec5SDimitry Andric   void ConstructJob(Compilation &C, const JobAction &JA,
350b57cec5SDimitry Andric                     const InputInfo &Output,
360b57cec5SDimitry Andric                     const InputInfoList &Inputs,
370b57cec5SDimitry Andric                     const llvm::opt::ArgList &TCArgs,
380b57cec5SDimitry Andric                     const char *LinkingOutput) const override;
390b57cec5SDimitry Andric };
400b57cec5SDimitry Andric 
410b57cec5SDimitry Andric class LLVM_LIBRARY_VISIBILITY Link : public Tool {
420b57cec5SDimitry Andric public:
435ffd83dbSDimitry Andric   Link(const ToolChain &TC) : Tool("PS4cpu::Link", "linker", TC) {}
440b57cec5SDimitry Andric 
450b57cec5SDimitry Andric   bool hasIntegratedCPP() const override { return false; }
460b57cec5SDimitry Andric   bool isLinkJob() const override { return true; }
470b57cec5SDimitry Andric 
480b57cec5SDimitry Andric   void ConstructJob(Compilation &C, const JobAction &JA,
490b57cec5SDimitry Andric                     const InputInfo &Output,
500b57cec5SDimitry Andric                     const InputInfoList &Inputs,
510b57cec5SDimitry Andric                     const llvm::opt::ArgList &TCArgs,
520b57cec5SDimitry Andric                     const char *LinkingOutput) const override;
530b57cec5SDimitry Andric };
540b57cec5SDimitry Andric } // end namespace PS4cpu
550b57cec5SDimitry Andric } // namespace tools
560b57cec5SDimitry Andric 
570b57cec5SDimitry Andric namespace toolchains {
580b57cec5SDimitry Andric 
590b57cec5SDimitry Andric class LLVM_LIBRARY_VISIBILITY PS4CPU : public Generic_ELF {
600b57cec5SDimitry Andric public:
610b57cec5SDimitry Andric   PS4CPU(const Driver &D, const llvm::Triple &Triple,
620b57cec5SDimitry Andric          const llvm::opt::ArgList &Args);
630b57cec5SDimitry Andric 
640b57cec5SDimitry Andric   // No support for finding a C++ standard library yet.
650b57cec5SDimitry Andric   void addLibCxxIncludePaths(
660b57cec5SDimitry Andric       const llvm::opt::ArgList &DriverArgs,
670b57cec5SDimitry Andric       llvm::opt::ArgStringList &CC1Args) const override {}
680b57cec5SDimitry Andric   void addLibStdCxxIncludePaths(
690b57cec5SDimitry Andric       const llvm::opt::ArgList &DriverArgs,
700b57cec5SDimitry Andric       llvm::opt::ArgStringList &CC1Args) const override {}
710b57cec5SDimitry Andric 
720b57cec5SDimitry Andric   bool IsMathErrnoDefault() const override { return false; }
730b57cec5SDimitry Andric   bool IsObjCNonFragileABIDefault() const override { return true; }
740b57cec5SDimitry Andric   bool HasNativeLLVMSupport() const override;
750b57cec5SDimitry Andric   bool isPICDefault() const override;
760b57cec5SDimitry Andric 
77e8d8bef9SDimitry Andric   LangOptions::StackProtectorMode
78e8d8bef9SDimitry Andric   GetDefaultStackProtectorLevel(bool KernelOrKext) const override {
79e8d8bef9SDimitry Andric     return LangOptions::SSPStrong;
800b57cec5SDimitry Andric   }
810b57cec5SDimitry Andric 
820b57cec5SDimitry Andric   llvm::DebuggerKind getDefaultDebuggerTuning() const override {
830b57cec5SDimitry Andric     return llvm::DebuggerKind::SCE;
840b57cec5SDimitry Andric   }
850b57cec5SDimitry Andric 
860b57cec5SDimitry Andric   SanitizerMask getSupportedSanitizers() const override;
870b57cec5SDimitry Andric 
88480093f4SDimitry Andric   // PS4 toolchain uses legacy thin LTO API, which is not
89480093f4SDimitry Andric   // capable of unit splitting.
90480093f4SDimitry Andric   bool canSplitThinLTOUnit() const override { return false; }
91480093f4SDimitry Andric 
925ffd83dbSDimitry Andric   void addClangTargetOptions(
935ffd83dbSDimitry Andric     const llvm::opt::ArgList &DriverArgs,
945ffd83dbSDimitry Andric     llvm::opt::ArgStringList &CC1Args,
955ffd83dbSDimitry Andric     Action::OffloadKind DeviceOffloadingKind) const override;
965ffd83dbSDimitry Andric 
975ffd83dbSDimitry Andric   llvm::DenormalMode getDefaultDenormalModeForType(
985ffd83dbSDimitry Andric       const llvm::opt::ArgList &DriverArgs, const JobAction &JA,
995ffd83dbSDimitry Andric       const llvm::fltSemantics *FPType) const override {
1005ffd83dbSDimitry Andric     // DAZ and FTZ are on by default.
1015ffd83dbSDimitry Andric     return llvm::DenormalMode::getPreserveSign();
1025ffd83dbSDimitry Andric   }
1035ffd83dbSDimitry Andric 
1045ffd83dbSDimitry Andric   bool useRelaxRelocations() const override { return true; }
1055ffd83dbSDimitry Andric 
1060b57cec5SDimitry Andric protected:
1070b57cec5SDimitry Andric   Tool *buildAssembler() const override;
1080b57cec5SDimitry Andric   Tool *buildLinker() const override;
1090b57cec5SDimitry Andric };
1100b57cec5SDimitry Andric 
1110b57cec5SDimitry Andric } // end namespace toolchains
1120b57cec5SDimitry Andric } // end namespace driver
1130b57cec5SDimitry Andric } // end namespace clang
1140b57cec5SDimitry Andric 
1150b57cec5SDimitry Andric #endif // LLVM_CLANG_LIB_DRIVER_TOOLCHAINS_PS4CPU_H
116