diff options
Diffstat (limited to 'lib/Target/WebAssembly')
| -rw-r--r-- | lib/Target/WebAssembly/WebAssemblyInstrControl.td | 26 | ||||
| -rw-r--r-- | lib/Target/WebAssembly/WebAssemblyLowerEmscriptenEHSjLj.cpp | 2 | 
2 files changed, 22 insertions, 6 deletions
| diff --git a/lib/Target/WebAssembly/WebAssemblyInstrControl.td b/lib/Target/WebAssembly/WebAssemblyInstrControl.td index 39cb1ca336f2..129794171464 100644 --- a/lib/Target/WebAssembly/WebAssemblyInstrControl.td +++ b/lib/Target/WebAssembly/WebAssemblyInstrControl.td @@ -57,17 +57,19 @@ def BR_TABLE_I64 : I<(outs), (ins I64:$index, variable_ops),  }  } // isTerminator = 1, hasCtrlDep = 1, isBarrier = 1 -// Placemarkers to indicate the start or end of a block or loop scope. These -// use/clobber VALUE_STACK to prevent them from being moved into the middle of -// an expression tree. +// Placemarkers to indicate the start or end of a block, loop, or try scope. +// These use/clobber VALUE_STACK to prevent them from being moved into the +// middle of an expression tree.  let Uses = [VALUE_STACK], Defs = [VALUE_STACK] in {  def BLOCK     : I<(outs), (ins Signature:$sig), [], "block   \t$sig", 0x02>;  def LOOP      : I<(outs), (ins Signature:$sig), [], "loop    \t$sig", 0x03>; +def TRY       : I<(outs), (ins Signature:$sig), [], "try     \t$sig", 0x06>; -// END_BLOCK, END_LOOP, and END_FUNCTION are represented with the same opcode -// in wasm. +// END_BLOCK, END_LOOP, END_TRY, and END_FUNCTION are represented with the same +// opcode in wasm.  def END_BLOCK : I<(outs), (ins), [], "end_block", 0x0b>;  def END_LOOP  : I<(outs), (ins), [], "end_loop", 0x0b>; +def END_TRY   : I<(outs), (ins), [], "end_try", 0x0b>;  let isTerminator = 1, isBarrier = 1 in  def END_FUNCTION : I<(outs), (ins), [], "end_function", 0x0b>;  } // Uses = [VALUE_STACK], Defs = [VALUE_STACK] @@ -112,6 +114,20 @@ let isReturn = 1 in {  def UNREACHABLE : I<(outs), (ins), [(trap)], "unreachable", 0x00>; +def THROW_I32 : I<(outs), (ins i32imm:$tag, I32:$obj), +                  [(int_wasm_throw imm:$tag, I32:$obj)], "throw   \t$tag, $obj", +                  0x08>; +def THROW_I64 : I<(outs), (ins i32imm:$tag, I64:$obj), +                  [(int_wasm_throw imm:$tag, I64:$obj)], "throw   \t$tag, $obj", +                  0x08>; +def RETHROW : I<(outs), (ins i32imm:$rel_depth), [], "rethrow \t$rel_depth", +                0x09>; +  } // isTerminator = 1, hasCtrlDep = 1, isBarrier = 1  } // Defs = [ARGUMENTS] + +// rethrow takes a relative depth as an argument, for which currently only 0 is +// possible for C++. Once other languages need depths other than 0, depths will +// be computed in CFGStackify. +def : Pat<(int_wasm_rethrow), (RETHROW 0)>; diff --git a/lib/Target/WebAssembly/WebAssemblyLowerEmscriptenEHSjLj.cpp b/lib/Target/WebAssembly/WebAssemblyLowerEmscriptenEHSjLj.cpp index 947c0329bb6e..f0b6a3e35dba 100644 --- a/lib/Target/WebAssembly/WebAssemblyLowerEmscriptenEHSjLj.cpp +++ b/lib/Target/WebAssembly/WebAssemblyLowerEmscriptenEHSjLj.cpp @@ -897,7 +897,7 @@ bool WebAssemblyLowerEmscriptenEHSjLj::runEHOnFunction(Function &F) {      }    } -  // Look for orphan landingpads, can occur in blocks with no predecesors +  // Look for orphan landingpads, can occur in blocks with no predecessors    for (BasicBlock &BB : F) {      Instruction *I = BB.getFirstNonPHI();      if (auto *LPI = dyn_cast<LandingPadInst>(I)) | 
