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();
24FunctionPass *createSPIRVMergeRegionExitTargetsPass();
25FunctionPass *createSPIRVStripConvergenceIntrinsicsPass();
26FunctionPass *createSPIRVLegalizePointerCastPass(SPIRVTargetMachine *TM);
27FunctionPass *createSPIRVRegularizerPass();
28FunctionPass *createSPIRVPreLegalizerCombiner();
29FunctionPass *createSPIRVPreLegalizerPass();
30FunctionPass *createSPIRVPostLegalizerPass();
31ModulePass *createSPIRVEmitIntrinsicsPass(SPIRVTargetMachine *TM);
32MachineFunctionPass *createSPIRVEmitNonSemanticDIPass(SPIRVTargetMachine *TM);
33InstructionSelector *
34createSPIRVInstructionSelector(const SPIRVTargetMachine &TM,
35 const SPIRVSubtarget &Subtarget,
36 const RegisterBankInfo &RBI);
37
38void initializeSPIRVModuleAnalysisPass(PassRegistry &);
39void initializeSPIRVAsmPrinterPass(PassRegistry &);
40void initializeSPIRVConvergenceRegionAnalysisWrapperPassPass(PassRegistry &);
41void initializeSPIRVPreLegalizerPass(PassRegistry &);
42void initializeSPIRVPreLegalizerCombinerPass(PassRegistry &);
43void initializeSPIRVPostLegalizerPass(PassRegistry &);
44void initializeSPIRVStructurizerPass(PassRegistry &);
45void initializeSPIRVEmitIntrinsicsPass(PassRegistry &);
46void initializeSPIRVEmitNonSemanticDIPass(PassRegistry &);
47void initializeSPIRVLegalizePointerCastPass(PassRegistry &);
48void initializeSPIRVRegularizerPass(PassRegistry &);
49void initializeSPIRVMergeRegionExitTargetsPass(PassRegistry &);
50void initializeSPIRVPrepareFunctionsPass(PassRegistry &);
51void initializeSPIRVStripConvergentIntrinsicsPass(PassRegistry &);
52} // namespace llvm
53
54#endif // LLVM_LIB_TARGET_SPIRV_SPIRV_H
55