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 26*349cc55cSDimitry Andric void addSanitizerArgs(const ToolChain &TC, const llvm::opt::ArgList &Args, 27*349cc55cSDimitry Andric llvm::opt::ArgStringList &CmdArgs); 280b57cec5SDimitry Andric 290b57cec5SDimitry Andric class LLVM_LIBRARY_VISIBILITY Assemble : public Tool { 300b57cec5SDimitry Andric public: 315ffd83dbSDimitry Andric Assemble(const ToolChain &TC) : Tool("PS4cpu::Assemble", "assembler", TC) {} 320b57cec5SDimitry Andric 330b57cec5SDimitry Andric bool hasIntegratedCPP() const override { return false; } 340b57cec5SDimitry Andric 350b57cec5SDimitry Andric void ConstructJob(Compilation &C, const JobAction &JA, 360b57cec5SDimitry Andric const InputInfo &Output, 370b57cec5SDimitry Andric const InputInfoList &Inputs, 380b57cec5SDimitry Andric const llvm::opt::ArgList &TCArgs, 390b57cec5SDimitry Andric const char *LinkingOutput) const override; 400b57cec5SDimitry Andric }; 410b57cec5SDimitry Andric 420b57cec5SDimitry Andric class LLVM_LIBRARY_VISIBILITY Link : public Tool { 430b57cec5SDimitry Andric public: 445ffd83dbSDimitry Andric Link(const ToolChain &TC) : Tool("PS4cpu::Link", "linker", TC) {} 450b57cec5SDimitry Andric 460b57cec5SDimitry Andric bool hasIntegratedCPP() const override { return false; } 470b57cec5SDimitry Andric bool isLinkJob() const override { return true; } 480b57cec5SDimitry Andric 490b57cec5SDimitry Andric void ConstructJob(Compilation &C, const JobAction &JA, 500b57cec5SDimitry Andric const InputInfo &Output, 510b57cec5SDimitry Andric const InputInfoList &Inputs, 520b57cec5SDimitry Andric const llvm::opt::ArgList &TCArgs, 530b57cec5SDimitry Andric const char *LinkingOutput) const override; 540b57cec5SDimitry Andric }; 550b57cec5SDimitry Andric } // end namespace PS4cpu 560b57cec5SDimitry Andric } // namespace tools 570b57cec5SDimitry Andric 580b57cec5SDimitry Andric namespace toolchains { 590b57cec5SDimitry Andric 600b57cec5SDimitry Andric class LLVM_LIBRARY_VISIBILITY PS4CPU : public Generic_ELF { 610b57cec5SDimitry Andric public: 620b57cec5SDimitry Andric PS4CPU(const Driver &D, const llvm::Triple &Triple, 630b57cec5SDimitry Andric const llvm::opt::ArgList &Args); 640b57cec5SDimitry Andric 650b57cec5SDimitry Andric // No support for finding a C++ standard library yet. 660b57cec5SDimitry Andric void addLibCxxIncludePaths( 670b57cec5SDimitry Andric const llvm::opt::ArgList &DriverArgs, 680b57cec5SDimitry Andric llvm::opt::ArgStringList &CC1Args) const override {} 690b57cec5SDimitry Andric void addLibStdCxxIncludePaths( 700b57cec5SDimitry Andric const llvm::opt::ArgList &DriverArgs, 710b57cec5SDimitry Andric llvm::opt::ArgStringList &CC1Args) const override {} 720b57cec5SDimitry Andric 730b57cec5SDimitry Andric bool IsMathErrnoDefault() const override { return false; } 740b57cec5SDimitry Andric bool IsObjCNonFragileABIDefault() const override { return true; } 750b57cec5SDimitry Andric bool HasNativeLLVMSupport() const override; 760b57cec5SDimitry Andric bool isPICDefault() const override; 770b57cec5SDimitry Andric 78e8d8bef9SDimitry Andric LangOptions::StackProtectorMode 79e8d8bef9SDimitry Andric GetDefaultStackProtectorLevel(bool KernelOrKext) const override { 80e8d8bef9SDimitry Andric return LangOptions::SSPStrong; 810b57cec5SDimitry Andric } 820b57cec5SDimitry Andric 830b57cec5SDimitry Andric llvm::DebuggerKind getDefaultDebuggerTuning() const override { 840b57cec5SDimitry Andric return llvm::DebuggerKind::SCE; 850b57cec5SDimitry Andric } 860b57cec5SDimitry Andric 870b57cec5SDimitry Andric SanitizerMask getSupportedSanitizers() const override; 880b57cec5SDimitry Andric 89480093f4SDimitry Andric // PS4 toolchain uses legacy thin LTO API, which is not 90480093f4SDimitry Andric // capable of unit splitting. 91480093f4SDimitry Andric bool canSplitThinLTOUnit() const override { return false; } 92480093f4SDimitry Andric 935ffd83dbSDimitry Andric void addClangTargetOptions( 945ffd83dbSDimitry Andric const llvm::opt::ArgList &DriverArgs, 955ffd83dbSDimitry Andric llvm::opt::ArgStringList &CC1Args, 965ffd83dbSDimitry Andric Action::OffloadKind DeviceOffloadingKind) const override; 975ffd83dbSDimitry Andric 985ffd83dbSDimitry Andric llvm::DenormalMode getDefaultDenormalModeForType( 995ffd83dbSDimitry Andric const llvm::opt::ArgList &DriverArgs, const JobAction &JA, 1005ffd83dbSDimitry Andric const llvm::fltSemantics *FPType) const override { 1015ffd83dbSDimitry Andric // DAZ and FTZ are on by default. 1025ffd83dbSDimitry Andric return llvm::DenormalMode::getPreserveSign(); 1035ffd83dbSDimitry Andric } 1045ffd83dbSDimitry Andric 1055ffd83dbSDimitry Andric bool useRelaxRelocations() const override { return true; } 1065ffd83dbSDimitry Andric 1070b57cec5SDimitry Andric protected: 1080b57cec5SDimitry Andric Tool *buildAssembler() const override; 1090b57cec5SDimitry Andric Tool *buildLinker() const override; 1100b57cec5SDimitry Andric }; 1110b57cec5SDimitry Andric 1120b57cec5SDimitry Andric } // end namespace toolchains 1130b57cec5SDimitry Andric } // end namespace driver 1140b57cec5SDimitry Andric } // end namespace clang 1150b57cec5SDimitry Andric 1160b57cec5SDimitry Andric #endif // LLVM_CLANG_LIB_DRIVER_TOOLCHAINS_PS4CPU_H 117