2015-12-08 11:36:00 +08:00
|
|
|
//=- WebAssemblyInstrFormats.td - WebAssembly Instr. Formats -*- tablegen -*-=//
|
2015-06-30 07:51:55 +08:00
|
|
|
//
|
2019-01-19 16:50:56 +08:00
|
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
2015-06-30 07:51:55 +08:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
2015-07-11 02:23:10 +08:00
|
|
|
///
|
|
|
|
/// \file
|
2018-05-01 23:54:18 +08:00
|
|
|
/// WebAssembly instruction format definitions.
|
2015-07-11 02:23:10 +08:00
|
|
|
///
|
2015-06-30 07:51:55 +08:00
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2015-08-25 06:16:48 +08:00
|
|
|
// WebAssembly Instruction Format.
|
2018-06-19 05:22:44 +08:00
|
|
|
// We instantiate 2 of these for every actual instruction (register based
|
|
|
|
// and stack based), see below.
|
2018-10-23 05:55:26 +08:00
|
|
|
class WebAssemblyInst<bits<32> inst, string asmstr, string stack> : StackRel,
|
|
|
|
Instruction {
|
|
|
|
bits<32> Inst = inst; // Instruction encoding.
|
|
|
|
string StackBased = stack;
|
|
|
|
string BaseName = NAME;
|
2015-06-30 07:51:55 +08:00
|
|
|
let Namespace = "WebAssembly";
|
|
|
|
let Pattern = [];
|
2015-11-06 04:42:30 +08:00
|
|
|
let AsmString = asmstr;
|
[WebAssembly] Make disassembler always emit most canonical name.
Summary:
There are a few instructions that all map to the same opcode, so
when disassembling, we have to pick one. That was just the first one
before (the except_ref variant in the case of "call"), now it is the
one marked as IsCanonical in tablegen, or failing that, the shortest
name (which is typically the "canonical" one).
Also introduced a canonical "end" instruction for this purpose.
Reviewers: dschuff, tlively
Subscribers: sbc100, jgravelle-google, aheejin, llvm-commits, sunfish
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D57713
llvm-svn: 353131
2019-02-05 09:19:45 +08:00
|
|
|
// When there are multiple instructions that map to the same encoding (in
|
|
|
|
// e.g. the disassembler use case) prefer the one where IsCanonical == 1.
|
|
|
|
bit IsCanonical = 0;
|
2015-06-30 07:51:55 +08:00
|
|
|
}
|
|
|
|
|
2018-06-19 05:22:44 +08:00
|
|
|
// Normal instructions. Default instantiation of a WebAssemblyInst.
|
2018-10-23 05:55:26 +08:00
|
|
|
class NI<dag oops, dag iops, list<dag> pattern, string stack,
|
|
|
|
string asmstr = "", bits<32> inst = -1>
|
2018-06-19 05:22:44 +08:00
|
|
|
: WebAssemblyInst<inst, asmstr, stack> {
|
2015-06-30 07:51:55 +08:00
|
|
|
dag OutOperandList = oops;
|
|
|
|
dag InOperandList = iops;
|
|
|
|
let Pattern = pattern;
|
2018-10-12 04:21:22 +08:00
|
|
|
let Defs = [ARGUMENTS];
|
2015-06-30 07:51:55 +08:00
|
|
|
}
|
2015-07-15 05:13:29 +08:00
|
|
|
|
2018-06-19 05:22:44 +08:00
|
|
|
// Generates both register and stack based versions of one actual instruction.
|
|
|
|
// We have 2 sets of operands (oops & iops) for the register and stack
|
|
|
|
// based version of this instruction, as well as the corresponding asmstr.
|
|
|
|
// The register versions have virtual-register operands which correspond to wasm
|
|
|
|
// locals or stack locations. Each use and def of the register corresponds to an
|
2019-01-08 14:25:55 +08:00
|
|
|
// implicit local.get / local.set or access of stack operands in wasm. These
|
2018-06-19 05:22:44 +08:00
|
|
|
// instructions are used for ISel and all MI passes. The stack versions of the
|
|
|
|
// instructions do not have register operands (they implicitly operate on the
|
2019-01-08 14:25:55 +08:00
|
|
|
// stack), and local.gets and local.sets are explicit. The register instructions
|
2018-06-19 05:22:44 +08:00
|
|
|
// are converted to their corresponding stack instructions before lowering to
|
|
|
|
// MC.
|
|
|
|
// Every instruction should want to be based on this multi-class to guarantee
|
|
|
|
// there is always an equivalent pair of instructions.
|
|
|
|
multiclass I<dag oops_r, dag iops_r, dag oops_s, dag iops_s,
|
|
|
|
list<dag> pattern_r, string asmstr_r = "", string asmstr_s = "",
|
|
|
|
bits<32> inst = -1> {
|
2018-09-22 04:53:55 +08:00
|
|
|
let isCodeGenOnly = 1 in
|
2018-10-23 05:55:26 +08:00
|
|
|
def "" : NI<oops_r, iops_r, pattern_r, "false", asmstr_r, inst>;
|
|
|
|
let BaseName = NAME in
|
|
|
|
def _S : NI<oops_s, iops_s, [], "true", asmstr_s, inst>;
|
2018-06-19 05:22:44 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// For instructions that have no register ops, so both sets are the same.
|
|
|
|
multiclass NRI<dag oops, dag iops, list<dag> pattern, string asmstr = "",
|
|
|
|
bits<32> inst = -1> {
|
|
|
|
defm "": I<oops, iops, oops, iops, pattern, asmstr, asmstr, inst>;
|
|
|
|
}
|