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" 130b57cec5SDimitry Andric #include "clang/Driver/Tool.h" 140b57cec5SDimitry Andric #include "clang/Driver/ToolChain.h" 150b57cec5SDimitry Andric 160b57cec5SDimitry Andric namespace clang { 170b57cec5SDimitry Andric namespace driver { 180b57cec5SDimitry Andric namespace tools { 190b57cec5SDimitry Andric 200b57cec5SDimitry Andric namespace PS4cpu { 210b57cec5SDimitry Andric 220b57cec5SDimitry Andric void addProfileRTArgs(const ToolChain &TC, const llvm::opt::ArgList &Args, 230b57cec5SDimitry Andric llvm::opt::ArgStringList &CmdArgs); 240b57cec5SDimitry Andric 250b57cec5SDimitry Andric void addSanitizerArgs(const ToolChain &TC, llvm::opt::ArgStringList &CmdArgs); 260b57cec5SDimitry Andric 270b57cec5SDimitry Andric class LLVM_LIBRARY_VISIBILITY Assemble : public Tool { 280b57cec5SDimitry Andric public: 29*5ffd83dbSDimitry Andric Assemble(const ToolChain &TC) : Tool("PS4cpu::Assemble", "assembler", TC) {} 300b57cec5SDimitry Andric 310b57cec5SDimitry Andric bool hasIntegratedCPP() const override { return false; } 320b57cec5SDimitry Andric 330b57cec5SDimitry Andric void ConstructJob(Compilation &C, const JobAction &JA, 340b57cec5SDimitry Andric const InputInfo &Output, 350b57cec5SDimitry Andric const InputInfoList &Inputs, 360b57cec5SDimitry Andric const llvm::opt::ArgList &TCArgs, 370b57cec5SDimitry Andric const char *LinkingOutput) const override; 380b57cec5SDimitry Andric }; 390b57cec5SDimitry Andric 400b57cec5SDimitry Andric class LLVM_LIBRARY_VISIBILITY Link : public Tool { 410b57cec5SDimitry Andric public: 42*5ffd83dbSDimitry Andric Link(const ToolChain &TC) : Tool("PS4cpu::Link", "linker", TC) {} 430b57cec5SDimitry Andric 440b57cec5SDimitry Andric bool hasIntegratedCPP() const override { return false; } 450b57cec5SDimitry Andric bool isLinkJob() const override { return true; } 460b57cec5SDimitry Andric 470b57cec5SDimitry Andric void ConstructJob(Compilation &C, const JobAction &JA, 480b57cec5SDimitry Andric const InputInfo &Output, 490b57cec5SDimitry Andric const InputInfoList &Inputs, 500b57cec5SDimitry Andric const llvm::opt::ArgList &TCArgs, 510b57cec5SDimitry Andric const char *LinkingOutput) const override; 520b57cec5SDimitry Andric }; 530b57cec5SDimitry Andric } // end namespace PS4cpu 540b57cec5SDimitry Andric } // namespace tools 550b57cec5SDimitry Andric 560b57cec5SDimitry Andric namespace toolchains { 570b57cec5SDimitry Andric 580b57cec5SDimitry Andric class LLVM_LIBRARY_VISIBILITY PS4CPU : public Generic_ELF { 590b57cec5SDimitry Andric public: 600b57cec5SDimitry Andric PS4CPU(const Driver &D, const llvm::Triple &Triple, 610b57cec5SDimitry Andric const llvm::opt::ArgList &Args); 620b57cec5SDimitry Andric 630b57cec5SDimitry Andric // No support for finding a C++ standard library yet. 640b57cec5SDimitry Andric void addLibCxxIncludePaths( 650b57cec5SDimitry Andric const llvm::opt::ArgList &DriverArgs, 660b57cec5SDimitry Andric llvm::opt::ArgStringList &CC1Args) const override {} 670b57cec5SDimitry Andric void addLibStdCxxIncludePaths( 680b57cec5SDimitry Andric const llvm::opt::ArgList &DriverArgs, 690b57cec5SDimitry Andric llvm::opt::ArgStringList &CC1Args) const override {} 700b57cec5SDimitry Andric 710b57cec5SDimitry Andric bool IsMathErrnoDefault() const override { return false; } 720b57cec5SDimitry Andric bool IsObjCNonFragileABIDefault() const override { return true; } 730b57cec5SDimitry Andric bool HasNativeLLVMSupport() const override; 740b57cec5SDimitry Andric bool isPICDefault() const override; 750b57cec5SDimitry Andric 760b57cec5SDimitry Andric unsigned GetDefaultStackProtectorLevel(bool KernelOrKext) const override { 770b57cec5SDimitry Andric return 2; // SSPStrong 780b57cec5SDimitry Andric } 790b57cec5SDimitry Andric 800b57cec5SDimitry Andric llvm::DebuggerKind getDefaultDebuggerTuning() const override { 810b57cec5SDimitry Andric return llvm::DebuggerKind::SCE; 820b57cec5SDimitry Andric } 830b57cec5SDimitry Andric 840b57cec5SDimitry Andric SanitizerMask getSupportedSanitizers() const override; 850b57cec5SDimitry Andric 86480093f4SDimitry Andric // PS4 toolchain uses legacy thin LTO API, which is not 87480093f4SDimitry Andric // capable of unit splitting. 88480093f4SDimitry Andric bool canSplitThinLTOUnit() const override { return false; } 89480093f4SDimitry Andric 90*5ffd83dbSDimitry Andric void addClangTargetOptions( 91*5ffd83dbSDimitry Andric const llvm::opt::ArgList &DriverArgs, 92*5ffd83dbSDimitry Andric llvm::opt::ArgStringList &CC1Args, 93*5ffd83dbSDimitry Andric Action::OffloadKind DeviceOffloadingKind) const override; 94*5ffd83dbSDimitry Andric 95*5ffd83dbSDimitry Andric llvm::DenormalMode getDefaultDenormalModeForType( 96*5ffd83dbSDimitry Andric const llvm::opt::ArgList &DriverArgs, const JobAction &JA, 97*5ffd83dbSDimitry Andric const llvm::fltSemantics *FPType) const override { 98*5ffd83dbSDimitry Andric // DAZ and FTZ are on by default. 99*5ffd83dbSDimitry Andric return llvm::DenormalMode::getPreserveSign(); 100*5ffd83dbSDimitry Andric } 101*5ffd83dbSDimitry Andric 102*5ffd83dbSDimitry Andric bool useRelaxRelocations() const override { return true; } 103*5ffd83dbSDimitry Andric 1040b57cec5SDimitry Andric protected: 1050b57cec5SDimitry Andric Tool *buildAssembler() const override; 1060b57cec5SDimitry Andric Tool *buildLinker() const override; 1070b57cec5SDimitry Andric }; 1080b57cec5SDimitry Andric 1090b57cec5SDimitry Andric } // end namespace toolchains 1100b57cec5SDimitry Andric } // end namespace driver 1110b57cec5SDimitry Andric } // end namespace clang 1120b57cec5SDimitry Andric 1130b57cec5SDimitry Andric #endif // LLVM_CLANG_LIB_DRIVER_TOOLCHAINS_PS4CPU_H 114