MLIR  20.0.0git
Namespaces | Macros | Functions
GPUToLLVMSPV.cpp File Reference
#include "mlir/Conversion/GPUToLLVMSPV/GPUToLLVMSPVPass.h"
#include "../GPUCommon/GPUOpsLowering.h"
#include "mlir/Conversion/GPUCommon/AttrToSPIRVConverter.h"
#include "mlir/Conversion/GPUCommon/GPUCommonPass.h"
#include "mlir/Conversion/LLVMCommon/ConversionTarget.h"
#include "mlir/Conversion/LLVMCommon/LoweringOptions.h"
#include "mlir/Conversion/LLVMCommon/Pattern.h"
#include "mlir/Conversion/LLVMCommon/TypeConverter.h"
#include "mlir/Conversion/SPIRVCommon/AttrToLLVMConverter.h"
#include "mlir/Dialect/GPU/IR/GPUDialect.h"
#include "mlir/Dialect/LLVMIR/LLVMAttrs.h"
#include "mlir/Dialect/LLVMIR/LLVMDialect.h"
#include "mlir/Dialect/LLVMIR/LLVMTypes.h"
#include "mlir/Dialect/SPIRV/IR/SPIRVDialect.h"
#include "mlir/Dialect/SPIRV/IR/SPIRVEnums.h"
#include "mlir/Dialect/SPIRV/IR/TargetAndABI.h"
#include "mlir/IR/BuiltinTypes.h"
#include "mlir/IR/Matchers.h"
#include "mlir/IR/PatternMatch.h"
#include "mlir/IR/SymbolTable.h"
#include "mlir/Pass/Pass.h"
#include "mlir/Support/LLVM.h"
#include "mlir/Transforms/DialectConversion.h"
#include "llvm/ADT/TypeSwitch.h"
#include "llvm/Support/FormatVariadic.h"
#include "mlir/Conversion/Passes.h.inc"

Go to the source code of this file.

Namespaces

 mlir
 Include the generated interface declarations.
 

Macros

#define DEBUG_TYPE   "gpu-to-llvm-spv"
 
#define GEN_PASS_DEF_CONVERTGPUOPSTOLLVMSPVOPS
 

Functions

static LLVM::LLVMFuncOp lookupOrCreateSPIRVFn (Operation *symbolTable, StringRef name, ArrayRef< Type > paramTypes, Type resultType, bool isMemNone, bool isConvergent)
 
static LLVM::CallOp createSPIRVBuiltinCall (Location loc, ConversionPatternRewriter &rewriter, LLVM::LLVMFuncOp func, ValueRange args)
 
void mlir::populateGpuToLLVMSPVConversionPatterns (const LLVMTypeConverter &converter, RewritePatternSet &patterns)
 
void mlir::populateGpuMemorySpaceAttributeConversions (TypeConverter &typeConverter)
 Populates memory space attribute conversion rules for lowering gpu.address_space to integer values. More...
 

Macro Definition Documentation

◆ DEBUG_TYPE

#define DEBUG_TYPE   "gpu-to-llvm-spv"

Definition at line 37 of file GPUToLLVMSPV.cpp.

◆ GEN_PASS_DEF_CONVERTGPUOPSTOLLVMSPVOPS

#define GEN_PASS_DEF_CONVERTGPUOPSTOLLVMSPVOPS

Definition at line 42 of file GPUToLLVMSPV.cpp.

Function Documentation

◆ createSPIRVBuiltinCall()

static LLVM::CallOp createSPIRVBuiltinCall ( Location  loc,
ConversionPatternRewriter rewriter,
LLVM::LLVMFuncOp  func,
ValueRange  args 
)
static

Definition at line 80 of file GPUToLLVMSPV.cpp.

References mlir::OpBuilder::create().

◆ lookupOrCreateSPIRVFn()

static LLVM::LLVMFuncOp lookupOrCreateSPIRVFn ( Operation symbolTable,
StringRef  name,
ArrayRef< Type paramTypes,
Type  resultType,
bool  isMemNone,
bool  isConvergent 
)
static