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