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(const SPIRVTargetMachine &TM);
36ModulePass *createSPIRVPrepareGlobalsPass();
37MachineFunctionPass *createSPIRVEmitNonSemanticDIPass(SPIRVTargetMachine *TM);
38ModulePass *createSPIRVCtorDtorLoweringLegacyPass();
39InstructionSelector *
40createSPIRVInstructionSelector(const SPIRVTargetMachine &TM,
41 const SPIRVSubtarget &Subtarget,
42 const RegisterBankInfo &RBI);
43
44void initializeSPIRVModuleAnalysisPass(PassRegistry &);
45void initializeSPIRVAsmPrinterPass(PassRegistry &);
46void initializeSPIRVConvergenceRegionAnalysisWrapperPassPass(PassRegistry &);
47void initializeSPIRVPreLegalizerPass(PassRegistry &);
48void initializeSPIRVPreLegalizerCombinerPass(PassRegistry &);
49void initializeSPIRVPostLegalizerPass(PassRegistry &);
50void initializeSPIRVStructurizerPass(PassRegistry &);
51void initializeSPIRVCBufferAccessLegacyPass(PassRegistry &);
52void initializeSPIRVPushConstantAccessLegacyPass(PassRegistry &);
53void initializeSPIRVEmitIntrinsicsPass(PassRegistry &);
54void initializeSPIRVEmitNonSemanticDIPass(PassRegistry &);
55void initializeSPIRVLegalizePointerCastPass(PassRegistry &);
56void initializeSPIRVRegularizerPass(PassRegistry &);
57void initializeSPIRVMergeRegionExitTargetsPass(PassRegistry &);
58void initializeSPIRVPrepareFunctionsPass(PassRegistry &);
59void initializeSPIRVPrepareGlobalsPass(PassRegistry &);
60void initializeSPIRVStripConvergentIntrinsicsPass(PassRegistry &);
61void initializeSPIRVLegalizeImplicitBindingPass(PassRegistry &);
62void initializeSPIRVLegalizeZeroSizeArraysLegacyPass(PassRegistry &);
63void initializeSPIRVCtorDtorLoweringLegacyPass(PassRegistry &);
64} // namespace llvm
65
66#endif // LLVM_LIB_TARGET_SPIRV_SPIRV_H
67