xref: /freebsd/contrib/llvm-project/llvm/lib/Target/SPIRV/SPIRV.h (revision 81ad626541db97eb356e2c1d4a20eb2a26a766ab)
1*81ad6265SDimitry Andric //===-- SPIRV.h - Top-level interface for SPIR-V representation -*- C++ -*-===//
2*81ad6265SDimitry Andric //
3*81ad6265SDimitry Andric // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4*81ad6265SDimitry Andric // See https://llvm.org/LICENSE.txt for license information.
5*81ad6265SDimitry Andric // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6*81ad6265SDimitry Andric //
7*81ad6265SDimitry Andric //===----------------------------------------------------------------------===//
8*81ad6265SDimitry Andric 
9*81ad6265SDimitry Andric #ifndef LLVM_LIB_TARGET_SPIRV_SPIRV_H
10*81ad6265SDimitry Andric #define LLVM_LIB_TARGET_SPIRV_SPIRV_H
11*81ad6265SDimitry Andric 
12*81ad6265SDimitry Andric #include "MCTargetDesc/SPIRVMCTargetDesc.h"
13*81ad6265SDimitry Andric #include "llvm/CodeGen/MachineFunctionPass.h"
14*81ad6265SDimitry Andric #include "llvm/Target/TargetMachine.h"
15*81ad6265SDimitry Andric 
16*81ad6265SDimitry Andric namespace llvm {
17*81ad6265SDimitry Andric class SPIRVTargetMachine;
18*81ad6265SDimitry Andric class SPIRVSubtarget;
19*81ad6265SDimitry Andric class InstructionSelector;
20*81ad6265SDimitry Andric class RegisterBankInfo;
21*81ad6265SDimitry Andric 
22*81ad6265SDimitry Andric FunctionPass *createSPIRVPreLegalizerPass();
23*81ad6265SDimitry Andric FunctionPass *createSPIRVEmitIntrinsicsPass(SPIRVTargetMachine *TM);
24*81ad6265SDimitry Andric InstructionSelector *
25*81ad6265SDimitry Andric createSPIRVInstructionSelector(const SPIRVTargetMachine &TM,
26*81ad6265SDimitry Andric                                const SPIRVSubtarget &Subtarget,
27*81ad6265SDimitry Andric                                const RegisterBankInfo &RBI);
28*81ad6265SDimitry Andric 
29*81ad6265SDimitry Andric void initializeSPIRVModuleAnalysisPass(PassRegistry &);
30*81ad6265SDimitry Andric void initializeSPIRVPreLegalizerPass(PassRegistry &);
31*81ad6265SDimitry Andric void initializeSPIRVEmitIntrinsicsPass(PassRegistry &);
32*81ad6265SDimitry Andric } // namespace llvm
33*81ad6265SDimitry Andric 
34*81ad6265SDimitry Andric #endif // LLVM_LIB_TARGET_SPIRV_SPIRV_H
35