abb7f21512a7915d47e537404132c6d2f72fcbf4
[oota-llvm.git] / lib / Target / WebAssembly / WebAssemblyInstrCall.td
1 //===- WebAssemblyInstrCall.td-WebAssembly Call codegen support -*- tablegen -*-
2 //
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 ///
10 /// \file
11 /// \brief WebAssembly Call operand code-gen constructs.
12 ///
13 //===----------------------------------------------------------------------===//
14
15 // The call sequence start/end LLVM-isms isn't useful to WebAssembly since it's
16 // a virtual ISA.
17 let isCodeGenOnly = 1 in {
18 def : I<(outs), (ins i64imm:$amt),
19         [(WebAssemblycallseq_start timm:$amt)]>;
20 def : I<(outs), (ins i64imm:$amt1, i64imm:$amt2),
21         [(WebAssemblycallseq_end timm:$amt1, timm:$amt2)]>;
22 } // isCodeGenOnly = 1
23
24 multiclass CALL<WebAssemblyRegClass vt> {
25   def CALL_#vt : I<(outs vt:$dst), (ins Int32:$callee, variable_ops),
26                    [(set vt:$dst, (WebAssemblycall Int32:$callee))]>;
27 }
28 let Uses = [SP32, SP64], isCall = 1 in {
29   defm : CALL<Int32>;
30   defm : CALL<Int64>;
31   defm : CALL<Float32>;
32   defm : CALL<Float64>;
33   // FIXME: void.
34 } // Uses = [SP32,SP64], isCall = 1
35
36 /*
37  * TODO(jfb): Add the following.
38  *
39  * call_direct: call function directly
40  * call_indirect: call function indirectly
41  * addressof: obtain a function pointer value for a given function
42  */