1*0fca6ea1SDimitry Andric //===--- SPIRVInlineAsmLowering.h - Inline Asm lowering ---------*- C++ -*-===// 2*0fca6ea1SDimitry Andric // 3*0fca6ea1SDimitry Andric // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 4*0fca6ea1SDimitry Andric // See https://llvm.org/LICENSE.txt for license information. 5*0fca6ea1SDimitry Andric // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 6*0fca6ea1SDimitry Andric // 7*0fca6ea1SDimitry Andric //===----------------------------------------------------------------------===// 8*0fca6ea1SDimitry Andric // 9*0fca6ea1SDimitry Andric // This file describes how to lower LLVM inline asm calls to machine 10*0fca6ea1SDimitry Andric // code calls for GlobalISel. 11*0fca6ea1SDimitry Andric // 12*0fca6ea1SDimitry Andric //===----------------------------------------------------------------------===// 13*0fca6ea1SDimitry Andric 14*0fca6ea1SDimitry Andric #ifndef LLVM_LIB_TARGET_SPIRV_SPIRVINLINEASMLOWERING_H 15*0fca6ea1SDimitry Andric #define LLVM_LIB_TARGET_SPIRV_SPIRVINLINEASMLOWERING_H 16*0fca6ea1SDimitry Andric 17*0fca6ea1SDimitry Andric #include "llvm/CodeGen/GlobalISel/InlineAsmLowering.h" 18*0fca6ea1SDimitry Andric 19*0fca6ea1SDimitry Andric namespace llvm { 20*0fca6ea1SDimitry Andric 21*0fca6ea1SDimitry Andric class SPIRVTargetLowering; 22*0fca6ea1SDimitry Andric 23*0fca6ea1SDimitry Andric class SPIRVInlineAsmLowering : public InlineAsmLowering { 24*0fca6ea1SDimitry Andric public: 25*0fca6ea1SDimitry Andric SPIRVInlineAsmLowering(const SPIRVTargetLowering &TLI); 26*0fca6ea1SDimitry Andric bool 27*0fca6ea1SDimitry Andric lowerAsmOperandForConstraint(Value *Val, StringRef Constraint, 28*0fca6ea1SDimitry Andric std::vector<MachineOperand> &Ops, 29*0fca6ea1SDimitry Andric MachineIRBuilder &MIRBuilder) const override; 30*0fca6ea1SDimitry Andric }; 31*0fca6ea1SDimitry Andric } // end namespace llvm 32*0fca6ea1SDimitry Andric 33*0fca6ea1SDimitry Andric #endif // LLVM_LIB_TARGET_SPIRV_SPIRVINLINEASMLOWERING_H 34