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 21*81ad6265SDimitry Andric namespace PScpu { 22*81ad6265SDimitry Andric // Functions/classes in this namespace support both PS4 and PS5. 230b57cec5SDimitry Andric 240b57cec5SDimitry Andric void addProfileRTArgs(const ToolChain &TC, const llvm::opt::ArgList &Args, 250b57cec5SDimitry Andric llvm::opt::ArgStringList &CmdArgs); 260b57cec5SDimitry Andric 27349cc55cSDimitry Andric void addSanitizerArgs(const ToolChain &TC, const llvm::opt::ArgList &Args, 28349cc55cSDimitry Andric llvm::opt::ArgStringList &CmdArgs); 290b57cec5SDimitry Andric 30*81ad6265SDimitry Andric class LLVM_LIBRARY_VISIBILITY Assembler : public Tool { 310b57cec5SDimitry Andric public: 32*81ad6265SDimitry Andric Assembler(const ToolChain &TC) : Tool("PScpu::Assembler", "assembler", TC) {} 330b57cec5SDimitry Andric 340b57cec5SDimitry Andric bool hasIntegratedCPP() const override { return false; } 350b57cec5SDimitry Andric 360b57cec5SDimitry Andric void ConstructJob(Compilation &C, const JobAction &JA, 37*81ad6265SDimitry Andric const InputInfo &Output, const InputInfoList &Inputs, 380b57cec5SDimitry Andric const llvm::opt::ArgList &TCArgs, 390b57cec5SDimitry Andric const char *LinkingOutput) const override; 400b57cec5SDimitry Andric }; 410b57cec5SDimitry Andric 42*81ad6265SDimitry Andric class LLVM_LIBRARY_VISIBILITY Linker : public Tool { 430b57cec5SDimitry Andric public: 44*81ad6265SDimitry Andric Linker(const ToolChain &TC) : Tool("PScpu::Linker", "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, 50*81ad6265SDimitry Andric const InputInfo &Output, const InputInfoList &Inputs, 510b57cec5SDimitry Andric const llvm::opt::ArgList &TCArgs, 520b57cec5SDimitry Andric const char *LinkingOutput) const override; 530b57cec5SDimitry Andric }; 54*81ad6265SDimitry Andric } // namespace PScpu 550b57cec5SDimitry Andric } // namespace tools 560b57cec5SDimitry Andric 570b57cec5SDimitry Andric namespace toolchains { 580b57cec5SDimitry Andric 59*81ad6265SDimitry Andric // Common Toolchain base class for PS4 and PS5. 60*81ad6265SDimitry Andric class LLVM_LIBRARY_VISIBILITY PS4PS5Base : public Generic_ELF { 610b57cec5SDimitry Andric public: 62*81ad6265SDimitry Andric PS4PS5Base(const Driver &D, const llvm::Triple &Triple, 63*81ad6265SDimitry Andric const llvm::opt::ArgList &Args, StringRef Platform, 64*81ad6265SDimitry Andric const char *EnvVar); 650b57cec5SDimitry Andric 660b57cec5SDimitry Andric // No support for finding a C++ standard library yet. 67*81ad6265SDimitry Andric void addLibCxxIncludePaths(const llvm::opt::ArgList &DriverArgs, 68*81ad6265SDimitry Andric llvm::opt::ArgStringList &CC1Args) const override { 69*81ad6265SDimitry Andric } 70*81ad6265SDimitry Andric void 71*81ad6265SDimitry Andric addLibStdCxxIncludePaths(const llvm::opt::ArgList &DriverArgs, 720b57cec5SDimitry Andric llvm::opt::ArgStringList &CC1Args) const override {} 730b57cec5SDimitry Andric 740b57cec5SDimitry Andric bool IsMathErrnoDefault() const override { return false; } 750b57cec5SDimitry Andric bool IsObjCNonFragileABIDefault() const override { return true; } 76*81ad6265SDimitry Andric bool HasNativeLLVMSupport() const override { return true; } 77*81ad6265SDimitry Andric bool isPICDefault() const override { return true; } 780b57cec5SDimitry Andric 79e8d8bef9SDimitry Andric LangOptions::StackProtectorMode 80e8d8bef9SDimitry Andric GetDefaultStackProtectorLevel(bool KernelOrKext) const override { 81e8d8bef9SDimitry Andric return LangOptions::SSPStrong; 820b57cec5SDimitry Andric } 830b57cec5SDimitry Andric 840b57cec5SDimitry Andric llvm::DebuggerKind getDefaultDebuggerTuning() const override { 850b57cec5SDimitry Andric return llvm::DebuggerKind::SCE; 860b57cec5SDimitry Andric } 870b57cec5SDimitry Andric 880b57cec5SDimitry Andric SanitizerMask getSupportedSanitizers() const override; 890b57cec5SDimitry Andric 905ffd83dbSDimitry Andric void addClangTargetOptions( 91*81ad6265SDimitry Andric const llvm::opt::ArgList &DriverArgs, llvm::opt::ArgStringList &CC1Args, 925ffd83dbSDimitry Andric Action::OffloadKind DeviceOffloadingKind) const override; 935ffd83dbSDimitry Andric 945ffd83dbSDimitry Andric llvm::DenormalMode getDefaultDenormalModeForType( 955ffd83dbSDimitry Andric const llvm::opt::ArgList &DriverArgs, const JobAction &JA, 965ffd83dbSDimitry Andric const llvm::fltSemantics *FPType) const override { 975ffd83dbSDimitry Andric // DAZ and FTZ are on by default. 985ffd83dbSDimitry Andric return llvm::DenormalMode::getPreserveSign(); 995ffd83dbSDimitry Andric } 1005ffd83dbSDimitry Andric 1015ffd83dbSDimitry Andric bool useRelaxRelocations() const override { return true; } 1025ffd83dbSDimitry Andric 103*81ad6265SDimitry Andric // Helper methods for PS4/PS5. 104*81ad6265SDimitry Andric virtual const char *getLinkerBaseName() const = 0; 105*81ad6265SDimitry Andric virtual std::string qualifyPSCmdName(StringRef CmdName) const = 0; 106*81ad6265SDimitry Andric virtual void addSanitizerArgs(const llvm::opt::ArgList &Args, 107*81ad6265SDimitry Andric llvm::opt::ArgStringList &CmdArgs, 108*81ad6265SDimitry Andric const char *Prefix, 109*81ad6265SDimitry Andric const char *Suffix) const = 0; 110*81ad6265SDimitry Andric virtual const char *getProfileRTLibName() const = 0; 111*81ad6265SDimitry Andric 112*81ad6265SDimitry Andric protected: 113*81ad6265SDimitry Andric Tool *buildLinker() const override; 114*81ad6265SDimitry Andric }; 115*81ad6265SDimitry Andric 116*81ad6265SDimitry Andric // PS4-specific Toolchain class. 117*81ad6265SDimitry Andric class LLVM_LIBRARY_VISIBILITY PS4CPU : public PS4PS5Base { 118*81ad6265SDimitry Andric public: 119*81ad6265SDimitry Andric PS4CPU(const Driver &D, const llvm::Triple &Triple, 120*81ad6265SDimitry Andric const llvm::opt::ArgList &Args); 121*81ad6265SDimitry Andric 122*81ad6265SDimitry Andric unsigned GetDefaultDwarfVersion() const override { return 4; } 123*81ad6265SDimitry Andric 124*81ad6265SDimitry Andric // PS4 toolchain uses legacy thin LTO API, which is not 125*81ad6265SDimitry Andric // capable of unit splitting. 126*81ad6265SDimitry Andric bool canSplitThinLTOUnit() const override { return false; } 127*81ad6265SDimitry Andric 128*81ad6265SDimitry Andric const char *getLinkerBaseName() const override { return "ld"; } 129*81ad6265SDimitry Andric std::string qualifyPSCmdName(StringRef CmdName) const override { 130*81ad6265SDimitry Andric return Twine("orbis-", CmdName).str(); 131*81ad6265SDimitry Andric } 132*81ad6265SDimitry Andric void addSanitizerArgs(const llvm::opt::ArgList &Args, 133*81ad6265SDimitry Andric llvm::opt::ArgStringList &CmdArgs, const char *Prefix, 134*81ad6265SDimitry Andric const char *Suffix) const override; 135*81ad6265SDimitry Andric const char *getProfileRTLibName() const override { 136*81ad6265SDimitry Andric return "libclang_rt.profile-x86_64.a"; 137*81ad6265SDimitry Andric } 138*81ad6265SDimitry Andric 1390b57cec5SDimitry Andric protected: 1400b57cec5SDimitry Andric Tool *buildAssembler() const override; 141*81ad6265SDimitry Andric }; 142*81ad6265SDimitry Andric 143*81ad6265SDimitry Andric // PS5-specific Toolchain class. 144*81ad6265SDimitry Andric class LLVM_LIBRARY_VISIBILITY PS5CPU : public PS4PS5Base { 145*81ad6265SDimitry Andric public: 146*81ad6265SDimitry Andric PS5CPU(const Driver &D, const llvm::Triple &Triple, 147*81ad6265SDimitry Andric const llvm::opt::ArgList &Args); 148*81ad6265SDimitry Andric 149*81ad6265SDimitry Andric unsigned GetDefaultDwarfVersion() const override { return 5; } 150*81ad6265SDimitry Andric 151*81ad6265SDimitry Andric SanitizerMask getSupportedSanitizers() const override; 152*81ad6265SDimitry Andric 153*81ad6265SDimitry Andric const char *getLinkerBaseName() const override { return "lld"; } 154*81ad6265SDimitry Andric std::string qualifyPSCmdName(StringRef CmdName) const override { 155*81ad6265SDimitry Andric return Twine("prospero-", CmdName).str(); 156*81ad6265SDimitry Andric } 157*81ad6265SDimitry Andric void addSanitizerArgs(const llvm::opt::ArgList &Args, 158*81ad6265SDimitry Andric llvm::opt::ArgStringList &CmdArgs, const char *Prefix, 159*81ad6265SDimitry Andric const char *Suffix) const override; 160*81ad6265SDimitry Andric const char *getProfileRTLibName() const override { 161*81ad6265SDimitry Andric return "libclang_rt.profile-x86_64_nosubmission.a"; 162*81ad6265SDimitry Andric } 163*81ad6265SDimitry Andric 164*81ad6265SDimitry Andric protected: 165*81ad6265SDimitry Andric Tool *buildAssembler() const override; 1660b57cec5SDimitry Andric }; 1670b57cec5SDimitry Andric 1680b57cec5SDimitry Andric } // end namespace toolchains 1690b57cec5SDimitry Andric } // end namespace driver 1700b57cec5SDimitry Andric } // end namespace clang 1710b57cec5SDimitry Andric 1720b57cec5SDimitry Andric #endif // LLVM_CLANG_LIB_DRIVER_TOOLCHAINS_PS4CPU_H 173