| //===-- SPIRVBuiltins.h - SPIR-V Built-in Functions -------------*- C++ -*-===// |
| // |
| // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. |
| // See https://llvm.org/LICENSE.txt for license information. |
| // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception |
| // |
| //===----------------------------------------------------------------------===// |
| // |
| // Lowering builtin function calls and types using their demangled names. |
| // |
| //===----------------------------------------------------------------------===// |
| |
| #ifndef LLVM_LIB_TARGET_SPIRV_SPIRVBUILTINS_H |
| #define LLVM_LIB_TARGET_SPIRV_SPIRVBUILTINS_H |
| |
| #include "SPIRVGlobalRegistry.h" |
| #include "llvm/CodeGen/GlobalISel/CallLowering.h" |
| #include "llvm/CodeGen/GlobalISel/MachineIRBuilder.h" |
| |
| namespace llvm { |
| namespace SPIRV { |
| /// Parses the name part of the demangled builtin call. |
| std::string lookupBuiltinNameHelper(StringRef DemangledCall); |
| /// Lowers a builtin function call using the provided \p DemangledCall skeleton |
| /// and external instruction \p Set. |
| /// |
| /// \return the lowering success status if the called function is a recognized |
| /// builtin, std::nullopt otherwise. |
| /// |
| /// \p DemangledCall is the skeleton of the lowered builtin function call. |
| /// \p Set is the external instruction set containing the given builtin. |
| /// \p OrigRet is the single original virtual return register if defined, |
| /// Register(0) otherwise. |
| /// \p OrigRetTy is the type of the \p OrigRet. |
| /// \p Args are the arguments of the lowered builtin call. |
| std::optional<bool> lowerBuiltin(const StringRef DemangledCall, |
| InstructionSet::InstructionSet Set, |
| MachineIRBuilder &MIRBuilder, |
| const Register OrigRet, const Type *OrigRetTy, |
| const SmallVectorImpl<Register> &Args, |
| SPIRVGlobalRegistry *GR); |
| |
| /// Helper function for finding a builtin function attributes |
| /// by a demangled function name. Defined in SPIRVBuiltins.cpp. |
| std::tuple<int, unsigned, unsigned> |
| mapBuiltinToOpcode(const StringRef DemangledCall, |
| SPIRV::InstructionSet::InstructionSet Set); |
| |
| /// Parses the provided \p ArgIdx argument base type in the \p DemangledCall |
| /// skeleton. A base type is either a basic type (e.g. i32 for int), pointer |
| /// element type (e.g. i8 for char*), or builtin type (TargetExtType). |
| /// |
| /// \return LLVM Type or nullptr if unrecognized |
| /// |
| /// \p DemangledCall is the skeleton of the lowered builtin function call. |
| /// \p ArgIdx is the index of the argument to parse. |
| Type *parseBuiltinCallArgumentBaseType(const StringRef DemangledCall, |
| unsigned ArgIdx, LLVMContext &Ctx); |
| |
| /// Translates a string representing a SPIR-V or OpenCL builtin type to a |
| /// TargetExtType that can be further lowered with lowerBuiltinType(). |
| /// |
| /// \return A TargetExtType representing the builtin SPIR-V type. |
| /// |
| /// \p TypeName is the full string representation of the SPIR-V or OpenCL |
| /// builtin type. |
| TargetExtType *parseBuiltinTypeNameToTargetExtType(std::string TypeName, |
| LLVMContext &Context); |
| |
| /// Handles the translation of the provided special opaque/builtin type \p Type |
| /// to SPIR-V type. Generates the corresponding machine instructions for the |
| /// target type or gets the already existing OpType<...> register from the |
| /// global registry \p GR. |
| /// |
| /// \return A machine instruction representing the OpType<...> SPIR-V type. |
| /// |
| /// \p Type is the special opaque/builtin type to be lowered. |
| SPIRVType *lowerBuiltinType(const Type *Type, |
| AccessQualifier::AccessQualifier AccessQual, |
| MachineIRBuilder &MIRBuilder, |
| SPIRVGlobalRegistry *GR); |
| } // namespace SPIRV |
| } // namespace llvm |
| #endif // LLVM_LIB_TARGET_SPIRV_SPIRVBUILTINS_H |