blob: 4028460bd231c724aac084eecaa7b6c588f48b02 [file] [log] [blame]
JF Bastien5ca0bac2015-07-10 18:23:10 +00001//===- 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
Dan Gohmanfb3e0592015-11-25 19:36:19 +000015let Defs = [ARGUMENTS] in {
16
JF Bastienaf111db2015-08-24 22:16:48 +000017// The call sequence start/end LLVM-isms isn't useful to WebAssembly since it's
18// a virtual ISA.
19let isCodeGenOnly = 1 in {
20def : I<(outs), (ins i64imm:$amt),
21 [(WebAssemblycallseq_start timm:$amt)]>;
22def : I<(outs), (ins i64imm:$amt1, i64imm:$amt2),
23 [(WebAssemblycallseq_end timm:$amt1, timm:$amt2)]>;
24} // isCodeGenOnly = 1
25
26multiclass CALL<WebAssemblyRegClass vt> {
Dan Gohman05a17aa2015-09-28 16:22:39 +000027 def CALL_#vt : I<(outs vt:$dst), (ins global:$callee, variable_ops),
Dan Gohmancf4748f2015-11-12 17:04:33 +000028 [(set vt:$dst, (WebAssemblycall1 (WebAssemblywrapper tglobaladdr:$callee)))],
Dan Gohman2f16f252015-11-23 22:04:06 +000029 "call \t$dst, $callee">;
Dan Gohman05a17aa2015-09-28 16:22:39 +000030 def CALL_INDIRECT_#vt : I<(outs vt:$dst), (ins I32:$callee, variable_ops),
Dan Gohmancf4748f2015-11-12 17:04:33 +000031 [(set vt:$dst, (WebAssemblycall1 I32:$callee))],
Dan Gohman2f16f252015-11-23 22:04:06 +000032 "call_indirect\t$dst, $callee">;
JF Bastienaf111db2015-08-24 22:16:48 +000033}
34let Uses = [SP32, SP64], isCall = 1 in {
Dan Gohmand0bf9812015-09-26 01:09:44 +000035 defm : CALL<I32>;
36 defm : CALL<I64>;
37 defm : CALL<F32>;
38 defm : CALL<F64>;
Dan Gohmanf71abef2015-09-09 16:13:47 +000039
Dan Gohman05a17aa2015-09-28 16:22:39 +000040 def CALL_VOID : I<(outs), (ins global:$callee, variable_ops),
Dan Gohmancf4748f2015-11-12 17:04:33 +000041 [(WebAssemblycall0 (WebAssemblywrapper tglobaladdr:$callee))],
Dan Gohman94ef41f2015-11-18 17:05:35 +000042 "call \t$callee">;
Dan Gohman05a17aa2015-09-28 16:22:39 +000043 def CALL_INDIRECT_VOID : I<(outs), (ins I32:$callee, variable_ops),
Dan Gohmancf4748f2015-11-12 17:04:33 +000044 [(WebAssemblycall0 I32:$callee)],
Dan Gohman1031d4a2015-11-15 15:34:19 +000045 "call_indirect\t$callee">;
JF Bastienaf111db2015-08-24 22:16:48 +000046} // Uses = [SP32,SP64], isCall = 1
Dan Gohmanfb3e0592015-11-25 19:36:19 +000047
48} // Defs = [ARGUMENTS]