1 | //===--- SPIRVInlineAsmLowering.h - Inline Asm lowering ---------*- 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 | // This file describes how to lower LLVM inline asm calls to machine |
10 | // code calls for GlobalISel. |
11 | // |
12 | //===----------------------------------------------------------------------===// |
13 | |
14 | #ifndef LLVM_LIB_TARGET_SPIRV_SPIRVINLINEASMLOWERING_H |
15 | #define LLVM_LIB_TARGET_SPIRV_SPIRVINLINEASMLOWERING_H |
16 | |
17 | #include "llvm/CodeGen/GlobalISel/InlineAsmLowering.h" |
18 | |
19 | namespace llvm { |
20 | |
21 | class SPIRVTargetLowering; |
22 | |
23 | class SPIRVInlineAsmLowering : public InlineAsmLowering { |
24 | public: |
25 | SPIRVInlineAsmLowering(const SPIRVTargetLowering &TLI); |
26 | bool |
27 | lowerAsmOperandForConstraint(Value *Val, StringRef Constraint, |
28 | std::vector<MachineOperand> &Ops, |
29 | MachineIRBuilder &MIRBuilder) const override; |
30 | }; |
31 | } // end namespace llvm |
32 | |
33 | #endif // LLVM_LIB_TARGET_SPIRV_SPIRVINLINEASMLOWERING_H |
34 | |