1//===-- SPIRV.h - Top-level interface for SPIR-V representation -*- C++ -*-===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8
9#ifndef LLVM_LIB_TARGET_SPIRV_SPIRV_H
10#define LLVM_LIB_TARGET_SPIRV_SPIRV_H
11
12#include "MCTargetDesc/SPIRVMCTargetDesc.h"
13#include "llvm/CodeGen/MachineFunctionPass.h"
14#include "llvm/Target/TargetMachine.h"
15
16namespace llvm {
17class SPIRVTargetMachine;
18class SPIRVSubtarget;
19class InstructionSelector;
20class RegisterBankInfo;
21
22ModulePass *createSPIRVPrepareFunctionsPass(const SPIRVTargetMachine &TM);
23FunctionPass *createSPIRVStructurizerPass();
24ModulePass *createSPIRVCBufferAccessLegacyPass();
25ModulePass *createSPIRVPushConstantAccessLegacyPass(SPIRVTargetMachine *TM);
26FunctionPass *createSPIRVMergeRegionExitTargetsPass();
27FunctionPass *createSPIRVStripConvergenceIntrinsicsPass();
28ModulePass *createSPIRVLegalizeImplicitBindingPass();
29ModulePass *createSPIRVLegalizeZeroSizeArraysPass(const SPIRVTargetMachine &TM);
30FunctionPass *createSPIRVLegalizePointerCastPass(SPIRVTargetMachine *TM);
31FunctionPass *createSPIRVRegularizerPass();
32FunctionPass *createSPIRVPreLegalizerCombiner();
33FunctionPass *createSPIRVPreLegalizerPass();
34FunctionPass *createSPIRVPostLegalizerPass();
35ModulePass *createSPIRVEmitIntrinsicsPass(SPIRVTargetMachine *TM);
36ModulePass *createSPIRVPrepareGlobalsPass();
37MachineFunctionPass *createSPIRVEmitNonSemanticDIPass(SPIRVTargetMachine *TM);
38InstructionSelector *
39createSPIRVInstructionSelector(const SPIRVTargetMachine &TM,
40 const SPIRVSubtarget &Subtarget,
41 const RegisterBankInfo &RBI);
42
43void initializeSPIRVModuleAnalysisPass(PassRegistry &);
44void initializeSPIRVAsmPrinterPass(PassRegistry &);
45void initializeSPIRVConvergenceRegionAnalysisWrapperPassPass(PassRegistry &);
46void initializeSPIRVPreLegalizerPass(PassRegistry &);
47void initializeSPIRVPreLegalizerCombinerPass(PassRegistry &);
48void initializeSPIRVPostLegalizerPass(PassRegistry &);
49void initializeSPIRVStructurizerPass(PassRegistry &);
50void initializeSPIRVCBufferAccessLegacyPass(PassRegistry &);
51void initializeSPIRVPushConstantAccessLegacyPass(PassRegistry &);
52void initializeSPIRVEmitIntrinsicsPass(PassRegistry &);
53void initializeSPIRVEmitNonSemanticDIPass(PassRegistry &);
54void initializeSPIRVLegalizePointerCastPass(PassRegistry &);
55void initializeSPIRVRegularizerPass(PassRegistry &);
56void initializeSPIRVMergeRegionExitTargetsPass(PassRegistry &);
57void initializeSPIRVPrepareFunctionsPass(PassRegistry &);
58void initializeSPIRVPrepareGlobalsPass(PassRegistry &);
59void initializeSPIRVStripConvergentIntrinsicsPass(PassRegistry &);
60void initializeSPIRVLegalizeImplicitBindingPass(PassRegistry &);
61void initializeSPIRVLegalizeZeroSizeArraysLegacyPass(PassRegistry &);
62} // namespace llvm
63
64#endif // LLVM_LIB_TARGET_SPIRV_SPIRV_H
65